mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2024-12-22 12:01:32 +00:00
test(i18n): replace e2e test for language picker with unit test
Signed-off-by: Tilman Vatteroth <git@tilmanvatteroth.de>
This commit is contained in:
parent
07a28824d3
commit
745be42101
4 changed files with 61 additions and 28 deletions
|
@ -1,28 +0,0 @@
|
|||
/*
|
||||
* SPDX-FileCopyrightText: 2022 The HedgeDoc developers (see AUTHORS file)
|
||||
*
|
||||
* SPDX-License-Identifier: AGPL-3.0-only
|
||||
*/
|
||||
import { languages } from '../fixtures/languages'
|
||||
|
||||
describe('Languages', () => {
|
||||
beforeEach(() => {
|
||||
cy.visitHome()
|
||||
cy.getByCypressId('settingsButton').click()
|
||||
})
|
||||
|
||||
it('all languages are available', () => {
|
||||
cy.getByCypressId('language-picker').find('option').as('languages')
|
||||
cy.get('@languages').should('have.length', 28)
|
||||
languages.forEach((language) => {
|
||||
cy.get('@languages').contains(language)
|
||||
})
|
||||
})
|
||||
|
||||
it('language changes affect the UI', () => {
|
||||
cy.getByCypressId('language-picker').select('English')
|
||||
cy.getByCypressId('new-note-button').contains('New Note')
|
||||
cy.getByCypressId('language-picker').select('Deutsch')
|
||||
cy.getByCypressId('new-note-button').contains('Neue Notiz')
|
||||
})
|
||||
})
|
|
@ -0,0 +1,22 @@
|
|||
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
||||
|
||||
exports[`language picker renders all languages 1`] = `
|
||||
<div>
|
||||
<select
|
||||
as="select"
|
||||
class="w-auto form-select"
|
||||
data-testid="language-picker"
|
||||
>
|
||||
<option
|
||||
value="de"
|
||||
>
|
||||
Deutsch
|
||||
</option>
|
||||
<option
|
||||
value="en"
|
||||
>
|
||||
English
|
||||
</option>
|
||||
</select>
|
||||
</div>
|
||||
`;
|
|
@ -0,0 +1,37 @@
|
|||
/*
|
||||
* SPDX-FileCopyrightText: 2023 The HedgeDoc developers (see AUTHORS file)
|
||||
*
|
||||
* SPDX-License-Identifier: AGPL-3.0-only
|
||||
*/
|
||||
import { mockI18n } from '../../../../test-utils/mock-i18n'
|
||||
import { LanguagePicker } from './language-picker'
|
||||
import { fireEvent, render, screen } from '@testing-library/react'
|
||||
import i18n from 'i18next'
|
||||
|
||||
jest.mock('./available-languages', () => ({
|
||||
availableLanguages: jest.fn(() => ['de', 'en'])
|
||||
}))
|
||||
|
||||
describe('language picker', () => {
|
||||
beforeAll(() => mockI18n())
|
||||
|
||||
it('renders all languages', () => {
|
||||
const view = render(<LanguagePicker />)
|
||||
expect(view.container).toMatchSnapshot()
|
||||
expect(i18n.language).toBe('en')
|
||||
})
|
||||
|
||||
it('can change the language', async () => {
|
||||
render(<LanguagePicker />)
|
||||
|
||||
const option: HTMLOptionElement = await screen.findByText('Deutsch')
|
||||
|
||||
expect(option.selected).toBeFalsy()
|
||||
expect(i18n.language).toBe('en')
|
||||
|
||||
fireEvent.change(screen.getByTestId('language-picker'), { target: { value: 'de' } })
|
||||
|
||||
expect(option.selected).toBeTruthy()
|
||||
expect(i18n.language).toBe('de')
|
||||
})
|
||||
})
|
|
@ -5,6 +5,7 @@
|
|||
*/
|
||||
import { cypressId } from '../../../../utils/cypress-attribute'
|
||||
import { Logger } from '../../../../utils/logger'
|
||||
import { testId } from '../../../../utils/test-id'
|
||||
import { availableLanguages } from './available-languages'
|
||||
import { LanguageOption } from './language-option'
|
||||
import React, { useCallback, useMemo } from 'react'
|
||||
|
@ -59,6 +60,7 @@ export const LanguagePicker: React.FC = () => {
|
|||
className='w-auto'
|
||||
value={languageCode}
|
||||
onChange={onChangeLang}
|
||||
{...testId('language-picker')}
|
||||
{...cypressId('language-picker')}>
|
||||
{languageOptions}
|
||||
</Form.Select>
|
||||
|
|
Loading…
Reference in a new issue