mirror of
https://github.com/willmiao/ComfyUI-Lora-Manager.git
synced 2026-03-24 06:32:12 -03:00
test(frontend): extend coverage for comfyui widgets and helpers
This commit is contained in:
108
tests/frontend/utils/uiHelpers.dom.test.js
Normal file
108
tests/frontend/utils/uiHelpers.dom.test.js
Normal file
@@ -0,0 +1,108 @@
|
||||
import { describe, it, beforeEach, afterEach, expect, vi } from 'vitest';
|
||||
|
||||
const {
|
||||
I18N_MODULE,
|
||||
STATE_MODULE,
|
||||
STORAGE_MODULE,
|
||||
CONSTANTS_MODULE,
|
||||
EVENT_MANAGER_MODULE,
|
||||
UI_HELPERS_MODULE,
|
||||
} = vi.hoisted(() => ({
|
||||
I18N_MODULE: new URL('../../../static/js/utils/i18nHelpers.js', import.meta.url).pathname,
|
||||
STATE_MODULE: new URL('../../../static/js/state/index.js', import.meta.url).pathname,
|
||||
STORAGE_MODULE: new URL('../../../static/js/utils/storageHelpers.js', import.meta.url).pathname,
|
||||
CONSTANTS_MODULE: new URL('../../../static/js/utils/constants.js', import.meta.url).pathname,
|
||||
EVENT_MANAGER_MODULE: new URL('../../../static/js/utils/EventManager.js', import.meta.url).pathname,
|
||||
UI_HELPERS_MODULE: new URL('../../../static/js/utils/uiHelpers.js', import.meta.url).pathname,
|
||||
}));
|
||||
|
||||
const translateMock = vi.fn((key, _params, fallback) => fallback || key);
|
||||
const getStorageItemMock = vi.fn();
|
||||
const setStorageItemMock = vi.fn();
|
||||
|
||||
vi.mock(I18N_MODULE, () => ({
|
||||
translate: translateMock,
|
||||
}));
|
||||
|
||||
vi.mock(STATE_MODULE, () => ({
|
||||
state: {},
|
||||
getCurrentPageState: vi.fn(),
|
||||
}));
|
||||
|
||||
vi.mock(STORAGE_MODULE, () => ({
|
||||
getStorageItem: getStorageItemMock,
|
||||
setStorageItem: setStorageItemMock,
|
||||
}));
|
||||
|
||||
vi.mock(CONSTANTS_MODULE, () => ({
|
||||
NODE_TYPE_ICONS: {},
|
||||
DEFAULT_NODE_COLOR: '#ffffff',
|
||||
}));
|
||||
|
||||
vi.mock(EVENT_MANAGER_MODULE, () => ({
|
||||
eventManager: {
|
||||
emit: vi.fn(),
|
||||
on: vi.fn(),
|
||||
off: vi.fn(),
|
||||
addHandler: vi.fn(),
|
||||
removeHandler: vi.fn(),
|
||||
},
|
||||
}));
|
||||
|
||||
describe('UI helper DOM utilities', () => {
|
||||
beforeEach(() => {
|
||||
document.body.innerHTML = '';
|
||||
document.body.removeAttribute('data-theme');
|
||||
document.documentElement.removeAttribute('data-theme');
|
||||
getStorageItemMock.mockReset();
|
||||
setStorageItemMock.mockReset();
|
||||
translateMock.mockReset();
|
||||
globalThis.requestAnimationFrame = (cb) => cb();
|
||||
});
|
||||
|
||||
afterEach(() => {
|
||||
vi.useRealTimers();
|
||||
});
|
||||
|
||||
it('creates toast elements and cleans them up after timeout', async () => {
|
||||
vi.useFakeTimers();
|
||||
translateMock.mockReturnValue('Toast message');
|
||||
|
||||
const { showToast } = await import(UI_HELPERS_MODULE);
|
||||
|
||||
showToast('uiHelpers.clipboard.copied', {}, 'success');
|
||||
|
||||
const container = document.querySelector('.toast-container');
|
||||
expect(container).not.toBeNull();
|
||||
expect(container.querySelectorAll('.toast')).toHaveLength(1);
|
||||
|
||||
await Promise.resolve();
|
||||
vi.advanceTimersByTime(2000);
|
||||
|
||||
const toast = container.querySelector('.toast');
|
||||
toast.dispatchEvent(new Event('transitionend', { bubbles: true }));
|
||||
await Promise.resolve();
|
||||
|
||||
expect(toast.classList.contains('show')).toBe(false);
|
||||
});
|
||||
|
||||
it('toggles the persisted theme and updates DOM attributes', async () => {
|
||||
getStorageItemMock.mockReturnValue('light');
|
||||
document.body.innerHTML = '<button class="theme-toggle"></button>';
|
||||
globalThis.matchMedia = vi.fn(() => ({
|
||||
matches: false,
|
||||
addEventListener: vi.fn(),
|
||||
removeEventListener: vi.fn(),
|
||||
}));
|
||||
|
||||
const { toggleTheme } = await import(UI_HELPERS_MODULE);
|
||||
|
||||
const nextTheme = toggleTheme();
|
||||
|
||||
expect(nextTheme).toBe('dark');
|
||||
expect(setStorageItemMock).toHaveBeenCalledWith('theme', 'dark');
|
||||
expect(document.documentElement.getAttribute('data-theme')).toBe('dark');
|
||||
expect(document.body.dataset.theme).toBe('dark');
|
||||
expect(document.querySelector('.theme-toggle').classList.contains('theme-dark')).toBe(true);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user