Skip to content

Commit

Permalink
feat(cozy-viewer): Remove Enzyme
Browse files Browse the repository at this point in the history
  • Loading branch information
Merkur39 committed Dec 20, 2024
1 parent 671625f commit 21ac02c
Show file tree
Hide file tree
Showing 14 changed files with 111 additions and 361 deletions.
8 changes: 1 addition & 7 deletions packages/cozy-viewer/jest.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,5 @@ module.exports = {
transformIgnorePatterns: ['node_modules/(?!(cozy-ui|cozy-harvest-lib))'],
transform: {
'^.+\\.(ts|tsx|js|jsx)?$': 'babel-jest'
},
globals: {
__ALLOW_HTTP__: false,
cozy: {}
},
setupFilesAfterEnv: ['<rootDir>/test/jestLib/setup.js', 'jest-canvas-mock'],
snapshotSerializers: ['enzyme-to-json/serializer']
}
}
5 changes: 1 addition & 4 deletions packages/cozy-viewer/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -32,11 +32,8 @@
"cozy-logger": "^1.16.1",
"cozy-sharing": "^17.0.0",
"cozy-ui": "^115.0.2",
"enzyme": "3.11.0",
"enzyme-adapter-react-16": "1.15.6",
"enzyme-to-json": "3.6.2",
"identity-obj-proxy": "3.0.0",
"jest-canvas-mock": "2.3.1",
"jest": "26.6.3",
"prop-types": "15.8.1",
"react-dom": "16.12.0",
"react-test-renderer": "16.12.0",
Expand Down
2 changes: 1 addition & 1 deletion packages/cozy-viewer/src/NoViewer/NoViewer.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import FileIcon from './FileIcon'
import styles from '../ViewersByFile/styles.styl'

