@eclipse-che/che-e2e 7.73.0-dev-1397a5e → 7.73.0-dev-62c0c9d

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (175) hide show
  1. package/configs/inversify.config.ts +6 -6
  2. package/configs/inversify.types.ts +27 -27
  3. package/configs/mocharc.ts +21 -21
  4. package/constants/APITestConstants.ts +39 -38
  5. package/constants/BaseTestConstants.ts +44 -43
  6. package/constants/ChromeDriverConstants.ts +29 -29
  7. package/constants/FactoryTestConstants.ts +30 -30
  8. package/constants/MonacoConstants.ts +10 -10
  9. package/constants/OAuthConstants.ts +46 -46
  10. package/constants/ReporterConstants.ts +28 -28
  11. package/constants/TimeoutConstants.ts +101 -101
  12. package/dist/configs/inversify.config.js.map +1 -1
  13. package/dist/configs/inversify.types.js.map +1 -1
  14. package/dist/configs/mocharc.js +1 -1
  15. package/dist/configs/mocharc.js.map +1 -1
  16. package/dist/constants/APITestConstants.js +2 -2
  17. package/dist/constants/APITestConstants.js.map +1 -1
  18. package/dist/constants/BaseTestConstants.js +1 -1
  19. package/dist/constants/BaseTestConstants.js.map +1 -1
  20. package/dist/constants/ChromeDriverConstants.js +1 -1
  21. package/dist/constants/ChromeDriverConstants.js.map +1 -1
  22. package/dist/constants/FactoryTestConstants.js +1 -1
  23. package/dist/constants/FactoryTestConstants.js.map +1 -1
  24. package/dist/constants/MonacoConstants.js +1 -1
  25. package/dist/constants/MonacoConstants.js.map +1 -1
  26. package/dist/constants/OAuthConstants.js +1 -1
  27. package/dist/constants/OAuthConstants.js.map +1 -1
  28. package/dist/constants/ReporterConstants.js +1 -1
  29. package/dist/constants/ReporterConstants.js.map +1 -1
  30. package/dist/constants/TimeoutConstants.js.map +1 -1
  31. package/dist/driver/ChromeDriver.js.map +1 -1
  32. package/dist/pageobjects/dashboard/CreateWorkspace.js +8 -8
  33. package/dist/pageobjects/dashboard/CreateWorkspace.js.map +1 -1
  34. package/dist/pageobjects/dashboard/Dashboard.js +11 -11
  35. package/dist/pageobjects/dashboard/Dashboard.js.map +1 -1
  36. package/dist/pageobjects/dashboard/Workspaces.js +14 -14
  37. package/dist/pageobjects/dashboard/Workspaces.js.map +1 -1
  38. package/dist/pageobjects/dashboard/workspace-details/WorkspaceDetails.js +8 -8
  39. package/dist/pageobjects/dashboard/workspace-details/WorkspaceDetails.js.map +1 -1
  40. package/dist/pageobjects/git-providers/OauthPage.js +17 -17
  41. package/dist/pageobjects/git-providers/OauthPage.js.map +1 -1
  42. package/dist/pageobjects/ide/CheCodeLocatorLoader.js +1 -1
  43. package/dist/pageobjects/ide/CheCodeLocatorLoader.js.map +1 -1
  44. package/dist/pageobjects/login/kubernetes/DexLoginPage.js +5 -5
  45. package/dist/pageobjects/login/kubernetes/DexLoginPage.js.map +1 -1
  46. package/dist/pageobjects/login/kubernetes/KubernetesLoginPage.js +1 -1
  47. package/dist/pageobjects/login/kubernetes/KubernetesLoginPage.js.map +1 -1
  48. package/dist/pageobjects/login/openshift/OcpLoginPage.js +10 -10
  49. package/dist/pageobjects/login/openshift/OcpLoginPage.js.map +1 -1
  50. package/dist/pageobjects/login/openshift/OcpRedHatLoginPage.js +2 -2
  51. package/dist/pageobjects/login/openshift/OcpRedHatLoginPage.js.map +1 -1
  52. package/dist/pageobjects/login/openshift/OcpUserLoginPage.js +1 -1
  53. package/dist/pageobjects/login/openshift/OcpUserLoginPage.js.map +1 -1
  54. package/dist/pageobjects/login/openshift/RedHatLoginPage.js +6 -6
  55. package/dist/pageobjects/login/openshift/RedHatLoginPage.js.map +1 -1
  56. package/dist/pageobjects/login/openshift/RegularUserOcpCheLoginPage.js +2 -2
  57. package/dist/pageobjects/login/openshift/RegularUserOcpCheLoginPage.js.map +1 -1
  58. package/dist/pageobjects/openshift/OcpApplicationPage.js +2 -2
  59. package/dist/pageobjects/openshift/OcpApplicationPage.js.map +1 -1
  60. package/dist/pageobjects/openshift/OcpImportFromGitPage.js +5 -5
  61. package/dist/pageobjects/openshift/OcpImportFromGitPage.js.map +1 -1
  62. package/dist/pageobjects/openshift/OcpMainPage.js +11 -11
  63. package/dist/pageobjects/openshift/OcpMainPage.js.map +1 -1
  64. package/dist/specs/MochaHooks.js +1 -1
  65. package/dist/specs/MochaHooks.js.map +1 -1
  66. package/dist/specs/SmokeTest.spec.js +7 -3
  67. package/dist/specs/SmokeTest.spec.js.map +1 -1
  68. package/dist/specs/api/ContainerOverridesAPI.spec.js.map +1 -1
  69. package/dist/specs/api/DevfileAcceptanceTestAPI.spec.js +7 -5
  70. package/dist/specs/api/DevfileAcceptanceTestAPI.spec.js.map +1 -1
  71. package/dist/specs/api/EmptyWorkspaceAPI.spec.js +1 -1
  72. package/dist/specs/api/EmptyWorkspaceAPI.spec.js.map +1 -1
  73. package/dist/specs/api/PodOverridesAPI.spec.js.map +1 -1
  74. package/dist/specs/dashboard-samples/EmptyWorkspace.spec.js +9 -5
  75. package/dist/specs/dashboard-samples/EmptyWorkspace.spec.js.map +1 -1
  76. package/dist/specs/dashboard-samples/Quarkus.spec.js +7 -3
  77. package/dist/specs/dashboard-samples/Quarkus.spec.js.map +1 -1
  78. package/dist/specs/dashboard-samples/RecommendedExtensions.spec.js +6 -2
  79. package/dist/specs/dashboard-samples/RecommendedExtensions.spec.js.map +1 -1
  80. package/dist/specs/devconsole-intergration/DevConsoleIntegration.spec.js +3 -1
  81. package/dist/specs/devconsole-intergration/DevConsoleIntegration.spec.js.map +1 -1
  82. package/dist/specs/factory/Factory.spec.js +3 -1
  83. package/dist/specs/factory/Factory.spec.js.map +1 -1
  84. package/dist/specs/factory/NoSetupRepoFactory.spec.js +4 -2
  85. package/dist/specs/factory/NoSetupRepoFactory.spec.js.map +1 -1
  86. package/dist/specs/factory/RefusedOAuthFactory.spec.js +4 -2
  87. package/dist/specs/factory/RefusedOAuthFactory.spec.js.map +1 -1
  88. package/dist/specs/miscellaneous/PredefinedNamespace.spec.js +6 -2
  89. package/dist/specs/miscellaneous/PredefinedNamespace.spec.js.map +1 -1
  90. package/dist/tests-library/LoginTests.js.map +1 -1
  91. package/dist/tests-library/ProjectAndFileTests.js +3 -3
  92. package/dist/tests-library/ProjectAndFileTests.js.map +1 -1
  93. package/dist/tests-library/WorkspaceHandlingTests.js +54 -74
  94. package/dist/tests-library/WorkspaceHandlingTests.js.map +1 -1
  95. package/dist/utils/BrowserTabsUtil.js +10 -10
  96. package/dist/utils/BrowserTabsUtil.js.map +1 -1
  97. package/dist/utils/CheReporter.js.map +1 -1
  98. package/dist/utils/DevWorkspaceConfigurationHelper.js +2 -2
  99. package/dist/utils/DevWorkspaceConfigurationHelper.js.map +1 -1
  100. package/dist/utils/DevfilesRegistryHelper.js +7 -7
  101. package/dist/utils/DevfilesRegistryHelper.js.map +1 -1
  102. package/dist/utils/DriverHelper.js +81 -81
  103. package/dist/utils/DriverHelper.js.map +1 -1
  104. package/dist/utils/KubernetesCommandLineToolsExecutor.js +38 -35
  105. package/dist/utils/KubernetesCommandLineToolsExecutor.js.map +1 -1
  106. package/dist/utils/Logger.js +19 -10
  107. package/dist/utils/Logger.js.map +1 -1
  108. package/dist/utils/ScreenCatcher.js.map +1 -1
  109. package/dist/utils/ShellExecutor.js.map +1 -1
  110. package/dist/utils/StringUtil.js +2 -2
  111. package/dist/utils/StringUtil.js.map +1 -1
  112. package/dist/utils/request-handlers/CheApiRequestHandler.js +13 -11
  113. package/dist/utils/request-handlers/CheApiRequestHandler.js.map +1 -1
  114. package/dist/utils/request-handlers/headers/CheMultiuserAuthorizationHeaderHandler.js +1 -1
  115. package/dist/utils/request-handlers/headers/CheMultiuserAuthorizationHeaderHandler.js.map +1 -1
  116. package/dist/utils/workspace/ApiUrlResolver.js +3 -3
  117. package/dist/utils/workspace/ApiUrlResolver.js.map +1 -1
  118. package/dist/utils/workspace/TestWorkspaceUtil.js +20 -16
  119. package/dist/utils/workspace/TestWorkspaceUtil.js.map +1 -1
  120. package/dist/utils/workspace/WorkspaceStatus.js.map +1 -1
  121. package/driver/ChromeDriver.ts +44 -44
  122. package/driver/IDriver.ts +1 -1
  123. package/package.json +1 -1
  124. package/pageobjects/dashboard/CreateWorkspace.ts +52 -52
  125. package/pageobjects/dashboard/Dashboard.ts +72 -72
  126. package/pageobjects/dashboard/Workspaces.ts +138 -139
  127. package/pageobjects/dashboard/workspace-details/WorkspaceDetails.ts +92 -93
  128. package/pageobjects/git-providers/OauthPage.ts +136 -136
  129. package/pageobjects/ide/CheCodeLocatorLoader.ts +40 -40
  130. package/pageobjects/login/interfaces/ICheLoginPage.ts +1 -1
  131. package/pageobjects/login/interfaces/IOcpLoginPage.ts +1 -1
  132. package/pageobjects/login/kubernetes/DexLoginPage.ts +27 -27
  133. package/pageobjects/login/kubernetes/KubernetesLoginPage.ts +11 -11
  134. package/pageobjects/login/openshift/OcpLoginPage.ts +50 -50
  135. package/pageobjects/login/openshift/OcpRedHatLoginPage.ts +21 -21
  136. package/pageobjects/login/openshift/OcpUserLoginPage.ts +14 -14
  137. package/pageobjects/login/openshift/RedHatLoginPage.ts +44 -41
  138. package/pageobjects/login/openshift/RegularUserOcpCheLoginPage.ts +23 -23
  139. package/pageobjects/openshift/OcpApplicationPage.ts +16 -16
  140. package/pageobjects/openshift/OcpImportFromGitPage.ts +54 -54
  141. package/pageobjects/openshift/OcpMainPage.ts +64 -64
  142. package/specs/MochaHooks.ts +44 -44
  143. package/specs/SmokeTest.spec.ts +35 -31
  144. package/specs/api/ContainerOverridesAPI.spec.ts +23 -23
  145. package/specs/api/DevfileAcceptanceTestAPI.spec.ts +93 -91
  146. package/specs/api/EmptyWorkspaceAPI.spec.ts +50 -50
  147. package/specs/api/PodOverridesAPI.spec.ts +29 -29
  148. package/specs/dashboard-samples/EmptyWorkspace.spec.ts +29 -25
  149. package/specs/dashboard-samples/Quarkus.spec.ts +31 -27
  150. package/specs/dashboard-samples/RecommendedExtensions.spec.ts +156 -152
  151. package/specs/devconsole-intergration/DevConsoleIntegration.spec.ts +62 -64
  152. package/specs/factory/Factory.spec.ts +149 -147
  153. package/specs/factory/NoSetupRepoFactory.spec.ts +188 -186
  154. package/specs/factory/RefusedOAuthFactory.spec.ts +182 -180
  155. package/specs/miscellaneous/PredefinedNamespace.spec.ts +52 -48
  156. package/tests-library/LoginTests.ts +29 -29
  157. package/tests-library/ProjectAndFileTests.ts +13 -13
  158. package/tests-library/WorkspaceHandlingTests.ts +84 -103
  159. package/utils/BrowserTabsUtil.ts +69 -69
  160. package/utils/CheReporter.ts +4 -6
  161. package/utils/DevWorkspaceConfigurationHelper.ts +58 -58
  162. package/utils/DevfilesRegistryHelper.ts +51 -51
  163. package/utils/DriverHelper.ts +599 -600
  164. package/utils/KubernetesCommandLineToolsExecutor.ts +166 -158
  165. package/utils/Logger.ts +98 -67
  166. package/utils/ScreenCatcher.ts +42 -42
  167. package/utils/ShellExecutor.ts +10 -10
  168. package/utils/StringUtil.ts +29 -29
  169. package/utils/request-handlers/CheApiRequestHandler.ts +84 -82
  170. package/utils/request-handlers/headers/CheMultiuserAuthorizationHeaderHandler.ts +18 -18
  171. package/utils/request-handlers/headers/IAuthorizationHeaderHandler.ts +1 -1
  172. package/utils/workspace/ApiUrlResolver.ts +23 -23
  173. package/utils/workspace/ITestWorkspaceUtil.ts +29 -29
  174. package/utils/workspace/TestWorkspaceUtil.ts +120 -116
  175. package/utils/workspace/WorkspaceStatus.ts +3 -3
