1 package vid.automation.test.test;
4 import com.google.common.collect.ImmutableMap;
5 import com.google.common.primitives.Ints;
6 import org.json.JSONException;
7 import org.junit.Assert;
8 import org.openecomp.sdc.ci.tests.datatypes.UserCredentials;
9 import org.openecomp.sdc.ci.tests.utilities.GeneralUIUtils;
10 import org.openqa.selenium.JavascriptExecutor;
11 import org.openqa.selenium.WebElement;
12 import org.openqa.selenium.interactions.Actions;
13 import org.openqa.selenium.remote.RemoteWebElement;
14 import org.openqa.selenium.support.ui.Select;
15 import org.skyscreamer.jsonassert.JSONAssert;
16 import org.skyscreamer.jsonassert.JSONCompareMode;
17 import org.testng.annotations.*;
18 import vid.automation.test.Constants;
19 import vid.automation.test.infra.*;
20 import vid.automation.test.model.User;
21 import vid.automation.test.sections.ChangeManagementPage;
22 import vid.automation.test.services.SimulatorApi;
23 import vid.automation.test.utils.DB_CONFIG;
25 import java.sql.Connection;
26 import java.sql.DriverManager;
27 import java.sql.SQLException;
28 import java.sql.Statement;
29 import java.util.Arrays;
30 import java.util.List;
31 import java.util.stream.Collectors;
32 import java.util.stream.Stream;
34 import static org.hamcrest.CoreMatchers.*;
35 import static org.hamcrest.MatcherAssert.assertThat;
36 import static org.hamcrest.Matchers.greaterThan;
37 import static org.hamcrest.collection.IsEmptyCollection.empty;
38 import static org.hamcrest.core.IsNot.not;
40 public class ChangeManagementTest extends VidBaseTestCase {
42 public static final String SCHEDULED_ID = "0b87fe60-50b0-4bac-a0a7-49e951b0ba9e";
44 public void testLeftPanelChangeManagementButton() {
45 Assert.assertTrue(Wait.byText(Constants.SideMenu.VNF_CHANGES));
49 public void testChangeManagementHeaderLine() {
50 ChangeManagementPage.openChangeManagementPage();
51 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.pageHeadlineId));
52 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.headlineNewButtonId));
53 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.headlineSearchInputId));
57 public void testOpenNewChangeManagementModal() {
58 ChangeManagementPage.openNewChangeManagementModal();
59 Assert.assertTrue(Exists.modal());
60 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.newModalSubscriberInputId));
61 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.newModalServiceTypeInputId));
62 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.newModalVNFNameInputId));
63 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.newModalVNFTypeInputId));
64 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.newModalFromVNFVersionInputId));
65 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.newModalWorkFlowInputId));
66 Assert.assertTrue(Exists.byId(Constants.generalSubmitButtonId));
67 Assert.assertTrue(Exists.byId(Constants.generalCancelButtonId));
70 private void openAndFill1stScreen(String vnfName, String vnfTargetVersion, String workflow) {
71 String subscriberId = VNF_DATA_WITH_IN_PLACE.subscriberId;
72 String serviceType = VNF_DATA_WITH_IN_PLACE.serviceType;
73 String vnfType = VNF_DATA_WITH_IN_PLACE.vnfType;
74 String vnfSourceVersion = VNF_DATA_WITH_IN_PLACE.vnfSourceVersion;
75 ChangeManagementPage.openNewChangeManagementModal();
76 Wait.angularHttpRequestsLoaded();
77 ChangeManagementPage.selectSubscriberById(subscriberId);
78 Wait.angularHttpRequestsLoaded();
79 SelectOption.byIdAndVisibleText(Constants.ChangeManagement.newModalServiceTypeInputId, serviceType);
80 Wait.angularHttpRequestsLoaded();
81 SelectOption.byIdAndVisibleText(Constants.ChangeManagement.newModalVNFTypeInputId, vnfType);
82 Wait.angularHttpRequestsLoaded();
83 SelectOption.byIdAndVisibleText(Constants.ChangeManagement.newModalFromVNFVersionInputId, vnfSourceVersion);
84 Wait.angularHttpRequestsLoaded();
85 Click.byId(Constants.ChangeManagement.newModalVNFNameInputId);
86 Click.byText(vnfName);
87 // close the multi-select
88 Click.byId(Constants.ChangeManagement.newModalVNFNameInputId);
89 Wait.angularHttpRequestsLoaded();
90 GeneralUIUtils.ultimateWait();
92 if (vnfTargetVersion != null) {
93 SelectOption.byClassAndVisibleText(Constants.ChangeManagement.newModalTargetVersionInputsClass, vnfTargetVersion);
94 Wait.angularHttpRequestsLoaded();
96 SelectOption.byIdAndVisibleText(Constants.ChangeManagement.newModalWorkFlowInputId, workflow);
100 public void scheduleChange2ndScreen(String duration, String fallback, String concurrencyLimit, String policy) {
102 Wait.byText(Constants.ChangeManagement.schedulerModalNowLabel);
103 Click.byText(Constants.ChangeManagement.schedulerModalNowLabel);
106 SelectOption.byValue(Constants.ChangeManagement.schedulerModalHoursOption, Constants.ChangeManagement.schedulerModalTimeUnitSelectId);
108 Input.text(duration, Constants.ChangeManagement.schedulerModalDurationInputTestId);
109 Input.text(fallback, Constants.ChangeManagement.schedulerModalFallbackInputTestId);
110 Input.text(concurrencyLimit, Constants.ChangeManagement.schedulerModalConcurrencyLimitInputTestId);
111 Wait.angularHttpRequestsLoaded();
112 SelectOption.byIdAndVisibleText(Constants.ChangeManagement.schedulerModalPolicySelectId, policy);
114 Click.byText(Constants.ChangeManagement.schedulerModalScheduleButtonText);
118 static class VNF_DATA_WITH_IN_PLACE {
119 static final int vnfZrdm3amdns02test2Id = 11822;
120 static final int vnfHarrisonKrisId = 12822;
121 static String subscriberId = "a9a77d5a-123e-4ca2-9eb9-0b015d2ee0fb";
122 static String serviceType = "vFlowLogic";
123 static String vnfType = "vMobileDNS";
124 static String vnfSourceVersion = "1.0";
125 static String vnfName = "zrdm3amdns02test2";
126 static String vnfTargetVersion = "5.0";
127 static String workflowName = "VNF In Place Software Update";
131 protected void dropSpecialVNFs() {
132 System.out.println("Connecting database...");
134 try (Connection connection = DriverManager.getConnection(DB_CONFIG.url, DB_CONFIG.username, DB_CONFIG.password)) {
135 System.out.println("Database connected!");
137 Statement stmt = connection.createStatement();
138 stmt.addBatch("DELETE FROM `vid_vnf_workflow` WHERE `VNF_DB_ID` = " + VNF_DATA_WITH_IN_PLACE.vnfZrdm3amdns02test2Id);
139 stmt.addBatch("DELETE FROM `vid_vnf` WHERE `VNF_DB_ID` = " + VNF_DATA_WITH_IN_PLACE.vnfZrdm3amdns02test2Id);
140 int[] executeBatch = stmt.executeBatch();
142 stmt = connection.createStatement();
143 stmt.addBatch("DELETE FROM `vid_vnf_workflow` WHERE `VNF_DB_ID` = " + VNF_DATA_WITH_IN_PLACE.vnfHarrisonKrisId);
144 stmt.addBatch("DELETE FROM `vid_vnf` WHERE `VNF_DB_ID` = " + VNF_DATA_WITH_IN_PLACE.vnfHarrisonKrisId);
145 executeBatch = stmt.executeBatch();
147 } catch (SQLException e) {
148 throw new IllegalStateException("Cannot connect the database!", e);
153 protected void registerToSimulator() {
154 SimulatorApi.clearAll();
155 SimulatorApi.registerExpectation(SimulatorApi.RegistrationStrategy.APPEND,
156 "changeManagement/ecompportal_getSessionSlotCheckInterval.json"
157 , "changeManagement/get_aai_get_subscribers.json"
158 , "changeManagement/get_aai_sub_details.json"
159 , "changeManagement/get_sdc_catalog_services_2f80c596.json"
160 , "changeManagement/get_service-design-and-creation.json"
161 , "changeManagement/get_vnf_data_by_globalid_and_service_type.json"
162 , "changeManagement/service-design-and-creation.json"
163 , "changeManagement/mso_get_manual_task.json"
164 , "changeManagement/mso_post_manual_task.json"
167 registerDefaultTablesData();
170 private void registerDefaultTablesData() {
171 SimulatorApi.registerExpectation(
172 new String[] {"changeManagement/get_scheduler_details_short.json",
173 "changeManagement/mso_get_change_managements.json"
174 ,"changeManagement/delete_scheduled_task.json"},
176 "<SCHEDULE_ID>", SCHEDULED_ID,
177 "<IN_PROGRESS_DATE>", "Fri, 08 Sep 2017 19:34:32 GMT"), SimulatorApi.RegistrationStrategy.APPEND
182 protected void prepareSpecialVNFs() {
186 System.out.println("Connecting database...");
188 try (Connection connection = DriverManager.getConnection(DB_CONFIG.url, DB_CONFIG.username, DB_CONFIG.password)) {
190 System.out.println("Database connected!");
192 ///////////////////////////////
193 // Add 2 vnfs with some workflows
194 Statement stmt = connection.createStatement();
195 stmt.addBatch("INSERT INTO `vid_vnf` (`VNF_DB_ID`, `VNF_APP_UUID`, `VNF_APP_INVARIANT_UUID`) " +
196 "VALUES (" + VNF_DATA_WITH_IN_PLACE.vnfZrdm3amdns02test2Id + ", '76e908e0-5201-44d2-a3e2-9e6128d05820', '72e465fe-71b1-4e7b-b5ed-9496118ff7a8')");
197 stmt.addBatch("INSERT INTO `vid_vnf_workflow` (`VNF_DB_ID`, `WORKFLOW_DB_ID`) VALUES (" + VNF_DATA_WITH_IN_PLACE.vnfZrdm3amdns02test2Id + ", 2)");
198 stmt.addBatch("INSERT INTO `vid_vnf_workflow` (`VNF_DB_ID`, `WORKFLOW_DB_ID`) VALUES (" + VNF_DATA_WITH_IN_PLACE.vnfZrdm3amdns02test2Id + ", 3)");
199 stmt.addBatch("INSERT INTO `vid_vnf_workflow` (`VNF_DB_ID`, `WORKFLOW_DB_ID`) VALUES (" + VNF_DATA_WITH_IN_PLACE.vnfZrdm3amdns02test2Id + ", 4)");
200 int[] executeBatch = stmt.executeBatch();
201 assertThat(Ints.asList(executeBatch), everyItem(greaterThan(0)));
203 stmt = connection.createStatement();
204 stmt.addBatch("INSERT INTO `vid_vnf` (`VNF_DB_ID`, `VNF_APP_UUID`, `VNF_APP_INVARIANT_UUID`) " +
205 "VALUES (" + VNF_DATA_WITH_IN_PLACE.vnfHarrisonKrisId + ", '0903e1c0-8e03-4936-b5c2-260653b96413', '00beb8f9-6d39-452f-816d-c709b9cbb87d')");
206 stmt.addBatch("INSERT INTO `vid_vnf_workflow` (`VNF_DB_ID`, `WORKFLOW_DB_ID`) VALUES (" + VNF_DATA_WITH_IN_PLACE.vnfHarrisonKrisId + ", 1)");
207 stmt.addBatch("INSERT INTO `vid_vnf_workflow` (`VNF_DB_ID`, `WORKFLOW_DB_ID`) VALUES (" + VNF_DATA_WITH_IN_PLACE.vnfHarrisonKrisId + ", 2)");
208 executeBatch = stmt.executeBatch();
209 assertThat(Ints.asList(executeBatch), everyItem(greaterThan(0)));
211 } catch (SQLException e) {
212 throw new IllegalStateException("Cannot connect the database!", e);
218 protected UserCredentials getUserCredentials() {
220 String userName = Constants.Users.MOBILITY_VMMSC;
221 User user = usersService.getUser(userName);
222 return new UserCredentials(user.credentials.userId, user.credentials.password, userName, "", "");
225 private void updateConfigFile(String fileName) {
226 Assert.assertFalse(Exists.byId(Constants.ChangeManagement.newModalConfigUpdateInputId));
227 openAndFill1stScreen(VNF_DATA_WITH_IN_PLACE.vnfName, VNF_DATA_WITH_IN_PLACE.vnfTargetVersion, "VNF Config Update");
228 Assert.assertFalse(Get.byId(Constants.generalSubmitButtonId).isEnabled());
229 Input.file("changeManagement/" + fileName, Constants.ChangeManagement.newModalConfigUpdateInputId);
230 GeneralUIUtils.ultimateWait();
234 public void regretToCancelWorkflowOnPendingPopUp() {
235 updateSimulatorWithParametersOfScheduledJod("get_scheduler_details_short.json");
236 ChangeManagementPage.openChangeManagementPage();
238 Wait.angularHttpRequestsLoaded();
239 ChangeManagementPage.clickOnRefreshButton();
241 GeneralUIUtils.ultimateWait();
242 clickAndAssertOnCancelButton(SCHEDULED_ID);
243 Click.byClass("pull-right modal-close");
244 //TODO: if refresh button functional will be change to refactor next line.
245 ChangeManagementPage.clickOnRefreshButton();
247 assertAndCheckStatusCellOnDeletedSheduledJob(SCHEDULED_ID, "cancel-action icon-pending");
251 public void clickOnScheduledJob_SuccessfulMessageAppear() {
252 ChangeManagementPage.openChangeManagementPage();
253 // Wait.angularHttpRequestsLoaded();
254 GeneralUIUtils.ultimateWait();
255 clickAndAssertOnCancelButton(SCHEDULED_ID);
256 updateSimulatorWithParametersOfScheduledJod("get_scheduler_details_short_with_after_cancel" +
259 clickAndAssertClickOnCancelWorkflowButtonOnPendingPopUp();
261 GeneralUIUtils.ultimateWait();
262 //TODO: To develop automatic table refresh to avoid click on refresh button.
263 ChangeManagementPage.clickOnRefreshButton();
264 assertCorrectJobDeleted("ctsf0002v");
266 assertAndCheckStatusCellOnDeletedSheduledJob(SCHEDULED_ID, "ng-hide");
271 private void clickAndAssertOnCancelButton(String scheduledID){
272 Wait.waitByTestId("icon-status-"+ scheduledID, 5);
273 Click.byTestId("icon-status-"+ scheduledID);
274 GeneralUIUtils.ultimateWait();
275 WebElement cancelPendingConfirmationMessage = Get.byTestId("btn-cancel-workflow");
276 assertThat(cancelPendingConfirmationMessage.getText(),containsString("Are you sure you want to delete workflow"));
278 private void clickAndAssertClickOnCancelWorkflowButtonOnPendingPopUp() {
281 Click.byClass(Constants.ChangeManagement.pendingModalCancelWorkflowButtonClass);
282 GeneralUIUtils.ultimateWait();
283 Assert.assertTrue(Exists.byClassAndText(Constants.generalModalTitleClass, "Success"));
285 if (Exists.byClassAndText("modal-title", "Pending")){
286 Click.byClass("pull-right modal-close");
289 Click.byClassAndVisibleText("btn","OK");
292 private void assertCorrectJobDeleted (String vnfName){
293 WebElement canceledScheduledJobRow = GeneralUIUtils.getWebElementByTestID("pending-table-cm-row");
294 String scheduledVnfName = ((RemoteWebElement) canceledScheduledJobRow).findElementsByTagName("td").get(1).getText();
295 String scheduledState = ((RemoteWebElement) canceledScheduledJobRow).findElementsByTagName("td").get(5).getText();
296 Assert.assertEquals(vnfName, scheduledVnfName);
297 Assert.assertEquals("Deleted", scheduledState);
300 private void assertAndCheckStatusCellOnDeletedSheduledJob(String scheduledId, String classString){
301 boolean isNotDisplayed = GeneralUIUtils.waitForElementInVisibilityByTestId("icon-status-" + scheduledId, 5);
302 Assert.assertTrue(isNotDisplayed);
304 public void updateSimulatorWithParametersOfScheduledJod(String jasonFile){
305 SimulatorApi.registerExpectation(
306 new String[] {"changeManagement/"+jasonFile},
307 ImmutableMap.of("<SCHEDULE_ID>", SCHEDULED_ID), SimulatorApi.RegistrationStrategy.APPEND
312 public void testWorkflowVNFInPlaceSoftwareUpdateNotInWorkflowsListWhenNotExpected() {
313 List<String> workflows = getListOfWorkflowsFor("Harrison Kris");
314 assertThat(workflows, not(hasItem(VNF_DATA_WITH_IN_PLACE.workflowName)));
318 public void testWorkflowVNFInPlaceSoftwareUpdateInWorkflowsListWhenExpected() {
319 List<String> workflows = getListOfWorkflowsFor(VNF_DATA_WITH_IN_PLACE.vnfName);
320 assertThat(workflows, hasItem(VNF_DATA_WITH_IN_PLACE.workflowName));
323 public void openAndFill1stScreenWithWorkflowVNFInPlaceSoftwareUpdate() {
324 openAndFill1stScreen(VNF_DATA_WITH_IN_PLACE.vnfName, VNF_DATA_WITH_IN_PLACE.vnfTargetVersion, VNF_DATA_WITH_IN_PLACE.workflowName);
327 @AfterMethod(alwaysRun = true)
328 public void closeForm() {
329 // Tries closing left-out popups, if any
330 // If none -- catch clause will swallow the exception
332 Click.byId(Constants.generalCancelButtonId);
333 Click.byId(Constants.generalCancelButtonId);
334 Click.byId(Constants.generalCancelButtonId);
335 } catch (Exception | Error e) {
338 Wait.modalToDisappear();
342 public void testWorkflowVNFInPlaceSoftwareUpdateShows3Fields() {
343 openAndFill1stScreenWithWorkflowVNFInPlaceSoftwareUpdate();
345 List<String> idsWithoutMatchingElement =
347 "operations-timeout",
348 "existing-software-version",
349 "new-software-version")
350 .filter(id -> Get.byId(id) == null)
351 .collect(Collectors.toList());
352 assertThat("all three special VNFInPlace fields should appear", idsWithoutMatchingElement, is(empty()));
354 assertThat(Get.byId(Constants.generalSubmitButtonId).isEnabled(), is(false));
358 public void testWorkflowVNFInPlaceSoftwareUpdate3ValidValues() {
359 openAndFill1stScreenWithWorkflowVNFInPlaceSoftwareUpdate();
361 final String[][] options = {
362 {"true", "111", "222", "333"}
363 , {"true", "14710454", "Cz-Ou0EK5eH9.gAK1", "G9bUiFX3QM8xpxF8TlZ7b5T0"}
364 , {"true", "25316893", "fMx9V5kp.5.JGtYRhNGVTPoJ", "Jv5IieY0kTNjkfZ64bHXngR6"}
365 , {"true", "8", "3t3MhTRqkyjB85o5NC9OacAw", "B.bJ6f7KYI6WzDMR0fyNM9r4"}
366 , {"true", "3176", "ZlRS7tczf0cbMxQbBfyc6AP5", "1G1"}
367 , {"true", "78058488", "n", "WkH"}
368 , {"true", "501778", "1.d74LrJbBmcR.7bfvH.UZMX", "tFTAel7PS4RKEJeJ0b6mTeVT"}
369 , {"true", "76639623", "m2.EhbBxRE.rJj3j6qDtMxGR", "Rgkm-EPM1K0KAWm43Ex1wwjj"}
370 , {"true", "91244280", "zPDHRrXW65xR6GV.gVZND8C0", "mkrqFG26m7Vmv-28etQVyp04"}
371 , {"true", "8966", "7k2sRK2qSFRVCFpEvrlbmxAL", "IlvfmWTqzpF0Jo3elpZPHXx"}
372 , {"true", "01303495", "G26yl8B0NbLIKxu23h86QbZz", "vSou1seqCrcv9KoVbhlj4Wa4"}
373 , {"true", "787", "ce7joKCHYowpM2PtCb53Zs2v", ".qw1oY9HKjfAF2Yt05JNgib9"}
374 , {"true", "40116583", "-3bDEzEn.RbNnT2hWKQqf2HL", "QzlKlKZiIpc7sQ.EzO"}
375 , {"false", "", "222", "333"}
376 , {"false", "111", "", "333"}
377 , {"false", "111", "222", ""}
378 , {"false", "111a", "222", "333"}
379 , {"false", "aaa", "222", "333"}
380 , {"false", "111-", "222", "333"}
381 // , {"false", " 111", "222", "333"}
382 // , {"false", "111", "222 ", "333"}
383 // , {"false", "111", "222", " 333"}
384 , {"false", "111", "222", "3 33"}
385 , {"false", "111", "22,2", "333"}
386 , {"false", "111", "222~", "333"}
387 , {"false", "111", "222", "333&"}
388 , {"false", "$", "222", "333"}
389 , {"false", "111", "@", "333"}
390 , {"false", "111", "222", "^^^^^^"}
393 for (String[] option : options) {
394 fillVNFInPlace3Fields(option[1], option[2], option[3]);
395 assertThat("failed for set: " + Arrays.toString(option),
396 Get.byId(Constants.generalSubmitButtonId).isEnabled(), is(Boolean.parseBoolean(option[0])));
401 private void fillVNFInPlace3Fields(String operationsTimeout, String existingSwVersion, String newSwVersion) {
402 Get.byId("operations-timeout").clear();
403 Get.byId("existing-software-version").clear();
404 Get.byId("new-software-version").clear();
406 Get.byId("operations-timeout").sendKeys(operationsTimeout);
407 Get.byId("existing-software-version").sendKeys(existingSwVersion);
408 Get.byId("new-software-version").sendKeys(newSwVersion);
411 private List<String> getListOfWorkflowsFor(String vnfName) {
413 openAndFill1stScreen(vnfName, null /*no matter*/, "Replace");
415 Select selectlist = new Select(Get.byId("workflow"));
416 List<String> workflows = selectlist.getOptions().stream().map(we -> we.getText()).collect(Collectors.toList());
418 Click.byId(Constants.generalCancelButtonId);
424 public static Object[][] dataForUpdateWorkflowPartialWithInPlace() {
425 return new Object[][] {
426 { "1111", "22222", "33333" }
427 , {"8", "3t3MhTRqkyjB85o5NC9OacAw", "B.bJ6f7KYI6Wz-----DMR0.fyNM9r4"}
428 , {"78058488", "n", "WkH"}
432 // Deleted testVidToMsoCallbackDataWithInPlaceSWUpdate test. It was using assertThatVidToMsoCallbackDataIsOk which is no longer valid.
436 // Deleted testUploadConfigUpdateFile test. It was using assertThatVidToMsoCallbackDataIsOk which is no longer valid.
439 public void testUploadConfigUpdateNonCsvFile() {
440 String fileName = "non-valid.json";
441 updateConfigFile(fileName);
442 WebElement errorLabel = Get.byId("errorLabel");
443 Assert.assertEquals("wrong error message for non csv file", "Invalid file type. Please select a file with a CSV extension.", errorLabel.getText());
444 Assert.assertFalse(Get.byId(Constants.generalSubmitButtonId).isEnabled());
447 @Test(dataProvider = "invalidCsvFiles")
448 public void testUploadInvalidConfigUpdateFile(String fileName) {
449 updateConfigFile(fileName);
450 WebElement errorLabel = Get.byId("errorContentLabel");
451 Assert.assertEquals("wrong error message for non csv file", "Invalid file structure.", errorLabel.getText());
452 Assert.assertFalse(Get.byId(Constants.generalSubmitButtonId).isEnabled());
456 public static Object[][] invalidCsvFiles() {
457 return new Object[][] {
459 {"withoutPayload.csv"},
460 {"withoutConfigurationParameters.csv"},
461 {"withoutRequestParameters.csv"}
465 // Deleted testVidToMsoCallbackData test. It was using assertThatVidToMsoCallbackDataIsOk which is no longer valid.
467 private void assertThatVidToMsoCallbackDataIsOk(String workflow, String payload) {
468 Assert.assertTrue(Get.byId(Constants.generalSubmitButtonId).isEnabled());
469 Click.byId(Constants.generalSubmitButtonId);
471 String vidToMsoCallbackData = Input.getValueByTestId("vidToMsoCallbackData");
473 String modelInvariantId = "72e465fe-71b1-4e7b-b5ed-9496118ff7a8";
474 String vnfInstanceId = "8e5e3ba1-3fe6-4d86-966e-f9f03dab4855";
475 String expected = getExpectedVidToMsoCallbackData(modelInvariantId, vnfInstanceId, VNF_DATA_WITH_IN_PLACE.vnfName, VNF_DATA_WITH_IN_PLACE.vnfTargetVersion, workflow, payload);
478 JSONAssert.assertEquals("built mso request is not ok", expected, vidToMsoCallbackData, JSONCompareMode.STRICT);
479 } catch (JSONException e) {
480 throw new RuntimeException(e);
483 Click.byId(Constants.generalCancelButtonId);
486 @Test(enabled = false)
487 public void testUpdateWorkflowNow() {
489 String workflow = "Update";
491 String duration = "1";
492 String fallback = "1";
493 String concurrencyLimit = "1";
494 String policy = "SNIRO_1710.Config_MS_PlacementOptimizationPolicy_dhv_v1.1.xml";
496 openAndFill1stScreen(VNF_DATA_WITH_IN_PLACE.vnfName, VNF_DATA_WITH_IN_PLACE.vnfTargetVersion, workflow);
497 Assert.assertTrue(Get.byId(Constants.generalSubmitButtonId).isEnabled());
498 Click.byId(Constants.generalSubmitButtonId);
500 scheduleChange2ndScreen(duration, fallback, concurrencyLimit, policy);
504 public void testNewChangeManagementCreation() {
505 ChangeManagementPage.openChangeManagementPage();
507 //TODO: After scheduler will be ready than we will examine if the creation working fine.
511 public void testMainDashboardTable() {
512 ChangeManagementPage.openChangeManagementPage();
513 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.dashboardActiveTabId));
514 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.dashboardFinishedTabId));
516 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.dashboardActiveTableId));
517 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.dashboardInProgressTheadId));
518 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.dashboardPendingTheadId));
520 Click.byId(Constants.ChangeManagement.dashboardFinishedTabId);
521 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.dashboardFinishedTableId));
522 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.dashboardFinishedTheadId));
523 Click.byId(Constants.ChangeManagement.dashboardActiveTabId);
527 public void testMainDashboardTableContent() {
528 ChangeManagementPage.openChangeManagementPage();
529 GeneralUIUtils.ultimateWait();
530 List<WebElement> webElements = Get.multipleElementsByTestId(Constants.ChangeManagement.activeTableRowId);
531 assertThat("List of pending workflows is empty",webElements,is(not(empty())));
532 //TODO: After scheduler will be ready than we will examine if the content is valid.
537 public void testOnlyOneModalIsOpen() throws Exception {
539 updateSimulatorWithParametersOfScheduledJod("mso_get_change_managements.json");
541 ChangeManagementPage.openChangeManagementPage();
543 Wait.byText("ReplaceVnfInfra");
544 GeneralUIUtils.ultimateWait();
548 List<WebElement> elements = Get.byClass(Constants.ChangeManagement.pendingIconClass);
549 Assert.assertTrue(elements != null && elements.size() > 0);
551 ((JavascriptExecutor)getDriver()).executeScript("arguments[0].scrollIntoView();", elements.get(0));
554 elements.get(0).click();
556 GeneralUIUtils.ultimateWait();
558 elements = Get.byClass(Constants.ChangeManagement.pendingIconClass);
559 Assert.assertTrue(elements != null && elements.size() > 0);
560 elements.get(2).click();
562 GeneralUIUtils.ultimateWait();
563 List<WebElement> webElements = Get.byClass("modal-dialog");
564 Assert.assertTrue(webElements.size() == 1);
568 @Test(enabled = false)
569 public void testOpenFailedStatusModal() {
570 ChangeManagementPage.openChangeManagementPage();
572 if(!Exists.byClass(Constants.ChangeManagement.failedIconClass)) {
573 //TODO: Create a job which will shown with status fail.
576 Click.byClass(Constants.ChangeManagement.failedIconClass);
577 Wait.modalToBeDisplayed();
578 Assert.assertTrue(Exists.modal());
579 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.failedModalHeaderId));
580 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.failedModalContentId));
581 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.failedModalRetryButtonId));
582 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.failedModalRollbackButtonId));
584 Click.byClass(Constants.generalCloseModalButtonClass);
585 Wait.modalToDisappear();
588 @Test(enabled = false)
589 public void testOpenInProgressStatusModal() {
590 ChangeManagementPage.openChangeManagementPage();
592 if(!Exists.byClass(Constants.ChangeManagement.processIconClass)) {
593 //TODO: Create a job which will shown with status in-progress.
596 Click.byClass(Constants.ChangeManagement.processIconClass);
597 Wait.modalToBeDisplayed();
598 Assert.assertTrue(Exists.modal());
599 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.inProgressModalHeaderId));
600 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.inProgressModalContentId));
601 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.inProgressModalStopButtonId));
602 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.inProgressModalRollbackButtonId));
604 Click.byClass(Constants.generalCloseModalButtonClass);
605 Wait.modalToDisappear();
608 @Test(enabled = false)
609 public void testOpenAlertStatusModal() {
610 ChangeManagementPage.openChangeManagementPage();
612 if(!Exists.byClass(Constants.ChangeManagement.alertIconClass)) {
613 //TODO: Create a job which will shown with status alert.
616 Click.byClass(Constants.ChangeManagement.alertIconClass);
617 Wait.modalToBeDisplayed();
618 Assert.assertTrue(Exists.modal());
619 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.alertModalHeaderId));
620 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.alertModalContentId));
621 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.alertModalContinueButtonId));
622 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.alertModalRollbackButtonId));
624 Click.byClass(Constants.generalCloseModalButtonClass);
625 Wait.modalToDisappear();
628 @Test(enabled = false)
629 public void testOpenPendingStatusModal() {
630 ChangeManagementPage.openChangeManagementPage();
632 if(!Exists.byClass(Constants.ChangeManagement.pendingIconClass)) {
633 //TODO: Create a job which will shown with status pending.
636 Click.byClass(Constants.ChangeManagement.pendingIconClass);
637 Wait.modalToBeDisplayed();
638 Assert.assertTrue(Exists.modal());
639 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.pendingModalHeaderId));
640 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.pendingModalContentId));
641 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.pendingModalRescheduleButtonId));
642 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.pendingModalRollbackButtonId));
644 Click.byClass(Constants.generalCloseModalButtonClass);
645 Wait.modalToDisappear();
648 @Test(enabled = false)
649 public void testSuccessCancelPendingWorkflow() {
650 ChangeManagementPage.openChangeManagementPage();
651 Wait.angularHttpRequestsLoaded();
653 Click.byClass(Constants.ChangeManagement.cancelPendingButtonClass); //cancel pending workflow modal
654 Wait.modalToBeDisplayed();
655 Assert.assertTrue(Exists.modal());
656 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.pendingModalHeaderId));
657 Assert.assertTrue(Exists.byClass(Constants.ChangeManagement.pendingModalCancelWorkflowButtonClass));
658 Click.byClass(Constants.ChangeManagement.pendingModalCancelWorkflowButtonClass);
659 Wait.angularHttpRequestsLoaded();
661 Wait.modalToBeDisplayed(); //success alert modal should appear
662 Assert.assertTrue(Exists.modal());
663 Assert.assertTrue(Exists.byId(Constants.ChangeManagement.alertModalHeaderId));
664 Assert.assertTrue(Exists.byClassAndText(Constants.generalModalTitleClass, "Success"));
665 Click.byClass(Constants.generalCloseModalButtonClass);
666 Wait.modalToDisappear();
667 //TODO check the workflow deleted from table/changed to deleted action
671 public void testRefreshPageButton() {
672 ChangeManagementPage.openChangeManagementPage();
673 GeneralUIUtils.ultimateWait();
674 List<WebElement> pendingRows = Get.multipleElementsByTestId(Constants.ChangeManagement.pendingTableRowId);
675 List<WebElement> activeRows = Get.multipleElementsByTestId(Constants.ChangeManagement.activeTableRowId);
676 assertThat("The pending table has no content",pendingRows, is(not(empty())));
677 assertThat("The active table has no content",activeRows, is(not(empty())));
678 Click.byTestId(Constants.ChangeManagement.refreshBtnTestId);
679 GeneralUIUtils.ultimateWait();
680 pendingRows = Get.multipleElementsByTestId(Constants.ChangeManagement.pendingTableRowId);
681 assertThat("The pending table has no content",pendingRows, is(not(empty())));
682 assertThat("The active table has no content",activeRows, is(not(empty())));
683 //return the register requests to the default state
684 registerDefaultTablesData();
687 private String getExpectedVidToMsoCallbackData(String modelInvariantId, String vnfInstanceId, String vnfName, String vnfTargetVersion, String workflow, String payload) {
690 " \"requestType\": \"" + workflow + "\"," +
691 " \"requestDetails\": [" +
693 " \"vnfName\": \"" + vnfName + "\"," +
694 " \"vnfInstanceId\": \"" + vnfInstanceId + "\"," +
695 " \"modelInfo\": {" +
696 " \"modelType\": \"vnf\"," +
697 " \"modelInvariantId\": \"" + modelInvariantId + "\"," +
698 " \"modelVersionId\": \"76e908e0-5201-44d2-a3e2-9e6128d05820\"," +
699 " \"modelName\": \"" + vnfName + "\"," +
700 " \"modelVersion\": \"" + vnfTargetVersion + "\"," +
701 " \"modelCustomizationId\": \"c00e8fc8-af39-4da8-8c78-a7efc2fe5994\"" +
703 " \"cloudConfiguration\": {" +
704 " \"lcpCloudRegionId\": \"mdt1\"," +
705 " \"tenantId\": \"88a6ca3ee0394ade9403f075db23167e\"" +
707 " \"requestInfo\": {" +
708 " \"source\": \"VID\"," +
709 " \"suppressRollback\": false," +
710 " \"requestorId\": \"az2016\"" +
712 " \"relatedInstanceList\": [" +
714 " \"relatedInstance\": {" +
715 " \"instanceId\": \"97315a05-e6f3-4c47-ae7e-d850c327aa08\"," +
716 " \"modelInfo\": {" +
717 " \"modelType\": \"service\"," +
718 " \"modelInvariantId\": \"e49fbd11-e60c-4a8e-b4bf-30fbe8f4fcc0\"," +
719 " \"modelVersionId\": \"76e908e0-5201-44d2-a3e2-9e6128d05820\"," +
720 " \"modelName\": \"action-data\"," +
721 " \"modelVersion\": \"1.0\"" +
726 " \"requestParameters\": {" +
728 " \"usePreload\": true" +