1
0
mirror of https://github.com/h3poteto/whalebird-desktop synced 2025-01-24 14:41:16 +01:00
Whalebird-desktop-client-ma.../spec/renderer/integration/store/Preferences/Language.spec.ts
2019-03-28 23:35:25 +09:00

66 lines
1.6 KiB
TypeScript

import { createLocalVue } from '@vue/test-utils'
import Vuex from 'vuex'
import { ipcMain } from '~/spec/mock/electron'
import Language from '@/store/Preferences/Language'
import DefaultLanguage from '~/src/constants/language'
const state = () => {
return {
language: {
language: DefaultLanguage.en.key
}
}
}
const initStore = () => {
return {
namespaced: true,
state: state,
actions: Language.actions,
mutations: Language.mutations
}
}
describe('Preferences/Language', () => {
let store
let localVue
beforeEach(() => {
localVue = createLocalVue()
localVue.use(Vuex)
store = new Vuex.Store({
modules: {
Language: initStore()
}
})
})
describe('loadLanguage', () => {
beforeEach(() => {
ipcMain.once('get-preferences', (event: any, _) => {
event.sender.send('response-get-preferences', {
language: {
language: DefaultLanguage.ja.key
}
})
})
})
it('should be updated', async () => {
await store.dispatch('Language/loadLanguage')
expect(store.state.Language.language.language).toEqual(DefaultLanguage.ja.key)
})
})
describe('changeLanguage', () => {
beforeEach(() => {
ipcMain.once('change-language', (event: any, key: string) => {
event.sender.send('response-change-language', key)
})
})
it('should be changed', async () => {
await store.dispatch('Language/changeLanguage', DefaultLanguage.ja.key)
expect(store.state.Language.language.language).toEqual(DefaultLanguage.ja.key)
})
})
})