const NoViewer = ({ file, url, renderFallbackExtraContent }) => (
<div className={styles['viewer-noviewer']}>
<div className={styles['viewer-noviewer']} data-testid="no-viewer">
<FileIcon type={file.class} />
<p className={styles['viewer-filename']}>{file.name}</p>
{renderFallbackExtraContent(file, url)}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ exports[`NoViewer should render the viewer 1`] = `
<div>
<div
class="viewer-noviewer"
data-testid="no-viewer"
>
<svg
class="styles__icon___23x3R"
Expand Down Expand Up @@ -48,6 +49,7 @@ exports[`NoViewer should render the viewer with specific extra content 1`] = `
<div>
<div
class="viewer-noviewer"
data-testid="no-viewer"
>
<svg
class="styles__icon___23x3R"
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import '@testing-library/jest-dom'
import { fireEvent, render } from '@testing-library/react'
import React from 'react'

Expand Down
1 change: 1 addition & 0 deletions packages/cozy-viewer/src/ViewersByFile/PdfJsViewer.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -133,6 +133,7 @@ export class PdfJsViewer extends Component {
<div
className={styles['viewer-pdfviewer']}
ref={ref => (this.wrapper = ref)}
data-testid="pdfjs-viewer"
>
<Document
file={url}
Expand Down
184 changes: 40 additions & 144 deletions packages/cozy-viewer/src/ViewersByFile/PdfJsViewer.spec.jsx
Original file line number Diff line number Diff line change
@@ -1,161 +1,57 @@
import { shallow } from 'enzyme'
import '@testing-library/jest-dom'
import { render } from '@testing-library/react'
import React from 'react'
import { Document } from 'react-pdf'

import { PdfJsViewer, MIN_SCALE, MAX_SCALE, MAX_PAGES } from './PdfJsViewer'
import { PdfJsViewer } from './PdfJsViewer'

jest.mock('../NoViewer/DownloadButton', () => () => (
<div data-testid="dl-btn-no-viewer">DownloadButton</div>
))

jest.mock('react-pdf', () => ({
Document: jest.fn(),
Page: jest.fn(() => <div>Page</div>)
}))

describe('PDFViewer', () => {
let component
const panGestureMock = jest.fn()
const swipeGestureMock = jest.fn()
const gesturesMock = {
get: jest.fn(type => ({
set: type === 'pan' ? panGestureMock : swipeGestureMock
}))
const setup = ({ file = {}, onLoadErrorMock } = {}) => {
Document.mockImplementation(
({ children, onLoadError = onLoadErrorMock }) => {
onLoadErrorMock && onLoadError()

return <div>{children}</div>
}
)
const defaultProps = { url: 'fake', file, t: x => x }
return render(<PdfJsViewer {...defaultProps} />)
}
beforeEach(() => {
component = shallow(
<PdfJsViewer url="test" file={{}} gestures={gesturesMock} t={x => x} />
)
})
afterEach(() => {
jest.clearAllMocks()
})

describe('desture integration', () => {
let instance
beforeEach(() => {
instance = component.instance()
})

it('should disable gestures when zooming in', () => {
instance.scaleUp()
expect(component.state('scale')).toBeGreaterThan(1)
expect(panGestureMock).toHaveBeenCalledWith({ enable: false })
expect(swipeGestureMock).toHaveBeenCalledWith({ enable: false })
instance.scaleUp()
expect(panGestureMock).toHaveBeenCalledTimes(1)
expect(swipeGestureMock).toHaveBeenCalledTimes(1)
})

it('should leave gestures alone when zooming out', () => {
instance.scaleDown()
expect(component.state('scale')).toBeLessThan(1)
expect(panGestureMock).not.toHaveBeenCalled()
expect(swipeGestureMock).not.toHaveBeenCalled()
})

it('should re-enable gestures when zooming back out', () => {
instance.scaleUp()
expect(component.state('scale')).toBeGreaterThan(1)
expect(panGestureMock).toHaveBeenCalledWith({ enable: false })
expect(swipeGestureMock).toHaveBeenCalledWith({ enable: false })
instance.scaleDown()
expect(component.state('scale')).toBe(1)
expect(panGestureMock).toHaveBeenCalledWith({ enable: true })
expect(swipeGestureMock).toHaveBeenCalledWith({ enable: true })
})
})

describe('with a valid PDF', () => {
let instance
beforeEach(() => {
instance = component.instance()
instance.onLoadSuccess({ numPages: 3 })
})
it('should render a fallback component', () => {
const onLoadErrorMock = jest.fn()
const { getByTestId, queryByTestId } = setup({ onLoadErrorMock })

it('should start with default options', () => {
expect(component.state('loaded')).toBe(true)
expect(component.state('totalPages')).toBe(3)
expect(component.state('currentPage')).toBe(1)
expect(component.state('scale')).toBe(1)
})
const DownloadBtnNoViewer = getByTestId('dl-btn-no-viewer')
const pdfjsNoViewer = getByTestId('no-viewer')
const pdfjsViewer = queryByTestId('pdfjs-viewer')

it('should flip to the next page while possible', () => {
instance.nextPage()
expect(component.state('currentPage')).toBe(2)
instance.nextPage()
expect(component.state('currentPage')).toBe(3)
instance.nextPage()
expect(component.state('currentPage')).toBe(3)
})

it('should flip to the previous page while possible', () => {
instance.nextPage()
expect(component.state('currentPage')).toBe(2)
instance.previousPage()
expect(component.state('currentPage')).toBe(1)
instance.previousPage()
expect(component.state('currentPage')).toBe(1)
})

it('should scale up to a certain point', () => {
const initialScale = component.state('scale')
instance.scaleUp()
expect(component.state('scale')).toBeGreaterThan(initialScale)

for (let i = 0; i < 10; i++) instance.scaleUp()
expect(component.state('scale')).toEqual(MAX_SCALE)
})

it('should scale down to a certain point', () => {
const initialScale = component.state('scale')
instance.scaleDown()
expect(component.state('scale')).toBeLessThan(initialScale)

for (let i = 0; i < 10; i++) instance.scaleDown()
expect(component.state('scale')).toEqual(MIN_SCALE)
})
expect(pdfjsViewer).toBeNull()
expect(DownloadBtnNoViewer).toBeInTheDocument()
expect(pdfjsNoViewer).toBeInTheDocument()
})

describe('a PDF with few pages', () => {
beforeEach(() => {
component.instance().onLoadSuccess({ numPages: MAX_PAGES })
})

it('should render all the pages', () => {
const pages = component.find('ForwardRef(Page)')
expect(pages.length).toEqual(MAX_PAGES)
})
it('should not render the fallback component', () => {
const { queryByTestId, getByTestId } = setup()

it('should not show pagination controls', () => {
const pageUp = component.find({ icon: 'top' })
const pageDown = component.find({ icon: 'bottom' })
expect(pageUp.length).toEqual(0)
expect(pageDown.length).toEqual(0)
})
})

describe('a PDF with many pages', () => {
beforeEach(() => {
component.instance().onLoadSuccess({ numPages: MAX_PAGES + 1 })
})

it('should render only the current page', () => {
const pages = component.find('ForwardRef(Page)')
expect(pages.length).toEqual(1)
})

it('should show pagination controls', () => {
const pageUp = component.find({ icon: 'top' })
const pageDown = component.find({ icon: 'bottom' })
expect(pageUp.length).toEqual(1)
expect(pageDown.length).toEqual(1)
})
})
const pdfjsViewer = getByTestId('pdfjs-viewer')
const pdfjsNoViewer = queryByTestId('no-viewer')
const DownloadBtnNoViewer = queryByTestId('dl-btn-no-viewer')

describe('with a pdf that does not load', () => {
beforeEach(() => {
jest.spyOn(console, 'warn').mockImplementation(() => {})
})
afterEach(() => {
// eslint-disable-next-line no-console
console.warn.mockRestore()
})
it('should show a fallback', () => {
component.instance().onLoadError('pdfviewer test error')
expect(component.state('errored')).toBe(true)
const noViewer = component.find('NoViewer')
expect(noViewer.length).toBe(1)
})
expect(pdfjsViewer).toBeInTheDocument()
expect(pdfjsNoViewer).toBeNull()
expect(DownloadBtnNoViewer).toBeNull()
})
})
3 changes: 2 additions & 1 deletion packages/cozy-viewer/src/ViewersByFile/TextViewer.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,14 +22,15 @@ const MarkdownRenderer = ({ text }) => (
const PlainTextRenderer = ({ text }) => (
<pre
className={cx(styles['viewer-textviewer-content'], 'u-mh-auto', 'u-mv-2')}
data-testid="viewer-plaintext"
>
{text}
</pre>
)

const Loader = () => {
return (
<div className={styles['viewer-textviewer']}>
<div className={styles['viewer-textviewer']} data-testid="viewer-spinner">
<ViewerSpinner />
</div>
)
Expand Down
Loading

0 comments on commit 21ac02c

Please sign in to comment.