mirror of https://github.com/artf/grapesjs.git
nocodeframeworkdrag-and-dropsite-buildersite-generatortemplate-builderui-builderweb-builderweb-builder-frameworkwebsite-builderno-codepage-builder
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
148 lines
4.6 KiB
148 lines
4.6 KiB
import Commands from '../../../src/commands';
|
|
import EditorModel from '../../../src/editor/model/Editor';
|
|
import { Command, CommandFunction } from '../../../src/commands/view/CommandAbstract';
|
|
|
|
describe('Commands', () => {
|
|
describe('Main', () => {
|
|
let em: EditorModel;
|
|
let obj: Commands;
|
|
let commSimple: Command;
|
|
let commRunOnly: Command;
|
|
let commFunc: CommandFunction;
|
|
let commName = 'commandTest';
|
|
let commResultRun = 'Run executed';
|
|
let commResultStop = 'Stop executed';
|
|
|
|
beforeEach(() => {
|
|
commSimple = {
|
|
run: () => commResultRun,
|
|
stop: () => commResultStop,
|
|
};
|
|
commRunOnly = {
|
|
run: () => commResultRun,
|
|
};
|
|
commFunc = () => commResultRun;
|
|
em = new EditorModel();
|
|
em.set('Editor', em);
|
|
obj = em.Commands;
|
|
});
|
|
|
|
afterEach(() => {
|
|
em.destroy();
|
|
});
|
|
|
|
test('No commands inside', () => {
|
|
expect(obj.get('test')).toBeUndefined();
|
|
});
|
|
|
|
test('Push new command', () => {
|
|
const comm = { test: 'test' };
|
|
const len = Object.keys(obj.getAll()).length;
|
|
obj.add('test', comm);
|
|
expect(obj.has('test')).toBe(true);
|
|
expect(Object.keys(obj.getAll()).length).toBe(len + 1);
|
|
expect(obj.get('test')!.test).toEqual('test');
|
|
});
|
|
|
|
test('Default commands after loadDefaultCommands', () => {
|
|
expect(obj.get('select-comp')).not.toBeUndefined();
|
|
});
|
|
|
|
test('Commands module should not have toLoad property', () => {
|
|
// @ts-ignore
|
|
expect(obj.toLoad).toBeUndefined();
|
|
});
|
|
|
|
test('Run simple command and check if the state is tracked', () => {
|
|
// Add the command
|
|
obj.add(commName, commSimple);
|
|
expect(obj.isActive(commName)).toBe(false);
|
|
|
|
// Start the command
|
|
let result = obj.run(commName);
|
|
expect(result).toBe(commResultRun);
|
|
expect(obj.isActive(commName)).toBe(true);
|
|
expect(Object.keys(obj.getActive()).length).toBe(1);
|
|
|
|
// Stop the command
|
|
result = obj.stop(commName);
|
|
expect(result).toBe(commResultStop);
|
|
expect(obj.isActive(commName)).toBe(false);
|
|
expect(Object.keys(obj.getActive()).length).toBe(0);
|
|
});
|
|
|
|
test('Run command only with run method, ensure is not tracked', () => {
|
|
// Add the command
|
|
obj.add(commName, commRunOnly);
|
|
expect(obj.isActive(commName)).toBe(false);
|
|
|
|
// Start the command
|
|
let result = obj.run(commName);
|
|
expect(result).toBe(commResultRun);
|
|
expect(obj.isActive(commName)).toBe(false);
|
|
expect(Object.keys(obj.getActive()).length).toBe(0);
|
|
});
|
|
|
|
test('Run function command, ensure is not tracked', () => {
|
|
// Add the command
|
|
obj.add(commName, commFunc);
|
|
expect(obj.isActive(commName)).toBe(false);
|
|
|
|
// Start the command
|
|
let result = obj.run(commName);
|
|
expect(result).toBe(commResultRun);
|
|
expect(obj.isActive(commName)).toBe(false);
|
|
expect(Object.keys(obj.getActive()).length).toBe(0);
|
|
});
|
|
|
|
test('Run command and check if defaultOptions are passed or not', () => {
|
|
const defaultOptions = { key: 'defaultValue' };
|
|
const customOptions = { key: 'customValue' };
|
|
const mergedOptions = { ...defaultOptions, ...customOptions };
|
|
|
|
const comm = {
|
|
run: jest.fn(() => commResultRun), // Mock the run method
|
|
};
|
|
|
|
// Add the command
|
|
obj.add(commName, comm);
|
|
expect(obj.isActive(commName)).toBe(false);
|
|
|
|
// Run the command without defaultOptions
|
|
let result = obj.run(commName, customOptions);
|
|
expect(result).toBe(commResultRun);
|
|
expect(comm.run).toHaveBeenCalledWith(
|
|
expect.any(Object), // The `em` object
|
|
expect.objectContaining(customOptions),
|
|
);
|
|
expect(obj.isActive(commName)).toBe(false);
|
|
|
|
// Configure defaultOptions
|
|
em.config.commands = {
|
|
defaultOptions: {
|
|
[commName]: {
|
|
run: (opts) => ({ ...defaultOptions, ...opts }), // Merge defaultOptions with provided options
|
|
},
|
|
},
|
|
};
|
|
|
|
// Run the command without custom options
|
|
result = obj.run(commName);
|
|
expect(result).toBe(commResultRun);
|
|
expect(comm.run).toHaveBeenCalledWith(
|
|
expect.any(Object), // The `em` object
|
|
expect.objectContaining(defaultOptions),
|
|
);
|
|
expect(obj.isActive(commName)).toBe(false);
|
|
|
|
// Run the command with custom options
|
|
result = obj.run(commName, customOptions);
|
|
expect(result).toBe(commResultRun);
|
|
expect(comm.run).toHaveBeenCalledWith(
|
|
expect.any(Object), // The `em` object
|
|
expect.objectContaining(mergedOptions),
|
|
);
|
|
expect(obj.isActive(commName)).toBe(false);
|
|
});
|
|
});
|
|
});
|
|
|