mirror of
https://github.com/unraid/api.git
synced 2026-05-03 21:50:20 -05:00
72860e71fe
<!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit - **New Features** - Added comprehensive test coverage for the purchase, replaceRenew, modal, notifications, theme, trial, unraidApi, unraidApiSettings, updateOs, updateOsActions, updateOsChangelog, activationCode, and callbackActions stores. - Exposed callback error state in the callbackActions store for external access. - Made error state publicly accessible in the replaceRenew store. - **Tests** - Introduced new test files covering state, getters, actions, and side effects for multiple stores including modal, notifications, purchase, replaceRenew, theme, trial, unraidApi, unraidApiSettings, updateOs, updateOsActions, updateOsChangelog, activationCode, and callbackActions. - Enhanced existing test suites with additional mocks, reactive state handling, and expanded test cases for improved coverage and robustness. - **Refactor** - Improved code clarity and readability in modal, notifications, purchase, replaceRenew, trial, theme, updateOsActions, callbackActions, and unraidApi stores through import reorganization and formatting adjustments. - Updated imports to include reactive and computed utilities for enhanced state management in several stores. - Standardized import styles and streamlined store definitions in the unraidApiSettings store. <!-- end of auto-generated comment: release notes by coderabbit.ai --> --------- Co-authored-by: mdatelle <mike@datelle.net>
167 lines
4.7 KiB
TypeScript
167 lines
4.7 KiB
TypeScript
/**
|
|
* Theme store test coverage
|
|
*/
|
|
|
|
import { nextTick } from 'vue';
|
|
import { createPinia, setActivePinia } from 'pinia';
|
|
|
|
import { defaultColors } from '~/themes/default';
|
|
import hexToRgba from 'hex-to-rgba';
|
|
import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
|
|
|
|
import { useThemeStore } from '~/store/theme';
|
|
|
|
vi.mock('hex-to-rgba', () => ({
|
|
default: vi.fn((hex, opacity) => `rgba(mock-${hex}-${opacity})`),
|
|
}));
|
|
|
|
describe('Theme Store', () => {
|
|
let store: ReturnType<typeof useThemeStore>;
|
|
const originalAddClassFn = document.body.classList.add;
|
|
const originalRemoveClassFn = document.body.classList.remove;
|
|
const originalStyleCssText = document.body.style.cssText;
|
|
|
|
beforeEach(() => {
|
|
setActivePinia(createPinia());
|
|
store = useThemeStore();
|
|
|
|
document.body.classList.add = vi.fn();
|
|
document.body.classList.remove = vi.fn();
|
|
document.body.style.cssText = '';
|
|
|
|
vi.spyOn(window, 'requestAnimationFrame').mockImplementation((cb) => {
|
|
cb(0);
|
|
return 0;
|
|
});
|
|
|
|
vi.clearAllMocks();
|
|
});
|
|
|
|
afterEach(() => {
|
|
// Restore original methods
|
|
document.body.classList.add = originalAddClassFn;
|
|
document.body.classList.remove = originalRemoveClassFn;
|
|
document.body.style.cssText = originalStyleCssText;
|
|
vi.restoreAllMocks();
|
|
});
|
|
|
|
describe('State and Initialization', () => {
|
|
it('should initialize with default theme', () => {
|
|
expect(store.theme).toEqual({
|
|
name: 'white',
|
|
banner: false,
|
|
bannerGradient: false,
|
|
bgColor: '',
|
|
descriptionShow: false,
|
|
metaColor: '',
|
|
textColor: '',
|
|
});
|
|
expect(store.activeColorVariables).toEqual(defaultColors.white);
|
|
});
|
|
|
|
it('should compute darkMode correctly', () => {
|
|
expect(store.darkMode).toBe(false);
|
|
|
|
store.setTheme({ ...store.theme, name: 'black' });
|
|
expect(store.darkMode).toBe(true);
|
|
|
|
store.setTheme({ ...store.theme, name: 'gray' });
|
|
expect(store.darkMode).toBe(true);
|
|
|
|
store.setTheme({ ...store.theme, name: 'white' });
|
|
expect(store.darkMode).toBe(false);
|
|
});
|
|
|
|
it('should compute bannerGradient correctly', () => {
|
|
expect(store.bannerGradient).toBeUndefined();
|
|
|
|
store.setTheme({
|
|
...store.theme,
|
|
banner: true,
|
|
bannerGradient: true,
|
|
});
|
|
expect(store.bannerGradient).toBe(
|
|
'background-image: linear-gradient(90deg, rgba(0, 0, 0, 0) 0, var(--header-background-color) 30%);'
|
|
);
|
|
|
|
store.setTheme({
|
|
...store.theme,
|
|
banner: true,
|
|
bannerGradient: true,
|
|
bgColor: '#123456',
|
|
});
|
|
expect(store.bannerGradient).toBe(
|
|
'background-image: linear-gradient(90deg, var(--header-gradient-start) 0, var(--header-gradient-end) 30%);'
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('Actions', () => {
|
|
it('should set theme correctly', () => {
|
|
const newTheme = {
|
|
name: 'black',
|
|
banner: true,
|
|
bannerGradient: true,
|
|
bgColor: '#123456',
|
|
descriptionShow: true,
|
|
metaColor: '#abcdef',
|
|
textColor: '#ffffff',
|
|
};
|
|
|
|
store.setTheme(newTheme);
|
|
expect(store.theme).toEqual(newTheme);
|
|
});
|
|
|
|
it('should update body classes for dark mode', async () => {
|
|
store.setTheme({ ...store.theme, name: 'black' });
|
|
|
|
await nextTick();
|
|
|
|
expect(document.body.classList.add).toHaveBeenCalledWith('dark');
|
|
|
|
store.setTheme({ ...store.theme, name: 'white' });
|
|
|
|
await nextTick();
|
|
|
|
expect(document.body.classList.remove).toHaveBeenCalledWith('dark');
|
|
});
|
|
|
|
it('should update activeColorVariables when theme changes', async () => {
|
|
store.setTheme({
|
|
...store.theme,
|
|
name: 'white',
|
|
textColor: '#333333',
|
|
metaColor: '#666666',
|
|
bgColor: '#ffffff',
|
|
});
|
|
|
|
await nextTick();
|
|
|
|
expect(store.activeColorVariables['--header-text-primary']).toBe('#333333');
|
|
expect(store.activeColorVariables['--header-text-secondary']).toBe('#666666');
|
|
expect(store.activeColorVariables['--header-background-color']).toBe('#ffffff');
|
|
});
|
|
|
|
it('should handle banner gradient correctly', async () => {
|
|
const mockHexToRgba = vi.mocked(hexToRgba);
|
|
|
|
mockHexToRgba.mockClear();
|
|
|
|
store.setTheme({
|
|
...store.theme,
|
|
banner: true,
|
|
bannerGradient: true,
|
|
bgColor: '#112233',
|
|
});
|
|
|
|
await nextTick();
|
|
|
|
expect(mockHexToRgba).toHaveBeenCalledWith('#112233', 0);
|
|
expect(mockHexToRgba).toHaveBeenCalledWith('#112233', 0.7);
|
|
|
|
expect(store.activeColorVariables['--header-gradient-start']).toBe('rgba(mock-#112233-0)');
|
|
expect(store.activeColorVariables['--header-gradient-end']).toBe('rgba(mock-#112233-0.7)');
|
|
});
|
|
});
|
|
});
|