mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-03-18 18:11:02 -07:00
113 lines
3.4 KiB
TypeScript
113 lines
3.4 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2025 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
import { useSnowfall } from './useSnowfall.js';
|
|
import { themeManager } from '../themes/theme-manager.js';
|
|
import { renderHookWithProviders } from '../../test-utils/render.js';
|
|
import { act } from 'react';
|
|
import { debugState } from '../debug.js';
|
|
import type { Theme } from '../themes/theme.js';
|
|
import type { UIState } from '../contexts/UIStateContext.js';
|
|
|
|
vi.mock('../themes/theme-manager.js', () => ({
|
|
themeManager: {
|
|
getActiveTheme: vi.fn(),
|
|
setTerminalBackground: vi.fn(),
|
|
getAllThemes: vi.fn(() => []),
|
|
setActiveTheme: vi.fn(),
|
|
},
|
|
DEFAULT_THEME: { name: 'Default' },
|
|
}));
|
|
|
|
vi.mock('../themes/holiday.js', () => ({
|
|
Holiday: { name: 'Holiday' },
|
|
}));
|
|
|
|
vi.mock('./useTerminalSize.js', () => ({
|
|
useTerminalSize: vi.fn(() => ({ columns: 120, rows: 20 })),
|
|
}));
|
|
|
|
describe('useSnowfall', () => {
|
|
const mockArt = 'LOGO';
|
|
|
|
beforeEach(() => {
|
|
vi.clearAllMocks();
|
|
vi.useFakeTimers();
|
|
vi.mocked(themeManager.getActiveTheme).mockReturnValue({
|
|
name: 'Holiday',
|
|
} as Theme);
|
|
vi.setSystemTime(new Date('2025-12-25'));
|
|
debugState.debugNumAnimatedComponents = 0;
|
|
});
|
|
|
|
afterEach(() => {
|
|
vi.useRealTimers();
|
|
});
|
|
|
|
it('initially enables animation during holiday season with Holiday theme', () => {
|
|
const { result } = renderHookWithProviders(() => useSnowfall(mockArt), {
|
|
uiState: { history: [], historyRemountKey: 0 } as Partial<UIState>,
|
|
});
|
|
|
|
// Should contain holiday trees
|
|
expect(result.current).toContain('|_|');
|
|
// Should have started animation
|
|
expect(debugState.debugNumAnimatedComponents).toBeGreaterThan(0);
|
|
});
|
|
|
|
it('stops animation after 15 seconds', () => {
|
|
const { result } = renderHookWithProviders(() => useSnowfall(mockArt), {
|
|
uiState: { history: [], historyRemountKey: 0 } as Partial<UIState>,
|
|
});
|
|
|
|
expect(debugState.debugNumAnimatedComponents).toBeGreaterThan(0);
|
|
|
|
act(() => {
|
|
vi.advanceTimersByTime(15001);
|
|
});
|
|
|
|
// Animation should be stopped
|
|
expect(debugState.debugNumAnimatedComponents).toBe(0);
|
|
// Should no longer contain trees
|
|
expect(result.current).toBe(mockArt);
|
|
});
|
|
|
|
it('does not enable animation if not holiday season', () => {
|
|
vi.setSystemTime(new Date('2025-06-15'));
|
|
const { result } = renderHookWithProviders(() => useSnowfall(mockArt), {
|
|
uiState: { history: [], historyRemountKey: 0 } as Partial<UIState>,
|
|
});
|
|
|
|
expect(result.current).toBe(mockArt);
|
|
expect(debugState.debugNumAnimatedComponents).toBe(0);
|
|
});
|
|
|
|
it('does not enable animation if theme is not Holiday', () => {
|
|
vi.mocked(themeManager.getActiveTheme).mockReturnValue({
|
|
name: 'Default',
|
|
} as Theme);
|
|
const { result } = renderHookWithProviders(() => useSnowfall(mockArt), {
|
|
uiState: { history: [], historyRemountKey: 0 } as Partial<UIState>,
|
|
});
|
|
|
|
expect(result.current).toBe(mockArt);
|
|
expect(debugState.debugNumAnimatedComponents).toBe(0);
|
|
});
|
|
|
|
it('does not enable animation if chat has started', () => {
|
|
const { result } = renderHookWithProviders(() => useSnowfall(mockArt), {
|
|
uiState: {
|
|
history: [{ type: 'user', text: 'hello' }],
|
|
historyRemountKey: 0,
|
|
} as Partial<UIState>,
|
|
});
|
|
|
|
expect(result.current).toBe(mockArt);
|
|
expect(debugState.debugNumAnimatedComponents).toBe(0);
|
|
});
|
|
});
|