mirror of
https://github.com/status-im/spiff-arena.git
synced 2025-01-27 10:15:10 +00:00
95 lines
3.2 KiB
JavaScript
95 lines
3.2 KiB
JavaScript
import {
|
|
query as domQuery,
|
|
} from 'min-dom';
|
|
import {
|
|
bootstrapPropertiesPanel, changeInput,
|
|
expectSelected, findEntry, findGroupEntry, findInput
|
|
} from './helpers';
|
|
import { BpmnPropertiesPanelModule, BpmnPropertiesProviderModule } from 'bpmn-js-properties-panel';
|
|
import spiffModdleExtension from '../../app/spiffworkflow/moddle/spiffworkflow.json';
|
|
import TestContainer from 'mocha-test-container-support';
|
|
import { fireEvent } from '@testing-library/preact';
|
|
import { findDataObject, findDataObjects } from '../../app/spiffworkflow/DataObject/DataObjectHelpers';
|
|
import dataObject from '../../app/spiffworkflow/DataObject';
|
|
|
|
describe('Properties Panel for a Process', function() {
|
|
let xml = require('./bpmn/diagram.bpmn').default;
|
|
let container;
|
|
|
|
beforeEach(function() {
|
|
container = TestContainer.get(this);
|
|
});
|
|
|
|
beforeEach(bootstrapPropertiesPanel(xml, {
|
|
container,
|
|
debounceInput: false,
|
|
additionalModules: [
|
|
dataObject,
|
|
BpmnPropertiesPanelModule,
|
|
BpmnPropertiesProviderModule,
|
|
],
|
|
moddleExtensions: {
|
|
spiffworkflow: spiffModdleExtension
|
|
},
|
|
}));
|
|
|
|
it('should allow you to edit the data objects', async function() {
|
|
|
|
// IF - a process is selected
|
|
await expectSelected('ProcessTest');
|
|
|
|
// THEN - there is a section where you can modify data objects.
|
|
let entry = findGroupEntry('editDataObjects', container);
|
|
expect(entry).to.exist;
|
|
});
|
|
|
|
it('should be possible to change a data objects id', async function() {
|
|
|
|
// IF - a process is selected and the id of a data object is changed
|
|
const process_svg = await expectSelected('ProcessTest');
|
|
|
|
let newId = 'a_brand_new_id';
|
|
|
|
// ID here is [process id]-dataObj-[data object index]-id
|
|
let myDataObjEntry = findEntry('ProcessTest-dataObj-0-id');
|
|
let textBox = findInput('text', myDataObjEntry);
|
|
changeInput(textBox, newId);
|
|
|
|
// THEN - there is a section where you can modify data objects.
|
|
let dataObject = findDataObject(process_svg.businessObject, newId);
|
|
expect(dataObject.id).to.equal(newId);
|
|
});
|
|
|
|
it('should be possible to remove a data object', async function() {
|
|
|
|
// IF - a process is selected and the delete button is clicked.
|
|
const process_svg = await expectSelected('ProcessTest');
|
|
const data_id = 'my_data_object';
|
|
let dataObject = findDataObject(process_svg.businessObject, data_id);
|
|
expect(dataObject).to.exist;
|
|
let myDataObjEntry = findEntry('ProcessTest-dataObj-2');
|
|
let deleteButton = domQuery('.bio-properties-panel-remove-entry', myDataObjEntry);
|
|
fireEvent.click(deleteButton);
|
|
|
|
// THEN - there should not be a 'my_data_object' anymore.
|
|
dataObject = findDataObject(process_svg.businessObject, data_id);
|
|
expect(dataObject).to.not.exist;
|
|
|
|
});
|
|
|
|
it('should be possible to add a data object', async function() {
|
|
|
|
// IF - a process is selected and the add button is clicked.
|
|
const process_svg = await expectSelected('ProcessTest');
|
|
let entry = findGroupEntry('editDataObjects', container);
|
|
let addButton = domQuery('.bio-properties-panel-add-entry', entry);
|
|
fireEvent.click(addButton);
|
|
|
|
// THEN - there should now be 4 data objects instead of just 3.
|
|
expect(findDataObjects(process_svg.businessObject).length).to.equal(4);
|
|
|
|
});
|
|
|
|
|
|
});
|