* fix: there is a case where app selects incorrect engine variant first launch * refactor: clean up legacy settings hook
111 lines
2.9 KiB
TypeScript
111 lines
2.9 KiB
TypeScript
/**
|
|
* @jest-environment jsdom
|
|
*/
|
|
|
|
import React from 'react'
|
|
import { render, screen, fireEvent, waitFor } from '@testing-library/react'
|
|
import '@testing-library/jest-dom'
|
|
import Advanced from '.'
|
|
|
|
class ResizeObserverMock {
|
|
observe() {}
|
|
unobserve() {}
|
|
disconnect() {}
|
|
}
|
|
|
|
global.ResizeObserver = ResizeObserverMock
|
|
global.window.core = {
|
|
api: {
|
|
getAppConfigurations: () => jest.fn(),
|
|
updateAppConfiguration: () => jest.fn(),
|
|
relaunch: () => jest.fn(),
|
|
},
|
|
}
|
|
|
|
|
|
jest.mock('@/containers/Toast')
|
|
|
|
jest.mock('@janhq/core', () => ({
|
|
__esModule: true,
|
|
...jest.requireActual('@janhq/core'),
|
|
fs: {
|
|
rm: jest.fn(),
|
|
},
|
|
}))
|
|
|
|
// Simulate a full advanced settings screen
|
|
// @ts-ignore
|
|
global.isMac = false
|
|
// @ts-ignore
|
|
global.isWindows = true
|
|
|
|
describe('Advanced', () => {
|
|
it('renders the component', async () => {
|
|
render(<Advanced />)
|
|
await waitFor(() => {
|
|
expect(screen.getByText('Experimental Mode')).toBeInTheDocument()
|
|
expect(screen.getByText('HTTPS Proxy')).toBeInTheDocument()
|
|
expect(screen.getByText('Jan Data Folder')).toBeInTheDocument()
|
|
expect(screen.getByText('Reset to Factory Settings')).toBeInTheDocument()
|
|
})
|
|
})
|
|
|
|
it('updates Experimental enabled', async () => {
|
|
render(<Advanced />)
|
|
let experimentalToggle
|
|
await waitFor(() => {
|
|
experimentalToggle = screen.getByTestId(/experimental-switch/i)
|
|
fireEvent.click(experimentalToggle!)
|
|
})
|
|
expect(experimentalToggle).toBeChecked()
|
|
})
|
|
|
|
it('updates Experimental disabled', async () => {
|
|
render(<Advanced />)
|
|
|
|
let experimentalToggle
|
|
await waitFor(() => {
|
|
experimentalToggle = screen.getByTestId(/experimental-switch/i)
|
|
fireEvent.click(experimentalToggle!)
|
|
})
|
|
expect(experimentalToggle).not.toBeChecked()
|
|
})
|
|
|
|
it('toggles proxy enabled', async () => {
|
|
render(<Advanced />)
|
|
let proxyToggle
|
|
await waitFor(() => {
|
|
expect(screen.getByText('HTTPS Proxy')).toBeInTheDocument()
|
|
proxyToggle = screen.getByTestId(/proxy-switch/i)
|
|
fireEvent.click(proxyToggle)
|
|
})
|
|
expect(proxyToggle).toBeChecked()
|
|
})
|
|
|
|
|
|
it('renders DataFolder component', async () => {
|
|
render(<Advanced />)
|
|
await waitFor(() => {
|
|
expect(screen.getByText('Jan Data Folder')).toBeInTheDocument()
|
|
expect(screen.getByTestId(/jan-data-folder-input/i)).toBeInTheDocument()
|
|
})
|
|
})
|
|
|
|
it('renders FactoryReset component', async () => {
|
|
render(<Advanced />)
|
|
await waitFor(() => {
|
|
expect(screen.getByText('Reset to Factory Settings')).toBeInTheDocument()
|
|
expect(screen.getByTestId(/reset-button/i)).toBeInTheDocument()
|
|
})
|
|
})
|
|
|
|
it('renders DeleteAllThreads component', async () => {
|
|
render(<Advanced />)
|
|
await waitFor(() => {
|
|
const elements = screen.getAllByText('Delete All Threads')
|
|
expect(elements.length).toBeGreaterThan(0)
|
|
expect(screen.getByTestId('delete-all-threads-button')).toBeInTheDocument()
|
|
})
|
|
})
|
|
})
|