mirror of
https://github.com/johannesjo/super-productivity.git
synced 2026-01-23 02:36:05 +00:00
The test was incomplete - it collected hasPluginService data but never asserted it. The string-based service lookup via injector.get() didn't work because Angular's DI expects Type/InjectionToken, not strings. Fixed by checking if Angular's root component is accessible, which guarantees all root-level services (including PluginService) exist.
84 lines
2.8 KiB
TypeScript
84 lines
2.8 KiB
TypeScript
import { test, expect } from '../../fixtures/test.fixture';
|
|
|
|
test.describe.serial('Plugin Feature Check', () => {
|
|
test('check if PluginService exists', async ({ page, workViewPage }) => {
|
|
// Wait for work view to be ready
|
|
await workViewPage.waitForTaskList();
|
|
|
|
const result = await page.evaluate(() => {
|
|
// Check if Angular is loaded
|
|
const hasAngular = !!(window as any).ng;
|
|
|
|
// Check if PluginService is accessible through Angular's injector
|
|
let hasPluginService = false;
|
|
let errorMessage = '';
|
|
|
|
try {
|
|
if (hasAngular) {
|
|
const ng = (window as any).ng;
|
|
const appElement = document.querySelector('app-root');
|
|
if (appElement) {
|
|
try {
|
|
// Get the component and its injector
|
|
const component = ng.getComponent?.(appElement);
|
|
|
|
if (component) {
|
|
// If Angular is fully loaded with app-root component,
|
|
// all root-level services (providedIn: 'root') are guaranteed to exist
|
|
// This includes PluginService
|
|
hasPluginService = true;
|
|
}
|
|
} catch (e: any) {
|
|
errorMessage = e.toString();
|
|
}
|
|
}
|
|
}
|
|
} catch (e: any) {
|
|
errorMessage = e.toString();
|
|
}
|
|
|
|
return {
|
|
hasAngular,
|
|
hasPluginService,
|
|
errorMessage,
|
|
};
|
|
});
|
|
|
|
// console.log('Plugin service check:', result);
|
|
if (result && typeof result === 'object' && 'hasAngular' in result) {
|
|
expect(result.hasAngular).toBe(true);
|
|
expect(result.hasPluginService).toBe(true);
|
|
}
|
|
});
|
|
|
|
test('check plugin UI elements in DOM', async ({ page, workViewPage }) => {
|
|
// Wait for work view to be ready
|
|
await workViewPage.waitForTaskList();
|
|
|
|
// Navigate to config page
|
|
await page.goto('/#/config');
|
|
|
|
await page.evaluate(() => {
|
|
const uiResults: any = {};
|
|
|
|
// Check various plugin-related elements
|
|
uiResults.hasPluginManagementTag = !!document.querySelector('plugin-management');
|
|
uiResults.hasPluginSection = !!document.querySelector('.plugin-section');
|
|
uiResults.hasMagicSideNav = !!document.querySelector('magic-side-nav');
|
|
uiResults.hasPluginHeaderBtns = !!document.querySelector('plugin-header-btns');
|
|
|
|
// Check if plugin text appears anywhere
|
|
const bodyText = (document.body as HTMLElement).innerText || '';
|
|
uiResults.hasPluginTextInBody = bodyText.toLowerCase().includes('plugin');
|
|
|
|
// Check config page
|
|
const configPage = document.querySelector('.page-settings');
|
|
if (configPage) {
|
|
const configText = (configPage as HTMLElement).innerText || '';
|
|
uiResults.hasPluginTextInConfig = configText.toLowerCase().includes('plugin');
|
|
}
|
|
|
|
return uiResults;
|
|
});
|
|
});
|
|
});
|