Files
overleaf-cep/services/web/test/frontend/features/settings-modal/settings/stop-on-first-error-setting.test.tsx
T
David 43e96ad863 Merge pull request #29253 from overleaf/dp-settings-modal-test-improvements
Improvements to settings modal frontend tests

GitOrigin-RevId: cbf30df51aa4b290580340507ba591e863a4f83b
2025-10-23 08:05:48 +00:00

45 lines
1.5 KiB
TypeScript

import { screen, render } from '@testing-library/react'
import { expect } from 'chai'
import fetchMock from 'fetch-mock'
import { SettingsModalProvider } from '@/features/ide-redesign/contexts/settings-modal-context'
import {
EditorProviders,
projectDefaults,
} from '../../../helpers/editor-providers'
import localStorage from '@/infrastructure/local-storage'
import userEvent from '@testing-library/user-event'
import StopOnFirstErrorSetting from '@/features/ide-redesign/components/settings/compiler-settings/stop-on-first-error-setting'
describe('<StopOnFirstErrorSetting />', function () {
afterEach(function () {
fetchMock.removeRoutes().clearHistory()
})
it('can toggle', async function () {
render(
<EditorProviders>
<SettingsModalProvider>
<StopOnFirstErrorSetting />
</SettingsModalProvider>
</EditorProviders>
)
const toggle = screen.getByLabelText('Stop on first error')
const startingCheckedValue = (toggle as HTMLInputElement).checked
// Toggle the checkbox
await userEvent.click(toggle)
expect((toggle as HTMLInputElement).checked).to.equal(!startingCheckedValue)
expect(
localStorage.getItem(`stop_on_first_error:${projectDefaults._id}`)
).to.equal(!startingCheckedValue)
// Toggle back to original value
await userEvent.click(toggle)
expect((toggle as HTMLInputElement).checked).to.equal(startingCheckedValue)
expect(
!!localStorage.getItem(`stop_on_first_error:${projectDefaults._id}`)
).to.equal(startingCheckedValue)
})
})