mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-02-08 00:50:05 +00:00
233 lines
6.2 KiB
TypeScript
233 lines
6.2 KiB
TypeScript
import { createPinia, setActivePinia } from 'pinia'
|
|
|
|
import { api } from '@/scripts/api'
|
|
import { app } from '@/scripts/app'
|
|
import { getSettingInfo, useSettingStore } from '@/stores/settingStore'
|
|
import type { SettingParams } from '@/types/settingTypes'
|
|
|
|
// Mock the api
|
|
jest.mock('@/scripts/api', () => ({
|
|
api: {
|
|
getSettings: jest.fn(),
|
|
storeSetting: jest.fn()
|
|
}
|
|
}))
|
|
|
|
// Mock the app
|
|
jest.mock('@/scripts/app', () => ({
|
|
app: {
|
|
ui: {
|
|
settings: {
|
|
dispatchChange: jest.fn()
|
|
}
|
|
}
|
|
}
|
|
}))
|
|
|
|
describe('useSettingStore', () => {
|
|
let store: ReturnType<typeof useSettingStore>
|
|
|
|
beforeEach(() => {
|
|
setActivePinia(createPinia())
|
|
store = useSettingStore()
|
|
jest.clearAllMocks()
|
|
})
|
|
|
|
it('should initialize with empty settings', () => {
|
|
expect(store.settingValues).toEqual({})
|
|
expect(store.settingsById).toEqual({})
|
|
expect(store.settingTree.children).toEqual([])
|
|
})
|
|
|
|
describe('loadSettingValues', () => {
|
|
it('should load settings from API', async () => {
|
|
const mockSettings = { 'test.setting': 'value' }
|
|
;(api.getSettings as jest.Mock).mockResolvedValue(mockSettings)
|
|
|
|
await store.loadSettingValues()
|
|
|
|
expect(store.settingValues).toEqual(mockSettings)
|
|
expect(api.getSettings).toHaveBeenCalled()
|
|
})
|
|
|
|
it('should throw error if settings are loaded after registration', async () => {
|
|
const setting: SettingParams = {
|
|
id: 'test.setting',
|
|
name: 'test.setting',
|
|
type: 'text',
|
|
defaultValue: 'default'
|
|
}
|
|
store.addSetting(setting)
|
|
|
|
await expect(store.loadSettingValues()).rejects.toThrow(
|
|
'Setting values must be loaded before any setting is registered.'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('addSetting', () => {
|
|
it('should register a new setting', () => {
|
|
const setting: SettingParams = {
|
|
id: 'test.setting',
|
|
name: 'test.setting',
|
|
type: 'text',
|
|
defaultValue: 'default'
|
|
}
|
|
|
|
store.addSetting(setting)
|
|
|
|
expect(store.settingsById['test.setting']).toEqual(setting)
|
|
})
|
|
|
|
it('should throw error for duplicate setting ID', () => {
|
|
const setting: SettingParams = {
|
|
id: 'test.setting',
|
|
name: 'test.setting',
|
|
type: 'text',
|
|
defaultValue: 'default'
|
|
}
|
|
|
|
store.addSetting(setting)
|
|
expect(() => store.addSetting(setting)).toThrow(
|
|
'Setting test.setting must have a unique ID.'
|
|
)
|
|
})
|
|
|
|
it('should migrate deprecated values', () => {
|
|
const setting: SettingParams = {
|
|
id: 'test.setting',
|
|
name: 'test.setting',
|
|
type: 'text',
|
|
defaultValue: 'default',
|
|
migrateDeprecatedValue: (value: string) => value.toUpperCase()
|
|
}
|
|
|
|
store.settingValues['test.setting'] = 'oldvalue'
|
|
store.addSetting(setting)
|
|
|
|
expect(store.settingValues['test.setting']).toBe('OLDVALUE')
|
|
})
|
|
})
|
|
|
|
describe('get and set', () => {
|
|
it('should get default value when setting not exists', () => {
|
|
const setting: SettingParams = {
|
|
id: 'test.setting',
|
|
name: 'test.setting',
|
|
type: 'text',
|
|
defaultValue: 'default'
|
|
}
|
|
store.addSetting(setting)
|
|
|
|
expect(store.get('test.setting')).toBe('default')
|
|
})
|
|
|
|
it('should set value and trigger onChange', async () => {
|
|
const onChangeMock = jest.fn()
|
|
const dispatchChangeMock = app.ui.settings.dispatchChange as jest.Mock
|
|
const setting: SettingParams = {
|
|
id: 'test.setting',
|
|
name: 'test.setting',
|
|
type: 'text',
|
|
defaultValue: 'default',
|
|
onChange: onChangeMock
|
|
}
|
|
store.addSetting(setting)
|
|
// Adding the new setting should trigger onChange
|
|
expect(onChangeMock).toHaveBeenCalledTimes(1)
|
|
expect(dispatchChangeMock).toHaveBeenCalledTimes(1)
|
|
|
|
await store.set('test.setting', 'newvalue')
|
|
|
|
expect(store.get('test.setting')).toBe('newvalue')
|
|
expect(onChangeMock).toHaveBeenCalledWith('newvalue', 'default')
|
|
expect(onChangeMock).toHaveBeenCalledTimes(2)
|
|
expect(dispatchChangeMock).toHaveBeenCalledTimes(2)
|
|
expect(api.storeSetting).toHaveBeenCalledWith('test.setting', 'newvalue')
|
|
|
|
// Set the same value again, it should not trigger onChange
|
|
await store.set('test.setting', 'newvalue')
|
|
expect(onChangeMock).toHaveBeenCalledTimes(2)
|
|
expect(dispatchChangeMock).toHaveBeenCalledTimes(2)
|
|
|
|
// Set a different value, it should trigger onChange
|
|
await store.set('test.setting', 'differentvalue')
|
|
expect(onChangeMock).toHaveBeenCalledWith('differentvalue', 'newvalue')
|
|
expect(onChangeMock).toHaveBeenCalledTimes(3)
|
|
expect(dispatchChangeMock).toHaveBeenCalledTimes(3)
|
|
expect(api.storeSetting).toHaveBeenCalledWith(
|
|
'test.setting',
|
|
'differentvalue'
|
|
)
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('getSettingInfo', () => {
|
|
const baseSetting: SettingParams = {
|
|
id: 'test.setting',
|
|
name: 'test.setting',
|
|
type: 'text',
|
|
defaultValue: 'default'
|
|
}
|
|
|
|
it('should handle settings with explicit category array', () => {
|
|
const setting: SettingParams = {
|
|
...baseSetting,
|
|
id: 'test.setting',
|
|
category: ['Main', 'Sub', 'Detail']
|
|
}
|
|
|
|
const result = getSettingInfo(setting)
|
|
|
|
expect(result).toEqual({
|
|
category: 'Main',
|
|
subCategory: 'Sub'
|
|
})
|
|
})
|
|
|
|
it('should handle settings with id-based categorization', () => {
|
|
const setting: SettingParams = {
|
|
...baseSetting,
|
|
id: 'main.sub.setting.name'
|
|
}
|
|
|
|
const result = getSettingInfo(setting)
|
|
|
|
expect(result).toEqual({
|
|
category: 'main',
|
|
subCategory: 'sub'
|
|
})
|
|
})
|
|
|
|
it('should use "Other" as default subCategory when missing', () => {
|
|
const setting: SettingParams = {
|
|
...baseSetting,
|
|
id: 'single.setting',
|
|
category: ['single']
|
|
}
|
|
|
|
const result = getSettingInfo(setting)
|
|
|
|
expect(result).toEqual({
|
|
category: 'single',
|
|
subCategory: 'Other'
|
|
})
|
|
})
|
|
|
|
it('should use "Other" as default category when missing', () => {
|
|
const setting: SettingParams = {
|
|
...baseSetting,
|
|
id: 'single.setting',
|
|
category: []
|
|
}
|
|
|
|
const result = getSettingInfo(setting)
|
|
|
|
expect(result).toEqual({
|
|
category: 'Other',
|
|
subCategory: 'Other'
|
|
})
|
|
})
|
|
})
|