This commit is contained in:
pa
2026-03-09 02:49:59 +09:00
parent 64b27ce7f1
commit 90a17bb0ba
39 changed files with 9487 additions and 4384 deletions

View File

@@ -0,0 +1,96 @@
import { beforeEach, describe, expect, test, vi } from 'vitest';
import { createPinia, setActivePinia } from 'pinia';
const mocks = vi.hoisted(() => ({
configRepository: {
getString: vi.fn(),
setString: vi.fn()
},
changeLogRemoveLinks: vi.fn((value) => value),
toast: {
error: vi.fn(),
success: vi.fn(),
warning: vi.fn()
}
}));
vi.mock('../../service/config', () => ({
default: mocks.configRepository
}));
vi.mock('../../shared/utils', () => ({
changeLogRemoveLinks: (...args) => mocks.changeLogRemoveLinks(...args)
}));
vi.mock('vue-sonner', () => ({
toast: mocks.toast
}));
vi.mock('vue-i18n', () => ({
useI18n: () => ({
t: (key) => key
})
}));
function flushPromises() {
return new Promise((resolve) => setTimeout(resolve, 0));
}
import { useVRCXUpdaterStore } from '../vrcxUpdater';
describe('useVRCXUpdaterStore.setAutoUpdateVRCX', () => {
beforeEach(async () => {
mocks.configRepository.getString.mockImplementation(
(key, defaultValue) => {
if (key === 'VRCX_autoUpdateVRCX') {
return Promise.resolve('Off');
}
if (key === 'VRCX_id') {
return Promise.resolve('test-vrcx-id');
}
if (key === 'VRCX_lastVRCXVersion') {
return Promise.resolve('2026.1.0');
}
return Promise.resolve(defaultValue ?? '');
}
);
mocks.configRepository.setString.mockResolvedValue(undefined);
globalThis.AppApi = {
GetVersion: vi.fn().mockResolvedValue('2026.1.0')
};
setActivePinia(createPinia());
useVRCXUpdaterStore();
await flushPromises();
vi.clearAllMocks();
});
test('sets autoUpdateVRCX to Off, clears pending flag, and persists config', async () => {
const store = useVRCXUpdaterStore();
store.pendingVRCXUpdate = true;
await store.setAutoUpdateVRCX('Off');
expect(store.autoUpdateVRCX).toBe('Off');
expect(store.pendingVRCXUpdate).toBe(false);
expect(mocks.configRepository.setString).toHaveBeenCalledWith(
'VRCX_autoUpdateVRCX',
'Off'
);
});
test('updates autoUpdateVRCX for non-Off values and keeps pending flag', async () => {
const store = useVRCXUpdaterStore();
store.pendingVRCXUpdate = true;
await store.setAutoUpdateVRCX('Notify');
expect(store.autoUpdateVRCX).toBe('Notify');
expect(store.pendingVRCXUpdate).toBe(true);
expect(mocks.configRepository.setString).toHaveBeenCalledWith(
'VRCX_autoUpdateVRCX',
'Notify'
);
});
});