From 6e81ddd1724268ff18c6f30649033c8ee90c8f6e Mon Sep 17 00:00:00 2001 From: Nandini Chandra Date: Fri, 2 Feb 2024 13:42:09 -0600 Subject: [PATCH] [RFR] Verify multiple apps inherit archetype assessment/review (#945) * Verify multiple apps inherit archetype assessment/review Signed-off-by: Nandini Chandra * updates Signed-off-by: Nandini Chandra * Update createMultipleApplications() Signed-off-by: Nandini Chandra --------- Signed-off-by: Nandini Chandra --- .../assessment/archetype_association.test.ts | 40 +++++++++++-------- cypress/utils/utils.ts | 9 ++++- 2 files changed, 30 insertions(+), 19 deletions(-) diff --git a/cypress/e2e/tests/migration/applicationinventory/assessment/archetype_association.test.ts b/cypress/e2e/tests/migration/applicationinventory/assessment/archetype_association.test.ts index 3827518ca..14e094df8 100644 --- a/cypress/e2e/tests/migration/applicationinventory/assessment/archetype_association.test.ts +++ b/cypress/e2e/tests/migration/applicationinventory/assessment/archetype_association.test.ts @@ -22,6 +22,7 @@ import { createMultipleArchetypes, deleteByList, createMultipleStakeholders, + createMultipleApplications, } from "../../../../../utils/utils"; import { Application } from "../../../../models/migration/applicationinventory/application"; import { Archetype } from "../../../../models/migration/archetypes/archetype"; @@ -30,8 +31,8 @@ import { AssessmentQuestionnaire } from "../../../../models/administration/asses import { legacyPathfinder, SEC } from "../../../../types/constants"; import { Stakeholders } from "../../../../models/migration/controls/stakeholders"; -let applicationList: Array = []; -let archetypeList: Array = []; +let applicationList: Application[]; +let archetypeList: Archetype[]; let tags: Tag[]; let stakeholders: Stakeholders[]; @@ -45,29 +46,34 @@ describe(["@tier2"], "Tests related to application-archetype association ", () = AssessmentQuestionnaire.enable(legacyPathfinder); }); - it("Archetype association - Application creation before archetype creation ", function () { - // Automates Polarion MTA-400 - const appdata = { - name: data.getAppName(), - tags: ["Web / WebSocket"], - }; - - const application = new Application(appdata); - applicationList.push(application); - application.create(); - cy.wait(2 * SEC); + it("Verify multiple applications inherit assessment and review inheritance from an archetype", function () { + // Automates Polarion MTA-400 Archetype association - Application creation before archetype creation. + applicationList = createMultipleApplications(2, [tags[0].name]); const archetype = new Archetype( data.getRandomWord(8), - ["Web / WebSocket"], - ["Web / WebSocket"], + [tags[0].name], + [tags[1].name], null ); archetype.create(); cy.wait(2 * SEC); - // Assert that associated archetypes are listed on app drawer after application gets associated with archetype(s) - application.verifyArchetypeList([archetype.name], "Associated archetypes"); + //Automates Polarion MTA-499 Verify multiple applications inherit assessment and review inheritance from an archetype + archetype.perform_review("low"); + archetype.perform_assessment("low"); + + for (let i = 0; i < applicationList.length; i++) { + // Assert that associated archetypes are listed on app drawer after application gets associated with archetype(s) + applicationList[i].verifyArchetypeList([archetype.name], "Associated archetypes"); + applicationList[i].verifyArchetypeList([archetype.name], "Archetypes reviewed"); + applicationList[i].validateInheritedReviewFields([archetype.name]); + applicationList[i].verifyStatus("review", "Completed"); + applicationList[i].verifyArchetypeList([archetype.name], "Archetypes assessed"); + applicationList[i].validateAssessmentField("Low"); + applicationList[i].verifyStatus("assessment", "Completed"); + } + archetype.delete(); }); diff --git a/cypress/utils/utils.ts b/cypress/utils/utils.ts index 5192e2ac4..28024f533 100644 --- a/cypress/utils/utils.ts +++ b/cypress/utils/utils.ts @@ -1102,11 +1102,16 @@ export function getRandomAnalysisData(analysisdata): analysisData { }; } -export function createMultipleApplications(numberofapplications: number): Array { +export function createMultipleApplications( + numberofapplications: number, + tags?: [string] +): Array { let applicationList: Array = []; + let application: Application; for (let i = 0; i < numberofapplications; i++) { // Navigate to application inventory tab and create new application - const application = new Application(getRandomApplicationData()); + if (tags) application = new Application(getRandomApplicationData(tags)); + else application = new Application(getRandomApplicationData()); application.create(); applicationList.push(application); cy.wait(2000);