mirror of
https://github.com/h3poteto/whalebird-desktop
synced 2024-12-12 00:45:19 +01:00
107 lines
2.8 KiB
JavaScript
107 lines
2.8 KiB
JavaScript
|
import { createLocalVue } from '@vue/test-utils'
|
||
|
import Vuex from 'vuex'
|
||
|
import { ipcMain } from '~/spec/mock/electron'
|
||
|
import App from '@/store/App'
|
||
|
import DisplayStyle from '~/src/constants/displayStyle'
|
||
|
import { LightTheme, DarkTheme } from '@/utils/theme'
|
||
|
import Theme from '~/src/constants/theme'
|
||
|
import TimeFormat from '~/src/constants/timeFormat'
|
||
|
import Language from '~/src/constants/language'
|
||
|
import DefaultFonts from '@/utils/fonts'
|
||
|
|
||
|
const state = () => {
|
||
|
return {
|
||
|
theme: LightTheme,
|
||
|
fontSize: 14,
|
||
|
displayNameStyle: DisplayStyle.DisplayNameAndUsername.value,
|
||
|
notify: {
|
||
|
reply: true,
|
||
|
reblog: true,
|
||
|
favourite: true,
|
||
|
follow: true
|
||
|
},
|
||
|
timeFormat: TimeFormat.Absolute.value,
|
||
|
language: Language.en.key,
|
||
|
defaultFonts: DefaultFonts,
|
||
|
ignoreCW: false,
|
||
|
ignoreNFSW: false
|
||
|
}
|
||
|
}
|
||
|
|
||
|
const initStore = () => {
|
||
|
return {
|
||
|
namespaced: true,
|
||
|
state: state(),
|
||
|
actions: App.actions,
|
||
|
mutations: App.mutations
|
||
|
}
|
||
|
}
|
||
|
|
||
|
describe('App', () => {
|
||
|
let store
|
||
|
let localVue
|
||
|
|
||
|
beforeEach(() => {
|
||
|
localVue = createLocalVue()
|
||
|
localVue.use(Vuex)
|
||
|
store = new Vuex.Store({
|
||
|
modules: {
|
||
|
App: initStore()
|
||
|
}
|
||
|
})
|
||
|
})
|
||
|
|
||
|
describe('loadPreferences', () => {
|
||
|
describe('error', () => {
|
||
|
it('should not change', async () => {
|
||
|
ipcMain.once('get-preferences', (event, _) => {
|
||
|
event.sender.send('error-get-preferences', new Error())
|
||
|
})
|
||
|
await store.dispatch('App/loadPreferences')
|
||
|
.catch((err) => {
|
||
|
expect(err instanceof Error).toEqual(true)
|
||
|
expect(store.state.App.theme).toEqual(LightTheme)
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
describe('success', () => {
|
||
|
it('should be changed', async () => {
|
||
|
ipcMain.once('get-preferences', (event, _) => {
|
||
|
event.sender.send('response-get-preferences', {
|
||
|
general: {
|
||
|
timeline: {
|
||
|
cw: true,
|
||
|
nfsw: true
|
||
|
}
|
||
|
},
|
||
|
language: {
|
||
|
language: Language.en.key
|
||
|
},
|
||
|
notification: {
|
||
|
notify: {
|
||
|
reply: true,
|
||
|
reblog: true,
|
||
|
favourite: true,
|
||
|
follow: true
|
||
|
}
|
||
|
},
|
||
|
appearance: {
|
||
|
theme: Theme.Dark.key,
|
||
|
fontSize: 13,
|
||
|
displayNameStyle: DisplayStyle.DisplayNameAndUsername.value,
|
||
|
timeFormat: TimeFormat.Absolute.value,
|
||
|
customThemeColor: LightTheme,
|
||
|
font: DefaultFonts[0]
|
||
|
}
|
||
|
})
|
||
|
})
|
||
|
await store.dispatch('App/loadPreferences')
|
||
|
expect(store.state.App.fontSize).toEqual(13)
|
||
|
expect(store.state.App.theme).toEqual(DarkTheme)
|
||
|
expect(store.state.App.ignoreCW).toEqual(true)
|
||
|
expect(store.state.App.ignoreNFSW).toEqual(true)
|
||
|
})
|
||
|
})
|
||
|
})
|
||
|
})
|