From ca8af1bce05dc122bfb45209689871d040fb66af Mon Sep 17 00:00:00 2001 From: jasquat Date: Mon, 1 May 2023 14:54:11 -0400 Subject: [PATCH] fixed cypress tests w/ burnettk --- .../cypress/e2e/process_instances.cy.js | 2 +- .../cypress/e2e/process_models.cy.js | 28 +++++----- .../cypress/e2e/tasks.cy.js | 55 +++++++------------ .../components/ProcessInstanceListTable.tsx | 2 +- .../src/routes/ProcessInstanceLogList.tsx | 2 +- .../src/routes/ReactFormEditor.tsx | 1 + 6 files changed, 37 insertions(+), 53 deletions(-) diff --git a/spiffworkflow-frontend/cypress/e2e/process_instances.cy.js b/spiffworkflow-frontend/cypress/e2e/process_instances.cy.js index db6f53d3..406a55c5 100644 --- a/spiffworkflow-frontend/cypress/e2e/process_instances.cy.js +++ b/spiffworkflow-frontend/cypress/e2e/process_instances.cy.js @@ -161,7 +161,7 @@ describe('process-instances', () => { cy.getBySel('process-instance-list-link').click(); cy.getBySel('process-instance-show-link-id').first().click(); cy.getBySel('process-instance-log-list-link').click(); - cy.getBySel('process-instance-log-detailed').click(); + cy.getBySel('process-instance-log-events').click(); cy.contains('process_model_one'); cy.contains('task_completed'); cy.basicPaginationTest(); diff --git a/spiffworkflow-frontend/cypress/e2e/process_models.cy.js b/spiffworkflow-frontend/cypress/e2e/process_models.cy.js index 9e7bd55d..06986080 100644 --- a/spiffworkflow-frontend/cypress/e2e/process_models.cy.js +++ b/spiffworkflow-frontend/cypress/e2e/process_models.cy.js @@ -1,9 +1,6 @@ -import { slowCypressDown } from 'cypress-slow-down'; import { modifyProcessIdentifierForPathParam } from '../../src/helpers'; import { miscDisplayName } from '../support/helpers'; -// slowCypressDown(500); - describe('process-models', () => { beforeEach(() => { cy.login(); @@ -15,7 +12,7 @@ describe('process-models', () => { const groupDisplayName = 'Acceptance Tests Group One'; const deleteProcessModelButtonId = 'delete-process-model-button'; const saveChangesButtonText = 'Save Changes'; - const fileNameInputSelector = 'input[name=file_name]'; + const fileNameInputSelector = 'input#process_model_file_name'; it('can perform crud operations', () => { const uuid = () => Cypress._.random(0, 1e6); @@ -36,7 +33,8 @@ describe('process-models', () => { cy.contains(`Process Model: ${modelDisplayName}`); cy.getBySel('edit-process-model-button').click(); - cy.get('input[name=display_name]').clear().type(newModelDisplayName); + cy.get('input[name=display_name]').clear(); + cy.get('input[name=display_name]').type(newModelDisplayName); cy.contains('Submit').click(); cy.contains(`Process Model: ${newModelDisplayName}`); @@ -50,7 +48,6 @@ describe('process-models', () => { const uuid = () => Cypress._.random(0, 1e6); const id = uuid(); const directParentGroupId = 'acceptance-tests-group-one'; - const directParentGroupName = 'Acceptance Tests Group One'; const groupId = `misc/${directParentGroupId}`; const modelDisplayName = `Test Model 2 ${id}`; const modelId = `test-model-2-${id}`; @@ -58,7 +55,7 @@ describe('process-models', () => { const bpmnFileName = `bpmn_test_file_${id}`; const dmnFileName = `dmn_test_file_${id}`; const jsonFileName = `json_test_file_${id}`; - const decision_acceptance_test_id = `decision_acceptance_test_${id}`; + const decisionAcceptanceTestId = `decision_acceptance_test_${id}`; cy.contains(miscDisplayName).click(); cy.contains(groupDisplayName).click(); @@ -79,9 +76,10 @@ describe('process-models', () => { // add new bpmn file cy.contains('New BPMN File').click(); cy.contains(/^Process Model File$/); - cy.get('g[data-element-id=StartEvent_1]').click().should('exist'); + cy.get('g[data-element-id=StartEvent_1]').click(); cy.contains('General').click(); - cy.get('#bio-properties-panel-name').clear().type('Start Event Name'); + cy.get('#bio-properties-panel-name').clear(); + cy.get('#bio-properties-panel-name').type('Start Event Name'); cy.wait(500); cy.contains('Save').click(); cy.contains('Start Event Name'); @@ -96,11 +94,10 @@ describe('process-models', () => { // add new dmn file cy.contains('New DMN File').click(); cy.contains(/^Process Model File$/); - cy.get('g[data-element-id=decision_1]').click().should('exist'); + cy.get('g[data-element-id=decision_1]').click(); cy.contains('General').click(); - cy.get('#bio-properties-panel-id') - .clear() - .type(decision_acceptance_test_id); + cy.get('#bio-properties-panel-id').clear(); + cy.get('#bio-properties-panel-id').type(decisionAcceptanceTestId); cy.contains('General').click(); cy.contains('Save').click(); cy.get(fileNameInputSelector).type(dmnFileName); @@ -135,7 +132,7 @@ describe('process-models', () => { cy.get('.tile-process-group-content-container').should('exist'); }); - it.only('can upload and run a bpmn file', () => { + it('can upload and run a bpmn file', () => { const uuid = () => Cypress._.random(0, 1e6); const id = uuid(); const directParentGroupId = 'acceptance-tests-group-one'; @@ -192,7 +189,8 @@ describe('process-models', () => { }); it('can allow searching for model', () => { - cy.getBySel('process-model-selection').click().type('model-3'); + cy.getBySel('process-model-selection').click(); + cy.getBySel('process-model-selection').type('model-3'); cy.contains('acceptance-tests-group-one/acceptance-tests-model-3').click(); cy.contains('Acceptance Tests Model 3'); }); diff --git a/spiffworkflow-frontend/cypress/e2e/tasks.cy.js b/spiffworkflow-frontend/cypress/e2e/tasks.cy.js index 50d24899..fde67873 100644 --- a/spiffworkflow-frontend/cypress/e2e/tasks.cy.js +++ b/spiffworkflow-frontend/cypress/e2e/tasks.cy.js @@ -1,13 +1,14 @@ const submitInputIntoFormField = (taskName, fieldKey, fieldValue) => { cy.contains(`Task: ${taskName}`, { timeout: 10000 }); - cy.get(fieldKey).clear().type(fieldValue); + cy.get(fieldKey).clear(); + cy.get(fieldKey).type(fieldValue); cy.contains('Submit').click(); }; -const checkFormFieldIsReadOnly = (formName, fieldKey) => { - cy.contains(`Task: ${formName}`); - cy.get(fieldKey).invoke('attr', 'disabled').should('exist'); -}; +// const checkFormFieldIsReadOnly = (formName, fieldKey) => { +// cy.contains(`Task: ${formName}`); +// cy.get(fieldKey).invoke('attr', 'disabled').should('exist'); +// }; const checkTaskHasClass = (taskName, className) => { cy.get(`g[data-element-id=${taskName}]`).should('have.class', className); @@ -38,38 +39,26 @@ describe('tasks', () => { cy.navigateToProcessModel(groupDisplayName, modelDisplayName); cy.runPrimaryBpmnFile(true); - submitInputIntoFormField( - 'get_user_generated_number_one', - '#root_user_generated_number_1', - 2 - ); - submitInputIntoFormField( - 'get_user_generated_number_two', - '#root_user_generated_number_2', - 3 - ); + submitInputIntoFormField('get_form_num_one', '#root_form_num_1', 2); + submitInputIntoFormField('get_form_num_two', '#root_form_num_2', 3); - cy.contains('Task: get_user_generated_number_three'); + cy.contains('Task: get_form_num_three'); // TODO: remove this if we decide to completely kill form navigation // cy.getBySel('form-nav-form2').click(); // checkFormFieldIsReadOnly( - // 'get_user_generated_number_two', - // '#root_user_generated_number_2' + // 'get_form_num_two', + // '#root_form_num_2' // ); // cy.getBySel('form-nav-form1').click(); // checkFormFieldIsReadOnly( - // 'get_user_generated_number_one', - // '#root_user_generated_number_1' + // 'get_form_num_one', + // '#root_form_num_1' // ); // // cy.getBySel('form-nav-form3').click(); - submitInputIntoFormField( - 'get_user_generated_number_three', - '#root_user_generated_number_3', - 4 - ); + submitInputIntoFormField('get_form_num_three', '#root_form_num_3', 4); - cy.contains('Task: get_user_generated_number_four'); + cy.contains('Task: get_form_num_four'); cy.navigateToProcessModel(groupDisplayName, modelDisplayName); cy.getBySel('process-instance-list-link').click(); cy.assertAtLeastOneItemInPaginatedResults(); @@ -79,10 +68,10 @@ describe('tasks', () => { cy.contains('Process Instance Id: '); cy.get(`g[data-element-id=form3]`).click(); - cy.contains('"user_generated_number_1": 2'); - cy.contains('"user_generated_number_2": 3'); - cy.contains('"user_generated_number_3": 4'); - cy.contains('"user_generated_number_4": 5').should('not.exist'); + cy.contains('"form_num_1": 2'); + cy.contains('"form_num_2": 3'); + cy.contains('"form_num_3": 4'); + cy.contains('"form_num_4": 5').should('not.exist'); checkTaskHasClass('form1', completedTaskClassName); checkTaskHasClass('form2', completedTaskClassName); checkTaskHasClass('form3', completedTaskClassName); @@ -97,11 +86,7 @@ describe('tasks', () => { // FIXME: this will probably need a better way to link to the proper form that we want cy.contains('Go').click(); - submitInputIntoFormField( - 'get_user_generated_number_four', - '#root_user_generated_number_4', - 5 - ); + submitInputIntoFormField('get_form_num_four', '#root_form_num_4', 5); cy.url().should('include', '/tasks'); cy.navigateToProcessModel(groupDisplayName, modelDisplayName); diff --git a/spiffworkflow-frontend/src/components/ProcessInstanceListTable.tsx b/spiffworkflow-frontend/src/components/ProcessInstanceListTable.tsx index 74d1012c..6f12d0e7 100644 --- a/spiffworkflow-frontend/src/components/ProcessInstanceListTable.tsx +++ b/spiffworkflow-frontend/src/components/ProcessInstanceListTable.tsx @@ -1692,7 +1692,7 @@ export default function ProcessInstanceListTable({ data-qa="process-instance-list-link" kind="ghost" renderIcon={ArrowRight} - iconDescription="Go to Filterable List" + iconDescription="View Filterable List" hasIconOnly size="lg" onClick={() => diff --git a/spiffworkflow-frontend/src/routes/ProcessInstanceLogList.tsx b/spiffworkflow-frontend/src/routes/ProcessInstanceLogList.tsx index efb5bd9f..a38276b9 100644 --- a/spiffworkflow-frontend/src/routes/ProcessInstanceLogList.tsx +++ b/spiffworkflow-frontend/src/routes/ProcessInstanceLogList.tsx @@ -494,7 +494,7 @@ export default function ProcessInstanceLogList({ variant }: OwnProps) { { resetFilters(); searchParams.set('events', 'false'); diff --git a/spiffworkflow-frontend/src/routes/ReactFormEditor.tsx b/spiffworkflow-frontend/src/routes/ReactFormEditor.tsx index f9e83f35..e03253da 100644 --- a/spiffworkflow-frontend/src/routes/ReactFormEditor.tsx +++ b/spiffworkflow-frontend/src/routes/ReactFormEditor.tsx @@ -174,6 +174,7 @@ export default function ReactFormEditor() { setNewFileName(e.target.value)}