@@ -46,156 +46,160 @@ const webCheCodeLocators: Locators = new CheCodeLocatorLoader().webCheCodeLocato
46
46
  const samples: string[] = PluginsTestConstants.TS_SAMPLE_LIST.split(',');
47
47
  const browserTabsUtil: BrowserTabsUtil = e2eContainer.get(CLASSES.BrowserTabsUtil);
48
48
 
49
- suite(`Check if recommended extensions installed for ${samples}`, async function (): Promise<void> {
50
- let projectSection: ViewSection;
51
- let extensionsView: SideBarView | undefined;
52
- let extensionSection: ExtensionsViewSection;
53
-
54
- const extensionsListFileName: string = 'extensions.json';
55
- let recommendedExtensions: any = {
56
- recommendations: []
57
- };
58
-
59
- loginTests.loginIntoChe();
60
-
61
- for (const sample of samples) {
62
- workspaceHandlingTests.createAndOpenWorkspace(sample);
63
- workspaceHandlingTests.obtainWorkspaceNameFromStartingPage();
64
-
65
- test('Registering the running workspace', async function (): Promise<void> {
66
- registerRunningWorkspace(WorkspaceHandlingTests.getWorkspaceName());
67
- });
68
-
69
- test('Wait workspace readiness', async function (): Promise<void> {
70
- await projectAndFileTests.waitWorkspaceReadinessForCheCodeEditor();
71
- });
72
-
73
- test('Wait until the project will be imported and accept it as trusted one', async function (): Promise<void> {
74
- [projectSection] = await new SideBarView().getContent().getSections();
75
- const label: string = BaseTestConstants.TS_SELENIUM_PROJECT_ROOT_FILE_NAME;
76
- Logger.debug(`projectSection.findItem: find ${label}`);
77
- const isFileImported: ViewItem | undefined = await projectSection.findItem(label);
78
- expect(isFileImported).not.eqls(undefined);
79
- try {
80
- const buttonYesITrustTheAuthors: string = `Yes, I trust the authors`;
81
- await driverHelper.waitVisibility(webCheCodeLocators.WelcomeContent.button, TimeoutConstants.TS_DIALOG_WINDOW_DEFAULT_TIMEOUT);
82
- const trustedProjectDialog: ModalDialog = new ModalDialog();
83
- Logger.debug(`trustedProjectDialog.pushButton: "${buttonYesITrustTheAuthors}"`);
84
- await trustedProjectDialog.pushButton(buttonYesITrustTheAuthors);
85
- } catch (e) {
86
- Logger.debug(`Welcome modal dialog was not shown: ${e}`);
87
- }
88
- });
89
-
90
- test(`Get recommended extensions list from ${extensionsListFileName}`, async function (): Promise<void> {
91
- Logger.debug(`projectSection.findItem(item))?.select(): expand .vscode folder and open extensions.json.`);
92
- await (await projectSection.findItem('.vscode'))?.select();
93
- // time to expand project tree
94
- await driverHelper.wait(TimeoutConstants.TS_EXPAND_PROJECT_TREE_ITEM_TIMEOUT);
95
- await (await projectSection.findItem(extensionsListFileName))?.select();
96
- Logger.debug(`EditorView().openEditor(${extensionsListFileName})`);
97
- const editor: TextEditor = await new EditorView().openEditor(extensionsListFileName) as TextEditor;
98
- await driverHelper.waitVisibility(webCheCodeLocators.Editor.inputArea);
99
- Logger.debug(`editor.getText(): get recommended extensions as text from editor, delete comments and parse to object.`);
100
- recommendedExtensions = JSON.parse((await editor.getText()).replace(/\/\*[\s\S]*?\*\/|(?<=[^:])\/\/.*|^\/\/.*/g, '').trim());
101
- Logger.debug(`recommendedExtensions.recommendations: Get recommendations clear names using map().`);
102
- recommendedExtensions.recommendations = recommendedExtensions.recommendations.map((r: { split: (arg: string) => [any, any]; }) => {
103
- const [publisher, name] = r.split('.');
104
- return {publisher, name};
105
- });
106
- Logger.info(`Recommended extension for this workspace:\n${JSON.stringify(recommendedExtensions.recommendations)}.`);
107
- });
108
-
109
- test(`Open "Extensions" view section`, async function (): Promise<void> {
110
- Logger.debug(`ActivityBar().getViewControl('Extensions'))?.openView(): open Extensions view.`);
111
- extensionsView = await (await new ActivityBar().getViewControl('Extensions'))?.openView();
112
- });
113
-
114
- test(`Let extensions complete installation`, async function (): Promise<void> {
115
- Logger.info(`Time for extensions installation TimeoutConstants.TS_COMMON_PLUGIN_TEST_TIMEOUT=${TimeoutConstants.TS_COMMON_PLUGIN_TEST_TIMEOUT}`);
116
- await driverHelper.wait(TimeoutConstants.TS_COMMON_PLUGIN_TEST_TIMEOUT);
117
- });
118
-
119
- test(`Check if extensions are installed and enabled`, async function (): Promise<void> {
120
- this.retries(10);
121
- Logger.debug(`ActivityBar().getViewControl('Extensions'))?.openView(): open Extensions view.`);
122
- extensionsView = await (await new ActivityBar().getViewControl('Extensions'))?.openView();
123
-
124
- Logger.debug(`extensionsView?.getContent().getSections(): get current section.`);
125
- [extensionSection] = await extensionsView?.getContent().getSections() as ExtensionsViewSection[];
126
- await driverHelper.waitAllPresence(webCheCodeLocators.ExtensionsViewSection.itemTitle, TimeoutConstants.TS_EDITOR_TAB_INTERACTION_TIMEOUT);
127
-
128
- for (const extension of recommendedExtensions.recommendations) {
129
- Logger.info(`Check if ${JSON.stringify(extension)} are installed.`);
130
-
131
- Logger.debug(`extensionSection.findItem(${extension.name}).`);
132
- await extensionSection.findItem(extension.name);
133
-
134
- // check if extension require reload the page
135
- if (await driverHelper.isVisible((webCheCodeLocators.ExtensionsViewSection as any).requireReloadButton)) {
136
- Logger.debug(`Extension require reload the editor. Refreshing the page..`);
137
- await browserTabsUtil.refreshPage();
138
- await projectAndFileTests.waitWorkspaceReadinessForCheCodeEditor();
139
- Logger.debug(`ActivityBar().getViewControl('Extensions'))?.openView(): open Extensions view.`);
140
- extensionsView = await (await new ActivityBar().getViewControl('Extensions'))?.openView();
141
- Logger.debug(`extensionsView?.getContent().getSections(): get current section.`);
142
- [extensionSection] = await extensionsView?.getContent().getSections() as ExtensionsViewSection[];
143
- await driverHelper.waitAllPresence(webCheCodeLocators.ExtensionsViewSection.itemTitle, TimeoutConstants.TS_EDITOR_TAB_INTERACTION_TIMEOUT);
144
- Logger.debug(`extensionSection.findItem(${extension.name}).`);
145
- await extensionSection.findItem(extension.name);
146
- }
147
-
148
- Logger.debug(`extensionsView?.getContent().getSections(): switch to marketplace section.`);
149
- const [marketplaceSection]: ExtensionsViewSection[] = await extensionsView?.getContent().getSections() as ExtensionsViewSection[];
150
- await driverHelper.waitVisibility(webCheCodeLocators.ExtensionsViewSection.items, TimeoutConstants.TS_EDITOR_TAB_INTERACTION_TIMEOUT);
151
-
152
- Logger.debug(`marketplaceSection.getVisibleItems(): get all found items.`);
153
- const allFinedItems: ExtensionsViewItem[] = await marketplaceSection.getVisibleItems();
154
-
155
- let itemWithRightNameAndPublisher: ExtensionsViewItem | undefined;
156
- for (const item of allFinedItems) {
157
- Logger.debug(`Try to find extension published by ${extension.publisher}.`);
158
- if (await item.getAuthor() === extension.publisher) {
159
- itemWithRightNameAndPublisher = item;
160
- Logger.debug(`Extension was found: ${await itemWithRightNameAndPublisher?.getTitle()}`);
161
- break;
162
- }
163
- if (itemWithRightNameAndPublisher === undefined) {
164
- Logger.error(`Extension with publisher as ${extension.publisher} was not found.`);
165
- }
166
- }
167
-
168
- Logger.debug(`itemWithRightNameAndPublisher?.isInstalled()`);
169
- const isInstalled: boolean = await itemWithRightNameAndPublisher?.isInstalled() as boolean;
170
-
171
- Logger.debug(`itemWithRightNameAndPublisher?.isInstalled(): ${isInstalled}.`);
172
- expect(isInstalled).eqls(true);
173
-
174
- Logger.debug(`itemWithRightNameAndPublisher.manage(): get context menu.`);
175
- const extensionManageMenu: ContextMenu = await (itemWithRightNameAndPublisher as ExtensionsViewItem).manage();
176
-
177
- Logger.debug(`extensionManageMenu.getItems(): get menu items.`);
178
- const extensionMenuItems: ContextMenuItem[] = await extensionManageMenu.getItems();
179
- let extensionMenuItemLabels: string = '';
180
- for (const item of extensionMenuItems) {
181
- Logger.trace(`extensionMenuItems -> item.getLabel(): get menu items names.`);
182
- extensionMenuItemLabels += (await item.getLabel()) + ' ';
183
- }
184
-
185
- Logger.debug(`extensionMenuItemLabels: ${extensionMenuItemLabels}.`);
186
- expect(extensionMenuItemLabels).contains('Disable').and.not.contains('Enable');
187
- }
188
- });
189
-
190
- test('Stop the workspace', async function (): Promise<void> {
191
- await workspaceHandlingTests.stopWorkspace(WorkspaceHandlingTests.getWorkspaceName());
192
- await browserTabsUtil.closeAllTabsExceptCurrent();
193
- });
194
-
195
- test('Delete the workspace', async function (): Promise<void> {
196
- await workspaceHandlingTests.removeWorkspace(WorkspaceHandlingTests.getWorkspaceName());
197
- });
198
- }
199
-
200
- loginTests.logoutFromChe();
49
+ suite(`Check if recommended extensions installed for ${samples}`, async function(): Promise<void> {
50
+ let projectSection: ViewSection;
51
+ let extensionsView: SideBarView | undefined;
52
+ let extensionSection: ExtensionsViewSection;
53
+
54
+ const extensionsListFileName: string = 'extensions.json';
55
+ let recommendedExtensions: any = {
56
+ recommendations: []
57
+ };
58
+
59
+ loginTests.loginIntoChe();
60
+
61
+ for (const sample of samples) {
62
+ test(`Create and open new workspace, stack:${sample}`, async function(): Promise<void> {
63
+ await workspaceHandlingTests.createAndOpenWorkspace(sample);
64
+ });
65
+ test('Obtain workspace name from workspace loader page', async function(): Promise<void> {
66
+ await workspaceHandlingTests.obtainWorkspaceNameFromStartingPage();
67
+ });
68
+
69
+ test('Registering the running workspace', async function(): Promise<void> {
70
+ registerRunningWorkspace(WorkspaceHandlingTests.getWorkspaceName());
71
+ });
72
+
73
+ test('Wait workspace readiness', async function(): Promise<void> {
74
+ await projectAndFileTests.waitWorkspaceReadinessForCheCodeEditor();
75
+ });
76
+
77
+ test('Wait until the project will be imported and accept it as trusted one', async function(): Promise<void> {
78
+ [projectSection] = await new SideBarView().getContent().getSections();
79
+ const label: string = BaseTestConstants.TS_SELENIUM_PROJECT_ROOT_FILE_NAME;
80
+ Logger.debug(`projectSection.findItem: find ${label}`);
81
+ const isFileImported: ViewItem | undefined = await projectSection.findItem(label);
82
+ expect(isFileImported).not.eqls(undefined);
83
+ try {
84
+ const buttonYesITrustTheAuthors: string = `Yes, I trust the authors`;
85
+ await driverHelper.waitVisibility(webCheCodeLocators.WelcomeContent.button, TimeoutConstants.TS_DIALOG_WINDOW_DEFAULT_TIMEOUT);
86
+ const trustedProjectDialog: ModalDialog = new ModalDialog();
87
+ Logger.debug(`trustedProjectDialog.pushButton: "${buttonYesITrustTheAuthors}"`);
88
+ await trustedProjectDialog.pushButton(buttonYesITrustTheAuthors);
89
+ } catch (e) {
90
+ Logger.debug(`Welcome modal dialog was not shown: ${e}`);
91
+ }
92
+ });
93
+
94
+ test(`Get recommended extensions list from ${extensionsListFileName}`, async function(): Promise<void> {
95
+ Logger.debug(`projectSection.findItem(item))?.select(): expand .vscode folder and open extensions.json.`);
96
+ await (await projectSection.findItem('.vscode'))?.select();
97
+ // time to expand project tree
98
+ await driverHelper.wait(TimeoutConstants.TS_EXPAND_PROJECT_TREE_ITEM_TIMEOUT);
99
+ await (await projectSection.findItem(extensionsListFileName))?.select();
100
+ Logger.debug(`EditorView().openEditor(${extensionsListFileName})`);
101
+ const editor: TextEditor = await new EditorView().openEditor(extensionsListFileName) as TextEditor;
102
+ await driverHelper.waitVisibility(webCheCodeLocators.Editor.inputArea);
103
+ Logger.debug(`editor.getText(): get recommended extensions as text from editor, delete comments and parse to object.`);
104
+ recommendedExtensions = JSON.parse((await editor.getText()).replace(/\/\*[\s\S]*?\*\/|(?<=[^:])\/\/.*|^\/\/.*/g, '').trim());
105
+ Logger.debug(`recommendedExtensions.recommendations: Get recommendations clear names using map().`);
106
+ recommendedExtensions.recommendations = recommendedExtensions.recommendations.map((r: { split: (arg: string) => [any, any]; }) => {
107
+ const [publisher, name] = r.split('.');
108
+ return { publisher, name };
109
+ });
110
+ Logger.info(`Recommended extension for this workspace:\n${JSON.stringify(recommendedExtensions.recommendations)}.`);
111
+ });
112
+
113
+ test(`Open "Extensions" view section`, async function(): Promise<void> {
114
+ Logger.debug(`ActivityBar().getViewControl('Extensions'))?.openView(): open Extensions view.`);
115
+ extensionsView = await (await new ActivityBar().getViewControl('Extensions'))?.openView();
116
+ });
117
+
118
+ test(`Let extensions complete installation`, async function(): Promise<void> {
119
+ Logger.info(`Time for extensions installation TimeoutConstants.TS_COMMON_PLUGIN_TEST_TIMEOUT=${TimeoutConstants.TS_COMMON_PLUGIN_TEST_TIMEOUT}`);
120
+ await driverHelper.wait(TimeoutConstants.TS_COMMON_PLUGIN_TEST_TIMEOUT);
121
+ });
122
+
123
+ test(`Check if extensions are installed and enabled`, async function(): Promise<void> {
124
+ this.retries(10);
125
+ Logger.debug(`ActivityBar().getViewControl('Extensions'))?.openView(): open Extensions view.`);
126
+ extensionsView = await (await new ActivityBar().getViewControl('Extensions'))?.openView();
127
+
128
+ Logger.debug(`extensionsView?.getContent().getSections(): get current section.`);
129
+ [extensionSection] = await extensionsView?.getContent().getSections() as ExtensionsViewSection[];
130
+ await driverHelper.waitAllPresence(webCheCodeLocators.ExtensionsViewSection.itemTitle, TimeoutConstants.TS_EDITOR_TAB_INTERACTION_TIMEOUT);
131
+
132
+ for (const extension of recommendedExtensions.recommendations) {
133
+ Logger.info(`Check if ${JSON.stringify(extension)} are installed.`);
134
+
135
+ Logger.debug(`extensionSection.findItem(${extension.name}).`);
136
+ await extensionSection.findItem(extension.name);
137
+
138
+ // check if extension require reload the page
139
+ if (await driverHelper.isVisible((webCheCodeLocators.ExtensionsViewSection as any).requireReloadButton)) {
140
+ Logger.debug(`Extension require reload the editor. Refreshing the page..`);
141
+ await browserTabsUtil.refreshPage();
142
+ await projectAndFileTests.waitWorkspaceReadinessForCheCodeEditor();
143
+ Logger.debug(`ActivityBar().getViewControl('Extensions'))?.openView(): open Extensions view.`);
144
+ extensionsView = await (await new ActivityBar().getViewControl('Extensions'))?.openView();
145
+ Logger.debug(`extensionsView?.getContent().getSections(): get current section.`);
146
+ [extensionSection] = await extensionsView?.getContent().getSections() as ExtensionsViewSection[];
147
+ await driverHelper.waitAllPresence(webCheCodeLocators.ExtensionsViewSection.itemTitle, TimeoutConstants.TS_EDITOR_TAB_INTERACTION_TIMEOUT);
148
+ Logger.debug(`extensionSection.findItem(${extension.name}).`);
149
+ await extensionSection.findItem(extension.name);
150
+ }
151
+
152
+ Logger.debug(`extensionsView?.getContent().getSections(): switch to marketplace section.`);
153
+ const [marketplaceSection]: ExtensionsViewSection[] = await extensionsView?.getContent().getSections() as ExtensionsViewSection[];
154
+ await driverHelper.waitVisibility(webCheCodeLocators.ExtensionsViewSection.items, TimeoutConstants.TS_EDITOR_TAB_INTERACTION_TIMEOUT);
155
+
156
+ Logger.debug(`marketplaceSection.getVisibleItems(): get all found items.`);
157
+ const allFinedItems: ExtensionsViewItem[] = await marketplaceSection.getVisibleItems();
158
+
159
+ let itemWithRightNameAndPublisher: ExtensionsViewItem | undefined;
160
+ for (const item of allFinedItems) {
161
+ Logger.debug(`Try to find extension published by ${extension.publisher}.`);
162
+ if (await item.getAuthor() === extension.publisher) {
163
+ itemWithRightNameAndPublisher = item;
164
+ Logger.debug(`Extension was found: ${await itemWithRightNameAndPublisher?.getTitle()}`);
165
+ break;
166
+ }
167
+ if (itemWithRightNameAndPublisher === undefined) {
168
+ Logger.error(`Extension with publisher as ${extension.publisher} was not found.`);
169
+ }
170
+ }
171
+
172
+ Logger.debug(`itemWithRightNameAndPublisher?.isInstalled()`);
173
+ const isInstalled: boolean = await itemWithRightNameAndPublisher?.isInstalled() as boolean;
174
+
175
+ Logger.debug(`itemWithRightNameAndPublisher?.isInstalled(): ${isInstalled}.`);
176
+ expect(isInstalled).eqls(true);
177
+
178
+ Logger.debug(`itemWithRightNameAndPublisher.manage(): get context menu.`);
179
+ const extensionManageMenu: ContextMenu = await (itemWithRightNameAndPublisher as ExtensionsViewItem).manage();
180
+
181
+ Logger.debug(`extensionManageMenu.getItems(): get menu items.`);
182
+ const extensionMenuItems: ContextMenuItem[] = await extensionManageMenu.getItems();
183
+ let extensionMenuItemLabels: string = '';
184
+ for (const item of extensionMenuItems) {
185
+ Logger.trace(`extensionMenuItems -> item.getLabel(): get menu items names.`);
186
+ extensionMenuItemLabels += (await item.getLabel()) + ' ';
187
+ }
188
+
189
+ Logger.debug(`extensionMenuItemLabels: ${extensionMenuItemLabels}.`);
190
+ expect(extensionMenuItemLabels).contains('Disable').and.not.contains('Enable');
191
+ }
192
+ });
193
+
194
+ test('Stop the workspace', async function(): Promise<void> {
195
+ await workspaceHandlingTests.stopWorkspace(WorkspaceHandlingTests.getWorkspaceName());
196
+ await browserTabsUtil.closeAllTabsExceptCurrent();
197
+ });
198
+
199
+ test('Delete the workspace', async function(): Promise<void> {
200
+ await workspaceHandlingTests.removeWorkspace(WorkspaceHandlingTests.getWorkspaceName());
201
+ });
202
+ }
203
+
204
+ loginTests.logoutFromChe();
201
205
  });
@@ -8,11 +8,7 @@
8
8
  * SPDX-License-Identifier: EPL-2.0
9
9
  **********************************************************************/
10
10
 
11
- import {
12
- SideBarView,
13
- ViewItem,
14
- ViewSection
15
- } from 'monaco-page-objects';
11
+ import { SideBarView, ViewItem, ViewSection } from 'monaco-page-objects';
16
12
  import { registerRunningWorkspace } from '../MochaHooks';
17
13
  import { LoginTests } from '../../tests-library/LoginTests';
18
14
  import { e2eContainer } from '../../configs/inversify.config';
@@ -36,63 +32,65 @@ let ocpApplicationPage: OcpApplicationPage;
36
32
  const kubernetesCommandLineToolsExecutor: KubernetesCommandLineToolsExecutor = new KubernetesCommandLineToolsExecutor();
37
33
 
38
34
  // works only with no-admin user
39
- suite(`DevConsole Integration`, async function (): Promise<void> {
40
- // test specific data
41
- const gitImportRepo: string = 'https://github.com/crw-qe/summit-lab-spring-music.git';
42
- const gitImportReference: string = 'pipeline';
43
- const projectLabel: string = 'app.openshift.io/runtime=spring';
44
- const projectName: string = 'devconsole-integration-test';
45
-
46
- suiteSetup('Create new empty project using ocp', async function (): Promise<void> {
47
- kubernetesCommandLineToolsExecutor.loginToOcp();
48
- kubernetesCommandLineToolsExecutor.createProject(projectName);
49
- });
50
-
51
- loginTests.loginIntoOcpConsole();
52
-
53
- test('Select test project and Developer role on DevConsole', async function (): Promise<void> {
54
- await ocpMainPage.selectDeveloperRole();
55
- await ocpMainPage.selectProject(projectName);
56
- });
57
-
58
- test('Open import from git project page', async function (): Promise<void> {
59
- ocpImportPage = await ocpMainPage.openImportFromGitPage();
60
- });
61
-
62
- test('Fill and submit import data', async function (): Promise<void> {
63
- ocpApplicationPage = await ocpImportPage.fitAndSubmitConfiguration(gitImportRepo, gitImportReference, projectLabel);
64
- });
65
-
66
- test('Wait until application creates', async function (): Promise<void> {
67
- await ocpApplicationPage.waitApplicationIcon();
68
- });
69
-
70
- test('Check if application has worked link "Open Source Code"', async function (): Promise<void> {
71
- await ocpApplicationPage.waitAndOpenEditSourceCodeIcon();
72
- });
73
-
74
- loginTests.loginIntoChe();
75
-
76
- workspaceHandlingTests.obtainWorkspaceNameFromStartingPage();
77
-
78
- test('Registering the running workspace', async function (): Promise<void> {
79
- registerRunningWorkspace(WorkspaceHandlingTests.getWorkspaceName());
80
- });
81
-
82
- test('Check if application source code opens in workspace', async function (): Promise<void> {
83
- await projectAndFileTests.waitWorkspaceReadinessForCheCodeEditor();
84
- });
85
-
86
- test('Check if project and files imported', async function (): Promise<void> {
87
- const applicationSourceProjectName: string = StringUtil.getProjectNameFromGitUrl(gitImportRepo);
88
- const projectSection: ViewSection = await new SideBarView().getContent().getSection(applicationSourceProjectName);
89
- const isFileImported: ViewItem | undefined = await projectSection.findItem(BaseTestConstants.TS_SELENIUM_PROJECT_ROOT_FILE_NAME);
90
- expect(isFileImported).not.eqls(undefined);
91
- });
92
-
93
- loginTests.logoutFromChe();
94
-
95
- suiteTeardown('Delete project using ocp', async function (): Promise<void> {
96
- kubernetesCommandLineToolsExecutor.deleteProject(projectName);
97
- });
35
+ suite(`DevConsole Integration`, async function(): Promise<void> {
36
+ // test specific data
37
+ const gitImportRepo: string = 'https://github.com/crw-qe/summit-lab-spring-music.git';
38
+ const gitImportReference: string = 'pipeline';
39
+ const projectLabel: string = 'app.openshift.io/runtime=spring';
40
+ const projectName: string = 'devconsole-integration-test';
41
+
42
+ suiteSetup('Create new empty project using ocp', async function(): Promise<void> {
43
+ kubernetesCommandLineToolsExecutor.loginToOcp();
44
+ kubernetesCommandLineToolsExecutor.createProject(projectName);
45
+ });
46
+
47
+ loginTests.loginIntoOcpConsole();
48
+
49
+ test('Select test project and Developer role on DevConsole', async function(): Promise<void> {
50
+ await ocpMainPage.selectDeveloperRole();
51
+ await ocpMainPage.selectProject(projectName);
52
+ });
53
+
54
+ test('Open import from git project page', async function(): Promise<void> {
55
+ ocpImportPage = await ocpMainPage.openImportFromGitPage();
56
+ });
57
+
58
+ test('Fill and submit import data', async function(): Promise<void> {
59
+ ocpApplicationPage = await ocpImportPage.fitAndSubmitConfiguration(gitImportRepo, gitImportReference, projectLabel);
60
+ });
61
+
62
+ test('Wait until application creates', async function(): Promise<void> {
63
+ await ocpApplicationPage.waitApplicationIcon();
64
+ });
65
+
66
+ test('Check if application has worked link "Open Source Code"', async function(): Promise<void> {
67
+ await ocpApplicationPage.waitAndOpenEditSourceCodeIcon();
68
+ });
69
+
70
+ loginTests.loginIntoChe();
71
+
72
+ test('Obtain workspace name from workspace loader page', async function(): Promise<void> {
73
+ await workspaceHandlingTests.obtainWorkspaceNameFromStartingPage();
74
+ });
75
+
76
+ test('Registering the running workspace', async function(): Promise<void> {
77
+ registerRunningWorkspace(WorkspaceHandlingTests.getWorkspaceName());
78
+ });
79
+
80
+ test('Check if application source code opens in workspace', async function(): Promise<void> {
81
+ await projectAndFileTests.waitWorkspaceReadinessForCheCodeEditor();
82
+ });
83
+
84
+ test('Check if project and files imported', async function(): Promise<void> {
85
+ const applicationSourceProjectName: string = StringUtil.getProjectNameFromGitUrl(gitImportRepo);
86
+ const projectSection: ViewSection = await new SideBarView().getContent().getSection(applicationSourceProjectName);
87
+ const isFileImported: ViewItem | undefined = await projectSection.findItem(BaseTestConstants.TS_SELENIUM_PROJECT_ROOT_FILE_NAME);
88
+ expect(isFileImported).not.eqls(undefined);
89
+ });
90
+
91
+ loginTests.logoutFromChe();
92
+
93
+ suiteTeardown('Delete project using ocp', async function(): Promise<void> {
94
+ kubernetesCommandLineToolsExecutor.deleteProject(projectName);
95
+ });
98
96
  });