mirror of
https://github.com/Tencent/tmagic-editor.git
synced 2026-05-15 04:54:12 +00:00
88 lines
3.7 KiB
TypeScript
88 lines
3.7 KiB
TypeScript
/*
|
|
* Tencent is pleased to support the open source community by making TMagicEditor available.
|
|
*
|
|
* Copyright (C) 2025 Tencent.
|
|
*/
|
|
import { afterEach, describe, expect, test, vi } from 'vitest';
|
|
|
|
import editorPlugin from '@editor/plugin';
|
|
|
|
vi.mock('@tmagic/design', () => ({
|
|
default: { install: vi.fn() },
|
|
}));
|
|
vi.mock('@tmagic/form', () => ({
|
|
default: { install: vi.fn() },
|
|
}));
|
|
vi.mock('@tmagic/table', () => ({
|
|
default: { install: vi.fn() },
|
|
}));
|
|
|
|
vi.mock('@editor/Editor.vue', () => ({
|
|
default: { name: 'MEditor', render: () => null },
|
|
}));
|
|
|
|
vi.mock('@editor/fields/Code.vue', () => ({ default: { name: 'Code', render: () => null } }));
|
|
vi.mock('@editor/fields/CodeLink.vue', () => ({ default: { name: 'CodeLink', render: () => null } }));
|
|
vi.mock('@editor/fields/CodeSelect.vue', () => ({ default: { name: 'CodeSelect', render: () => null } }));
|
|
vi.mock('@editor/fields/CodeSelectCol.vue', () => ({ default: { name: 'CodeSelectCol', render: () => null } }));
|
|
vi.mock('@editor/fields/CondOpSelect.vue', () => ({ default: { name: 'CondOpSelect', render: () => null } }));
|
|
vi.mock('@editor/fields/DataSourceFields.vue', () => ({
|
|
default: { name: 'DataSourceFields', render: () => null },
|
|
}));
|
|
vi.mock('@editor/fields/DataSourceFieldSelect/Index.vue', () => ({
|
|
default: { name: 'DataSourceFieldSelect', render: () => null },
|
|
}));
|
|
vi.mock('@editor/fields/DataSourceInput.vue', () => ({ default: { name: 'DataSourceInput', render: () => null } }));
|
|
vi.mock('@editor/fields/DataSourceMethods.vue', () => ({
|
|
default: { name: 'DataSourceMethods', render: () => null },
|
|
}));
|
|
vi.mock('@editor/fields/DataSourceMethodSelect.vue', () => ({
|
|
default: { name: 'DataSourceMethodSelect', render: () => null },
|
|
}));
|
|
vi.mock('@editor/fields/DataSourceMocks.vue', () => ({ default: { name: 'DataSourceMocks', render: () => null } }));
|
|
vi.mock('@editor/fields/DataSourceSelect.vue', () => ({ default: { name: 'DataSourceSelect', render: () => null } }));
|
|
vi.mock('@editor/fields/DisplayConds.vue', () => ({ default: { name: 'DisplayConds', render: () => null } }));
|
|
vi.mock('@editor/fields/EventSelect.vue', () => ({ default: { name: 'EventSelect', render: () => null } }));
|
|
vi.mock('@editor/fields/KeyValue.vue', () => ({ default: { name: 'KeyValue', render: () => null } }));
|
|
vi.mock('@editor/fields/PageFragmentSelect.vue', () => ({
|
|
default: { name: 'PageFragmentSelect', render: () => null },
|
|
}));
|
|
vi.mock('@editor/fields/StyleSetter/Index.vue', () => ({ default: { name: 'StyleSetter', render: () => null } }));
|
|
vi.mock('@editor/fields/UISelect.vue', () => ({ default: { name: 'UISelect', render: () => null } }));
|
|
vi.mock('@editor/layouts/CodeEditor.vue', () => ({ default: { name: 'CodeEditor', render: () => null } }));
|
|
|
|
afterEach(() => {
|
|
vi.clearAllMocks();
|
|
});
|
|
|
|
describe('plugin install', () => {
|
|
const buildApp = () => {
|
|
const components: Record<string, any> = {};
|
|
return {
|
|
app: {
|
|
component: vi.fn((name: string, comp: any) => {
|
|
components[name] = comp;
|
|
}),
|
|
use: vi.fn(),
|
|
config: { globalProperties: {} },
|
|
} as any,
|
|
components,
|
|
};
|
|
};
|
|
|
|
test('install 调用 design/form/table 插件并注册全局组件', () => {
|
|
const { app, components } = buildApp();
|
|
editorPlugin.install(app, { someOption: true } as any);
|
|
expect(app.use).toHaveBeenCalledTimes(3);
|
|
expect(Object.keys(components).length).toBeGreaterThan(10);
|
|
expect(components.MEditor).toBeDefined();
|
|
});
|
|
|
|
test('install 不传 opt 时使用默认配置', () => {
|
|
const { app } = buildApp();
|
|
editorPlugin.install(app);
|
|
expect(app.config.globalProperties.$TMAGIC_EDITOR).toBeDefined();
|
|
expect(typeof app.config.globalProperties.$TMAGIC_EDITOR.parseDSL).toBe('function');
|
|
});
|
|
});
|