107 lines
2.4 KiB
TypeScript
107 lines
2.4 KiB
TypeScript
import { createLocalVue } from '@vue/test-utils'
|
|
import Vuex from 'vuex'
|
|
import { ipcMain, ipcRenderer } from '~/spec/mock/electron'
|
|
import Notification, { NotificationState } from '@/store/Preferences/Notification'
|
|
import { MyWindow } from '~/src/types/global'
|
|
;((window as any) as MyWindow).ipcRenderer = ipcRenderer
|
|
|
|
const state = (): NotificationState => {
|
|
return {
|
|
notification: {
|
|
notify: {
|
|
reply: true,
|
|
reblog: true,
|
|
favourite: true,
|
|
follow: true,
|
|
reaction: true
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
const initStore = () => {
|
|
return {
|
|
namespaced: true,
|
|
state: state(),
|
|
actions: Notification.actions,
|
|
mutations: Notification.mutations
|
|
}
|
|
}
|
|
|
|
const App = {
|
|
namespaced: true,
|
|
actions: {
|
|
loadPreferences: jest.fn()
|
|
}
|
|
}
|
|
|
|
describe('Preferences/Notification', () => {
|
|
let store
|
|
let localVue
|
|
|
|
beforeEach(() => {
|
|
localVue = createLocalVue()
|
|
localVue.use(Vuex)
|
|
store = new Vuex.Store({
|
|
modules: {
|
|
Notification: initStore(),
|
|
App: App
|
|
}
|
|
})
|
|
})
|
|
|
|
describe('loadNotification', () => {
|
|
beforeEach(() => {
|
|
ipcMain.once('get-preferences', (event: any, _) => {
|
|
event.sender.send('response-get-preferences', {
|
|
notification: {
|
|
notify: {
|
|
reply: false,
|
|
reblog: false,
|
|
favourite: false,
|
|
follow: false,
|
|
reaction: false
|
|
}
|
|
}
|
|
})
|
|
})
|
|
it('should be updated', async () => {
|
|
await store.dispatch('Notification/loadNotification')
|
|
expect(store.state.Notification.notification).toEqual({
|
|
notify: {
|
|
reply: false,
|
|
reblog: false,
|
|
favourite: false,
|
|
follow: false,
|
|
reaction: false
|
|
}
|
|
})
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('updateNotify', () => {
|
|
beforeEach(() => {
|
|
ipcMain.once('update-preferences', (event: any, conf: object) => {
|
|
event.sender.send('response-update-preferences', conf)
|
|
})
|
|
})
|
|
it('should be updated', async () => {
|
|
await store.dispatch('Notification/updateNotify', {
|
|
reply: false,
|
|
reblog: false
|
|
})
|
|
expect(store.state.Notification.notification).toEqual({
|
|
notify: {
|
|
reply: false,
|
|
reblog: false,
|
|
favourite: true,
|
|
follow: true,
|
|
reaction: true
|
|
}
|
|
})
|
|
expect(App.actions.loadPreferences).toBeCalled()
|
|
})
|
|
})
|
|
})
|