// @vitest-environment jsdom import { beforeEach, describe, expect, it, vi } from 'vitest' import { createPinia, setActivePinia } from 'pinia' const mockSystemApi = vi.hoisted(() => ({ fetchAvailableModels: vi.fn(), updateDefaultModel: vi.fn(), addCustomProvider: vi.fn(), removeCustomProvider: vi.fn(), })) vi.mock('@/api/hermes/system', () => mockSystemApi) import { useAppStore } from '@/stores/hermes/app' import { useModelsStore } from '@/stores/hermes/models' describe('Models Store', () => { beforeEach(() => { setActivePinia(createPinia()) vi.clearAllMocks() window.localStorage.clear() }) it('keeps the sidebar model picker in sync after provider model visibility changes', async () => { const visibleGroups = [ { provider: 'deepseek', label: 'DeepSeek', base_url: 'https://api.deepseek.com/v1', api_key: 'sk-test', models: ['deepseek-v4-flash', 'deepseek-v4-pro'], available_models: ['deepseek-v4-flash', 'deepseek-v4-pro'], model_meta: { 'deepseek-v4-pro': { preview: true }, }, }, ] mockSystemApi.fetchAvailableModels.mockResolvedValue({ default: 'deepseek-v4-flash', default_provider: 'deepseek', groups: visibleGroups, allProviders: visibleGroups, model_visibility: { deepseek: { mode: 'include', models: ['deepseek-v4-flash', 'deepseek-v4-pro'] }, }, }) const appStore = useAppStore() appStore.modelGroups = [ { provider: 'deepseek', label: 'DeepSeek', base_url: 'https://api.deepseek.com/v1', api_key: 'sk-test', models: ['deepseek-v4-flash'], available_models: ['deepseek-v4-flash', 'deepseek-v4-pro'], }, ] const modelsStore = useModelsStore() await modelsStore.fetchProviders() expect(modelsStore.providers[0].models).toEqual(['deepseek-v4-flash', 'deepseek-v4-pro']) expect(appStore.modelGroups[0].models).toEqual(['deepseek-v4-flash', 'deepseek-v4-pro']) expect(appStore.modelGroups[0].available_models).toEqual(['deepseek-v4-flash', 'deepseek-v4-pro']) expect(appStore.modelGroups[0].model_meta).toEqual({ 'deepseek-v4-pro': { preview: true }, }) expect(appStore.modelVisibility).toEqual({ deepseek: { mode: 'include', models: ['deepseek-v4-flash', 'deepseek-v4-pro'] }, }) expect(appStore.selectedModel).toBe('deepseek-v4-flash') expect(appStore.selectedProvider).toBe('deepseek') }) })