mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-05-24 20:14:35 -04:00
refactor: organize app extensions
Signed-off-by: Tilman Vatteroth <git@tilmanvatteroth.de>
This commit is contained in:
parent
8cddc96881
commit
1e4709c087
209 changed files with 286 additions and 243 deletions
|
@ -0,0 +1,89 @@
|
|||
/*
|
||||
* SPDX-FileCopyrightText: 2023 The HedgeDoc developers (see AUTHORS file)
|
||||
*
|
||||
* SPDX-License-Identifier: AGPL-3.0-only
|
||||
*/
|
||||
import { StoreProvider } from '../../../redux/store-provider'
|
||||
import { mockI18n } from '../../../test-utils/mock-i18n'
|
||||
import { FlowChart } from './flowchart'
|
||||
import * as useMediaQuery from '@restart/hooks/useMediaQuery'
|
||||
import { render, screen } from '@testing-library/react'
|
||||
import type * as flowchartJsModule from 'flowchart.js'
|
||||
|
||||
jest.mock('@restart/hooks/useMediaQuery')
|
||||
|
||||
describe('Flowchart', () => {
|
||||
const successText = 'Flowchart rendering succeeded!'
|
||||
const expectedValidFlowchartCode = 'test code'
|
||||
|
||||
beforeAll(async () => {
|
||||
jest.spyOn(useMediaQuery, 'default').mockImplementation(() => false)
|
||||
await mockI18n()
|
||||
})
|
||||
|
||||
afterEach(() => {
|
||||
jest.resetModules()
|
||||
jest.restoreAllMocks()
|
||||
})
|
||||
|
||||
const mockFlowchartDraw = (): jest.Mock<void, Parameters<flowchartJsModule.Instance['drawSVG']>> => {
|
||||
const drawSvg = jest.fn((container: HTMLElement | string) => {
|
||||
if (typeof container === 'string') {
|
||||
throw new Error('HTMLElement expected')
|
||||
} else {
|
||||
container.innerHTML = successText
|
||||
}
|
||||
})
|
||||
jest.mock('flowchart.js', () => ({
|
||||
parse: jest.fn((code) => {
|
||||
if (code !== expectedValidFlowchartCode) {
|
||||
throw new Error('invalid flowchart code')
|
||||
}
|
||||
return { drawSVG: drawSvg, clean: jest.fn() }
|
||||
})
|
||||
}))
|
||||
return drawSvg
|
||||
}
|
||||
|
||||
it('renders correctly', async () => {
|
||||
const successText = 'Flowchart rendering succeeded!'
|
||||
const validFlowchartCode = 'test code'
|
||||
const mockDrawSvg = mockFlowchartDraw()
|
||||
|
||||
const view = render(
|
||||
<StoreProvider>
|
||||
<FlowChart code={validFlowchartCode} />
|
||||
</StoreProvider>
|
||||
)
|
||||
await screen.findByText(successText)
|
||||
expect(view.container).toMatchSnapshot()
|
||||
expect(mockDrawSvg).toBeCalled()
|
||||
})
|
||||
|
||||
it('handles error while rendering', async () => {
|
||||
const mockDrawSvg = mockFlowchartDraw()
|
||||
|
||||
const view = render(
|
||||
<StoreProvider>
|
||||
<FlowChart code={'Invalid!'} />
|
||||
</StoreProvider>
|
||||
)
|
||||
await screen.findByText('renderer.flowchart.invalidSyntax')
|
||||
expect(view.container).toMatchSnapshot()
|
||||
expect(mockDrawSvg).not.toBeCalled()
|
||||
})
|
||||
|
||||
it('handles error if lib loading failed', async () => {
|
||||
jest.mock('flowchart.js', () => {
|
||||
throw new Error('flowchart.js import is exploded!')
|
||||
})
|
||||
|
||||
const view = render(
|
||||
<StoreProvider>
|
||||
<FlowChart code={'Invalid!'} />
|
||||
</StoreProvider>
|
||||
)
|
||||
await screen.findByText('common.errorWhileLoading')
|
||||
expect(view.container).toMatchSnapshot()
|
||||
})
|
||||
})
|
Loading…
Add table
Add a link
Reference in a new issue