@theia/playwright 1.48.1 → 1.48.2

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 (159) hide show
  1. package/README.md +54 -54
  2. package/lib/index.d.ts +30 -30
  3. package/lib/index.js +48 -48
  4. package/lib/tests/theia-app.test.d.ts +1 -1
  5. package/lib/tests/theia-app.test.js +29 -29
  6. package/lib/tests/theia-application-shell.test.d.ts +1 -1
  7. package/lib/tests/theia-application-shell.test.js +57 -57
  8. package/lib/tests/theia-explorer-view.test.d.ts +1 -1
  9. package/lib/tests/theia-explorer-view.test.js +183 -183
  10. package/lib/tests/theia-getting-started.test.d.ts +1 -1
  11. package/lib/tests/theia-getting-started.test.js +45 -45
  12. package/lib/tests/theia-main-menu.test.d.ts +1 -1
  13. package/lib/tests/theia-main-menu.test.js +111 -111
  14. package/lib/tests/theia-output-view.test.d.ts +1 -1
  15. package/lib/tests/theia-output-view.test.js +78 -78
  16. package/lib/tests/theia-preference-view.test.d.ts +1 -1
  17. package/lib/tests/theia-preference-view.test.js +101 -101
  18. package/lib/tests/theia-problems-view.test.d.ts +1 -1
  19. package/lib/tests/theia-problems-view.test.js +54 -54
  20. package/lib/tests/theia-quick-command.test.d.ts +1 -1
  21. package/lib/tests/theia-quick-command.test.js +69 -69
  22. package/lib/tests/theia-sample-app.test.d.ts +1 -1
  23. package/lib/tests/theia-sample-app.test.js +57 -57
  24. package/lib/tests/theia-status-bar.test.d.ts +1 -1
  25. package/lib/tests/theia-status-bar.test.js +44 -44
  26. package/lib/tests/theia-terminal-view.test.d.ts +1 -1
  27. package/lib/tests/theia-terminal-view.test.js +78 -78
  28. package/lib/tests/theia-text-editor.test.d.ts +1 -1
  29. package/lib/tests/theia-text-editor.test.js +155 -155
  30. package/lib/tests/theia-toolbar.test.d.ts +1 -1
  31. package/lib/tests/theia-toolbar.test.js +61 -61
  32. package/lib/tests/theia-workspace.test.d.ts +1 -1
  33. package/lib/tests/theia-workspace.test.js +72 -72
  34. package/lib/theia-about-dialog.d.ts +4 -4
  35. package/lib/theia-about-dialog.js +26 -26
  36. package/lib/theia-app-loader.d.ts +19 -19
  37. package/lib/theia-app-loader.js +129 -129
  38. package/lib/theia-app.d.ts +50 -50
  39. package/lib/theia-app.js +153 -153
  40. package/lib/theia-context-menu.d.ts +8 -8
  41. package/lib/theia-context-menu.js +37 -37
  42. package/lib/theia-dialog.d.ts +28 -28
  43. package/lib/theia-dialog.js +99 -99
  44. package/lib/theia-editor.d.ts +9 -9
  45. package/lib/theia-editor.js +68 -68
  46. package/lib/theia-explorer-view.d.ts +47 -47
  47. package/lib/theia-explorer-view.js +273 -273
  48. package/lib/theia-main-menu.d.ts +12 -12
  49. package/lib/theia-main-menu.js +53 -53
  50. package/lib/theia-menu-item.d.ts +14 -14
  51. package/lib/theia-menu-item.js +66 -66
  52. package/lib/theia-menu.d.ts +16 -16
  53. package/lib/theia-menu.js +86 -86
  54. package/lib/theia-monaco-editor.d.ts +15 -15
  55. package/lib/theia-monaco-editor.js +75 -75
  56. package/lib/theia-notification-indicator.d.ts +7 -7
  57. package/lib/theia-notification-indicator.js +44 -44
  58. package/lib/theia-notification-overlay.d.ts +22 -22
  59. package/lib/theia-notification-overlay.js +79 -79
  60. package/lib/theia-output-channel.d.ts +24 -24
  61. package/lib/theia-output-channel.js +71 -71
  62. package/lib/theia-output-view.d.ts +9 -9
  63. package/lib/theia-output-view.js +81 -81
  64. package/lib/theia-page-object.d.ts +7 -7
  65. package/lib/theia-page-object.js +27 -27
  66. package/lib/theia-preference-view.d.ts +84 -84
  67. package/lib/theia-preference-view.js +209 -209
  68. package/lib/theia-problem-indicator.d.ts +8 -8
  69. package/lib/theia-problem-indicator.js +38 -38
  70. package/lib/theia-problem-view.d.ts +5 -5
  71. package/lib/theia-problem-view.js +30 -30
  72. package/lib/theia-quick-command-palette.d.ts +12 -12
  73. package/lib/theia-quick-command-palette.js +78 -78
  74. package/lib/theia-rename-dialog.d.ts +5 -5
  75. package/lib/theia-rename-dialog.js +34 -34
  76. package/lib/theia-status-bar.d.ts +13 -13
  77. package/lib/theia-status-bar.js +39 -39
  78. package/lib/theia-status-indicator.d.ts +10 -10
  79. package/lib/theia-status-indicator.js +48 -48
  80. package/lib/theia-terminal.d.ts +13 -13
  81. package/lib/theia-terminal.js +59 -59
  82. package/lib/theia-text-editor.d.ts +26 -26
  83. package/lib/theia-text-editor.js +120 -120
  84. package/lib/theia-toggle-bottom-indicator.d.ts +4 -4
  85. package/lib/theia-toggle-bottom-indicator.js +26 -26
  86. package/lib/theia-toolbar-item.d.ts +10 -10
  87. package/lib/theia-toolbar-item.js +39 -39
  88. package/lib/theia-toolbar.d.ts +19 -19
  89. package/lib/theia-toolbar.js +90 -90
  90. package/lib/theia-tree-node.d.ts +19 -19
  91. package/lib/theia-tree-node.js +72 -72
  92. package/lib/theia-view.d.ts +32 -32
  93. package/lib/theia-view.js +149 -149
  94. package/lib/theia-welcome-view.d.ts +5 -5
  95. package/lib/theia-welcome-view.js +30 -30
  96. package/lib/theia-workspace.d.ts +18 -18
  97. package/lib/theia-workspace.js +69 -69
  98. package/lib/util.d.ts +19 -19
  99. package/lib/util.js +93 -93
  100. package/package.json +2 -2
  101. package/src/index.ts +46 -46
  102. package/src/tests/resources/sample-files1/sample.txt +4 -4
  103. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt +1 -1
  104. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-2.txt +1 -1
  105. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-1.txt +1 -1
  106. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-2.txt +1 -1
  107. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-1/sampleFile2-1-1.txt +1 -1
  108. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-1/sampleFile2-1-2.txt +1 -1
  109. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-2/sampleFile2-2-1.txt +1 -1
  110. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-2/sampleFile2-2-2.txt +1 -1
  111. package/src/tests/resources/sample-files2/another-sample.txt +1 -1
  112. package/src/tests/theia-app.test.ts +33 -33
  113. package/src/tests/theia-application-shell.test.ts +67 -67
  114. package/src/tests/theia-explorer-view.test.ts +211 -211
  115. package/src/tests/theia-getting-started.test.ts +50 -50
  116. package/src/tests/theia-main-menu.test.ts +133 -133
  117. package/src/tests/theia-output-view.test.ts +85 -85
  118. package/src/tests/theia-preference-view.test.ts +122 -122
  119. package/src/tests/theia-problems-view.test.ts +64 -64
  120. package/src/tests/theia-quick-command.test.ts +80 -80
  121. package/src/tests/theia-sample-app.test.ts +66 -66
  122. package/src/tests/theia-status-bar.test.ts +52 -52
  123. package/src/tests/theia-terminal-view.test.ts +90 -90
  124. package/src/tests/theia-text-editor.test.ts +187 -187
  125. package/src/tests/theia-toolbar.test.ts +69 -69
  126. package/src/tests/theia-workspace.test.ts +80 -80
  127. package/src/theia-about-dialog.ts +26 -26
  128. package/src/theia-app-loader.ts +167 -167
  129. package/src/theia-app.ts +188 -188
  130. package/src/theia-context-menu.ts +42 -42
  131. package/src/theia-dialog.ts +114 -114
  132. package/src/theia-editor.ts +73 -73
  133. package/src/theia-explorer-view.ts +311 -311
  134. package/src/theia-main-menu.ts +54 -54
  135. package/src/theia-menu-item.ts +75 -75
  136. package/src/theia-menu.ts +96 -96
  137. package/src/theia-monaco-editor.ts +83 -83
  138. package/src/theia-notification-indicator.ts +44 -44
  139. package/src/theia-notification-overlay.ts +94 -94
  140. package/src/theia-output-channel.ts +88 -88
  141. package/src/theia-output-view.ts +87 -87
  142. package/src/theia-page-object.ts +29 -29
  143. package/src/theia-preference-view.ts +240 -240
  144. package/src/theia-problem-indicator.ts +37 -37
  145. package/src/theia-problem-view.ts +30 -30
  146. package/src/theia-quick-command-palette.ts +81 -81
  147. package/src/theia-rename-dialog.ts +35 -35
  148. package/src/theia-status-bar.ts +44 -44
  149. package/src/theia-status-indicator.ts +50 -50
  150. package/src/theia-terminal.ts +69 -69
  151. package/src/theia-text-editor.ts +141 -141
  152. package/src/theia-toggle-bottom-indicator.ts +21 -21
  153. package/src/theia-toolbar-item.ts +41 -41
  154. package/src/theia-toolbar.ts +99 -99
  155. package/src/theia-tree-node.ts +81 -81
  156. package/src/theia-view.ts +177 -177
  157. package/src/theia-welcome-view.ts +31 -31
  158. package/src/theia-workspace.ts +76 -76
  159. package/src/util.ts +91 -91
@@ -1,184 +1,184 @@
1
- "use strict";
2
- // *****************************************************************************
3
- // Copyright (C) 2021 logi.cals GmbH, EclipseSource and others.
4
- //
5
- // This program and the accompanying materials are made available under the
6
- // terms of the Eclipse Public License v. 2.0 which is available at
7
- // http://www.eclipse.org/legal/epl-2.0.
8
- //
9
- // This Source Code may also be made available under the following Secondary
10
- // Licenses when the conditions for such availability set forth in the Eclipse
11
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
- // with the GNU Classpath Exception which is available at
13
- // https://www.gnu.org/software/classpath/license.html.
14
- //
15
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
- // *****************************************************************************
17
- Object.defineProperty(exports, "__esModule", { value: true });
18
- const test_1 = require("@playwright/test");
19
- const theia_app_loader_1 = require("../theia-app-loader");
20
- const theia_preference_view_1 = require("../theia-preference-view");
21
- const theia_explorer_view_1 = require("../theia-explorer-view");
22
- const theia_workspace_1 = require("../theia-workspace");
23
- test_1.test.describe('Theia Explorer View', () => {
24
- let app;
25
- let explorer;
26
- test_1.test.beforeAll(async ({ playwright, browser }) => {
27
- const ws = new theia_workspace_1.TheiaWorkspace(['src/tests/resources/sample-files1']);
28
- app = await theia_app_loader_1.TheiaAppLoader.load({ playwright, browser }, ws);
29
- if (app.isElectron) {
30
- // set trash preference to off
31
- const preferenceView = await app.openPreferences(theia_preference_view_1.TheiaPreferenceView);
32
- await preferenceView.setBooleanPreferenceById(theia_preference_view_1.PreferenceIds.Files.EnableTrash, false);
33
- await preferenceView.close();
34
- }
35
- explorer = await app.openView(theia_explorer_view_1.TheiaExplorerView);
36
- await explorer.waitForVisibleFileNodes();
37
- });
38
- test_1.test.afterAll(async () => {
39
- await app.page.close();
40
- });
41
- (0, test_1.test)('should be visible and active after being opened', async () => {
42
- (0, test_1.expect)(await explorer.isTabVisible()).toBe(true);
43
- (0, test_1.expect)(await explorer.isDisplayed()).toBe(true);
44
- (0, test_1.expect)(await explorer.isActive()).toBe(true);
45
- });
46
- (0, test_1.test)("should be opened at the left and have the title 'Explorer'", async () => {
47
- (0, test_1.expect)(await explorer.isInSidePanel()).toBe(true);
48
- (0, test_1.expect)(await explorer.side()).toBe('left');
49
- (0, test_1.expect)(await explorer.title()).toBe('Explorer');
50
- });
51
- (0, test_1.test)('should be possible to close and reopen it', async () => {
52
- await explorer.close();
53
- (0, test_1.expect)(await explorer.isTabVisible()).toBe(false);
54
- explorer = await app.openView(theia_explorer_view_1.TheiaExplorerView);
55
- (0, test_1.expect)(await explorer.isTabVisible()).toBe(true);
56
- (0, test_1.expect)(await explorer.isDisplayed()).toBe(true);
57
- (0, test_1.expect)(await explorer.isActive()).toBe(true);
58
- });
59
- (0, test_1.test)('should show one folder named "sampleFolder", one named "sampleFolderCompact" and one file named "sample.txt"', async () => {
60
- await explorer.selectTreeNode('sampleFolder');
61
- (0, test_1.expect)(await explorer.isTreeNodeSelected('sampleFolder')).toBe(true);
62
- const fileStatElements = await explorer.visibleFileStatNodes(theia_explorer_view_1.DOT_FILES_FILTER);
63
- (0, test_1.expect)(fileStatElements.length).toBe(3);
64
- let file;
65
- let folder;
66
- let compactFolder;
67
- if (await fileStatElements[0].isFolder()) {
68
- folder = fileStatElements[0];
69
- compactFolder = fileStatElements[1];
70
- file = fileStatElements[2];
71
- }
72
- else {
73
- folder = fileStatElements[2];
74
- compactFolder = fileStatElements[1];
75
- file = fileStatElements[0];
76
- }
77
- (0, test_1.expect)(await folder.label()).toBe('sampleFolder');
78
- (0, test_1.expect)(await folder.isFile()).toBe(false);
79
- (0, test_1.expect)(await folder.isFolder()).toBe(true);
80
- (0, test_1.expect)(await compactFolder.label()).toBe('sampleFolderCompact');
81
- (0, test_1.expect)(await compactFolder.isFile()).toBe(false);
82
- (0, test_1.expect)(await compactFolder.isFolder()).toBe(true);
83
- (0, test_1.expect)(await file.label()).toBe('sample.txt');
84
- (0, test_1.expect)(await file.isFolder()).toBe(false);
85
- (0, test_1.expect)(await file.isFile()).toBe(true);
86
- });
87
- (0, test_1.test)('should provide file stat node by single path fragment "sample.txt"', async () => {
88
- const file = await explorer.getFileStatNodeByLabel('sample.txt');
89
- (0, test_1.expect)(await file.label()).toBe('sample.txt');
90
- (0, test_1.expect)(await file.isFolder()).toBe(false);
91
- (0, test_1.expect)(await file.isFile()).toBe(true);
92
- });
93
- (0, test_1.test)('should provide file stat nodes that can define whether they are collapsed or not and that can be expanded and collapsed', async () => {
94
- const file = await explorer.getFileStatNodeByLabel('sample.txt');
95
- (0, test_1.expect)(await file.isCollapsed()).toBe(false);
96
- const folder = await explorer.getFileStatNodeByLabel('sampleFolder');
97
- (0, test_1.expect)(await folder.isCollapsed()).toBe(true);
98
- await folder.expand();
99
- (0, test_1.expect)(await folder.isCollapsed()).toBe(false);
100
- await folder.collapse();
101
- (0, test_1.expect)(await folder.isCollapsed()).toBe(true);
102
- });
103
- (0, test_1.test)('should provide file stat node by path "sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt"', async () => {
104
- const file = await explorer.fileStatNode('sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt');
105
- if (!file) {
106
- throw Error('File stat node could not be retrieved by path');
107
- }
108
- (0, test_1.expect)(await file.label()).toBe('sampleFile1-1-1.txt');
109
- });
110
- (0, test_1.test)('should be able to check if compact folder "sampleFolderCompact/nestedFolder1/nestedFolder2" exists', async () => {
111
- const fileStatElements = await explorer.visibleFileStatNodes();
112
- // default setting `explorer.compactFolders=true` renders folders in a compact form - single child folders will be compressed in a combined tree element
113
- (0, test_1.expect)(await explorer.existsDirectoryNode('sampleFolderCompact/nestedFolder1/nestedFolder2', true /* compact */)).toBe(true);
114
- // the `existsDirectoryNode` function will expand the folder, hence we wait for the file nodes to increase as we expect a txt child file node
115
- await explorer.waitForFileNodesToIncrease(fileStatElements.length);
116
- });
117
- (0, test_1.test)('should provide file stat node by path of compact folder "sampleFolderCompact/nestedFolder1/nestedFolder2/sampleFile1-1.txt"', async () => {
118
- const file = await explorer.fileStatNode('sampleFolderCompact/nestedFolder1/nestedFolder2/sampleFile1-1.txt', true /* compact */);
119
- if (!file) {
120
- throw Error('File stat node could not be retrieved by path');
121
- }
122
- (0, test_1.expect)(await file.label()).toBe('sampleFile1-1.txt');
123
- });
124
- (0, test_1.test)('should open context menu on "sample.txt"', async () => {
125
- const file = await explorer.getFileStatNodeByLabel('sample.txt');
126
- const menu = await file.openContextMenu();
127
- (0, test_1.expect)(await menu.isOpen()).toBe(true);
128
- const menuItems = await menu.visibleMenuItems();
129
- (0, test_1.expect)(menuItems).toContain('Open');
130
- (0, test_1.expect)(menuItems).toContain('Delete');
131
- if (!app.isElectron) {
132
- (0, test_1.expect)(menuItems).toContain('Download');
133
- }
134
- await menu.close();
135
- (0, test_1.expect)(await menu.isOpen()).toBe(false);
136
- });
137
- (0, test_1.test)('should rename "sample.txt"', async () => {
138
- await explorer.renameNode('sample.txt', 'sample-new.txt');
139
- (0, test_1.expect)(await explorer.existsFileNode('sample-new.txt')).toBe(true);
140
- await explorer.renameNode('sample-new.txt', 'sample.txt');
141
- (0, test_1.expect)(await explorer.existsFileNode('sample.txt')).toBe(true);
142
- });
143
- (0, test_1.test)('should open context menu on nested folder segment "nestedFolder1"', async () => {
144
- (0, test_1.expect)(await explorer.existsDirectoryNode('sampleFolderCompact/nestedFolder1/nestedFolder2', true /* compact */)).toBe(true);
145
- const folder = await explorer.getFileStatNodeByLabel('sampleFolderCompact/nestedFolder1/nestedFolder2', true /* compact */);
146
- const menu = await folder.openContextMenuOnSegment('nestedFolder1');
147
- (0, test_1.expect)(await menu.isOpen()).toBe(true);
148
- const menuItems = await menu.visibleMenuItems();
149
- (0, test_1.expect)(menuItems).toContain('New File...');
150
- (0, test_1.expect)(menuItems).toContain('New Folder...');
151
- (0, test_1.expect)(menuItems).toContain('Open in Integrated Terminal');
152
- (0, test_1.expect)(menuItems).toContain('Find in Folder...');
153
- await menu.close();
154
- (0, test_1.expect)(await menu.isOpen()).toBe(false);
155
- });
156
- (0, test_1.test)('should rename compact folder "sampleFolderCompact" to "sampleDirectoryCompact', async () => {
157
- (0, test_1.expect)(await explorer.existsDirectoryNode('sampleFolderCompact/nestedFolder1/nestedFolder2', true /* compact */)).toBe(true);
158
- await explorer.renameNode('sampleFolderCompact/nestedFolder1/nestedFolder2', 'sampleDirectoryCompact', true /* confirm */, 'sampleFolderCompact' /* nodeSegmentLabel */);
159
- (0, test_1.expect)(await explorer.existsDirectoryNode('sampleDirectoryCompact/nestedFolder1/nestedFolder2', true /* compact */)).toBe(true);
160
- });
161
- (0, test_1.test)('should delete nested folder "sampleDirectoryCompact/nestedFolder1/nestedFolder2"', async () => {
162
- const fileStatElements = await explorer.visibleFileStatNodes();
163
- (0, test_1.expect)(await explorer.existsDirectoryNode('sampleDirectoryCompact/nestedFolder1/nestedFolder2', true /* compact */)).toBe(true);
164
- await explorer.deleteNode('sampleDirectoryCompact/nestedFolder1/nestedFolder2', true /* confirm */, 'nestedFolder2' /* nodeSegmentLabel */);
165
- await explorer.waitForFileNodesToDecrease(fileStatElements.length);
166
- const updatedFileStatElements = await explorer.visibleFileStatNodes();
167
- (0, test_1.expect)(updatedFileStatElements.length).toBe(fileStatElements.length - 1);
168
- });
169
- (0, test_1.test)('should delete compact folder "sampleDirectoryCompact/nestedFolder1"', async () => {
170
- const fileStatElements = await explorer.visibleFileStatNodes();
171
- (0, test_1.expect)(await explorer.existsDirectoryNode('sampleDirectoryCompact/nestedFolder1', true /* compact */)).toBe(true);
172
- await explorer.deleteNode('sampleDirectoryCompact/nestedFolder1', true /* confirm */, 'sampleDirectoryCompact' /* nodeSegmentLabel */);
173
- await explorer.waitForFileNodesToDecrease(fileStatElements.length);
174
- const updatedFileStatElements = await explorer.visibleFileStatNodes();
175
- (0, test_1.expect)(updatedFileStatElements.length).toBe(fileStatElements.length - 1);
176
- });
177
- (0, test_1.test)('open "sample.txt" via the context menu', async () => {
178
- (0, test_1.expect)(await explorer.existsFileNode('sample.txt')).toBe(true);
179
- await explorer.clickContextMenuItem('sample.txt', ['Open']);
180
- const span = await app.page.waitForSelector('span:has-text("content line 2")');
181
- (0, test_1.expect)(await span.isVisible()).toBe(true);
182
- });
183
- });
1
+ "use strict";
2
+ // *****************************************************************************
3
+ // Copyright (C) 2021 logi.cals GmbH, EclipseSource and others.
4
+ //
5
+ // This program and the accompanying materials are made available under the
6
+ // terms of the Eclipse Public License v. 2.0 which is available at
7
+ // http://www.eclipse.org/legal/epl-2.0.
8
+ //
9
+ // This Source Code may also be made available under the following Secondary
10
+ // Licenses when the conditions for such availability set forth in the Eclipse
11
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
+ // with the GNU Classpath Exception which is available at
13
+ // https://www.gnu.org/software/classpath/license.html.
14
+ //
15
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
+ // *****************************************************************************
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const test_1 = require("@playwright/test");
19
+ const theia_app_loader_1 = require("../theia-app-loader");
20
+ const theia_preference_view_1 = require("../theia-preference-view");
21
+ const theia_explorer_view_1 = require("../theia-explorer-view");
22
+ const theia_workspace_1 = require("../theia-workspace");
23
+ test_1.test.describe('Theia Explorer View', () => {
24
+ let app;
25
+ let explorer;
26
+ test_1.test.beforeAll(async ({ playwright, browser }) => {
27
+ const ws = new theia_workspace_1.TheiaWorkspace(['src/tests/resources/sample-files1']);
28
+ app = await theia_app_loader_1.TheiaAppLoader.load({ playwright, browser }, ws);
29
+ if (app.isElectron) {
30
+ // set trash preference to off
31
+ const preferenceView = await app.openPreferences(theia_preference_view_1.TheiaPreferenceView);
32
+ await preferenceView.setBooleanPreferenceById(theia_preference_view_1.PreferenceIds.Files.EnableTrash, false);
33
+ await preferenceView.close();
34
+ }
35
+ explorer = await app.openView(theia_explorer_view_1.TheiaExplorerView);
36
+ await explorer.waitForVisibleFileNodes();
37
+ });
38
+ test_1.test.afterAll(async () => {
39
+ await app.page.close();
40
+ });
41
+ (0, test_1.test)('should be visible and active after being opened', async () => {
42
+ (0, test_1.expect)(await explorer.isTabVisible()).toBe(true);
43
+ (0, test_1.expect)(await explorer.isDisplayed()).toBe(true);
44
+ (0, test_1.expect)(await explorer.isActive()).toBe(true);
45
+ });
46
+ (0, test_1.test)("should be opened at the left and have the title 'Explorer'", async () => {
47
+ (0, test_1.expect)(await explorer.isInSidePanel()).toBe(true);
48
+ (0, test_1.expect)(await explorer.side()).toBe('left');
49
+ (0, test_1.expect)(await explorer.title()).toBe('Explorer');
50
+ });
51
+ (0, test_1.test)('should be possible to close and reopen it', async () => {
52
+ await explorer.close();
53
+ (0, test_1.expect)(await explorer.isTabVisible()).toBe(false);
54
+ explorer = await app.openView(theia_explorer_view_1.TheiaExplorerView);
55
+ (0, test_1.expect)(await explorer.isTabVisible()).toBe(true);
56
+ (0, test_1.expect)(await explorer.isDisplayed()).toBe(true);
57
+ (0, test_1.expect)(await explorer.isActive()).toBe(true);
58
+ });
59
+ (0, test_1.test)('should show one folder named "sampleFolder", one named "sampleFolderCompact" and one file named "sample.txt"', async () => {
60
+ await explorer.selectTreeNode('sampleFolder');
61
+ (0, test_1.expect)(await explorer.isTreeNodeSelected('sampleFolder')).toBe(true);
62
+ const fileStatElements = await explorer.visibleFileStatNodes(theia_explorer_view_1.DOT_FILES_FILTER);
63
+ (0, test_1.expect)(fileStatElements.length).toBe(3);
64
+ let file;
65
+ let folder;
66
+ let compactFolder;
67
+ if (await fileStatElements[0].isFolder()) {
68
+ folder = fileStatElements[0];
69
+ compactFolder = fileStatElements[1];
70
+ file = fileStatElements[2];
71
+ }
72
+ else {
73
+ folder = fileStatElements[2];
74
+ compactFolder = fileStatElements[1];
75
+ file = fileStatElements[0];
76
+ }
77
+ (0, test_1.expect)(await folder.label()).toBe('sampleFolder');
78
+ (0, test_1.expect)(await folder.isFile()).toBe(false);
79
+ (0, test_1.expect)(await folder.isFolder()).toBe(true);
80
+ (0, test_1.expect)(await compactFolder.label()).toBe('sampleFolderCompact');
81
+ (0, test_1.expect)(await compactFolder.isFile()).toBe(false);
82
+ (0, test_1.expect)(await compactFolder.isFolder()).toBe(true);
83
+ (0, test_1.expect)(await file.label()).toBe('sample.txt');
84
+ (0, test_1.expect)(await file.isFolder()).toBe(false);
85
+ (0, test_1.expect)(await file.isFile()).toBe(true);
86
+ });
87
+ (0, test_1.test)('should provide file stat node by single path fragment "sample.txt"', async () => {
88
+ const file = await explorer.getFileStatNodeByLabel('sample.txt');
89
+ (0, test_1.expect)(await file.label()).toBe('sample.txt');
90
+ (0, test_1.expect)(await file.isFolder()).toBe(false);
91
+ (0, test_1.expect)(await file.isFile()).toBe(true);
92
+ });
93
+ (0, test_1.test)('should provide file stat nodes that can define whether they are collapsed or not and that can be expanded and collapsed', async () => {
94
+ const file = await explorer.getFileStatNodeByLabel('sample.txt');
95
+ (0, test_1.expect)(await file.isCollapsed()).toBe(false);
96
+ const folder = await explorer.getFileStatNodeByLabel('sampleFolder');
97
+ (0, test_1.expect)(await folder.isCollapsed()).toBe(true);
98
+ await folder.expand();
99
+ (0, test_1.expect)(await folder.isCollapsed()).toBe(false);
100
+ await folder.collapse();
101
+ (0, test_1.expect)(await folder.isCollapsed()).toBe(true);
102
+ });
103
+ (0, test_1.test)('should provide file stat node by path "sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt"', async () => {
104
+ const file = await explorer.fileStatNode('sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt');
105
+ if (!file) {
106
+ throw Error('File stat node could not be retrieved by path');
107
+ }
108
+ (0, test_1.expect)(await file.label()).toBe('sampleFile1-1-1.txt');
109
+ });
110
+ (0, test_1.test)('should be able to check if compact folder "sampleFolderCompact/nestedFolder1/nestedFolder2" exists', async () => {
111
+ const fileStatElements = await explorer.visibleFileStatNodes();
112
+ // default setting `explorer.compactFolders=true` renders folders in a compact form - single child folders will be compressed in a combined tree element
113
+ (0, test_1.expect)(await explorer.existsDirectoryNode('sampleFolderCompact/nestedFolder1/nestedFolder2', true /* compact */)).toBe(true);
114
+ // the `existsDirectoryNode` function will expand the folder, hence we wait for the file nodes to increase as we expect a txt child file node
115
+ await explorer.waitForFileNodesToIncrease(fileStatElements.length);
116
+ });
117
+ (0, test_1.test)('should provide file stat node by path of compact folder "sampleFolderCompact/nestedFolder1/nestedFolder2/sampleFile1-1.txt"', async () => {
118
+ const file = await explorer.fileStatNode('sampleFolderCompact/nestedFolder1/nestedFolder2/sampleFile1-1.txt', true /* compact */);
119
+ if (!file) {
120
+ throw Error('File stat node could not be retrieved by path');
121
+ }
122
+ (0, test_1.expect)(await file.label()).toBe('sampleFile1-1.txt');
123
+ });
124
+ (0, test_1.test)('should open context menu on "sample.txt"', async () => {
125
+ const file = await explorer.getFileStatNodeByLabel('sample.txt');
126
+ const menu = await file.openContextMenu();
127
+ (0, test_1.expect)(await menu.isOpen()).toBe(true);
128
+ const menuItems = await menu.visibleMenuItems();
129
+ (0, test_1.expect)(menuItems).toContain('Open');
130
+ (0, test_1.expect)(menuItems).toContain('Delete');
131
+ if (!app.isElectron) {
132
+ (0, test_1.expect)(menuItems).toContain('Download');
133
+ }
134
+ await menu.close();
135
+ (0, test_1.expect)(await menu.isOpen()).toBe(false);
136
+ });
137
+ (0, test_1.test)('should rename "sample.txt"', async () => {
138
+ await explorer.renameNode('sample.txt', 'sample-new.txt');
139
+ (0, test_1.expect)(await explorer.existsFileNode('sample-new.txt')).toBe(true);
140
+ await explorer.renameNode('sample-new.txt', 'sample.txt');
141
+ (0, test_1.expect)(await explorer.existsFileNode('sample.txt')).toBe(true);
142
+ });
143
+ (0, test_1.test)('should open context menu on nested folder segment "nestedFolder1"', async () => {
144
+ (0, test_1.expect)(await explorer.existsDirectoryNode('sampleFolderCompact/nestedFolder1/nestedFolder2', true /* compact */)).toBe(true);
145
+ const folder = await explorer.getFileStatNodeByLabel('sampleFolderCompact/nestedFolder1/nestedFolder2', true /* compact */);
146
+ const menu = await folder.openContextMenuOnSegment('nestedFolder1');
147
+ (0, test_1.expect)(await menu.isOpen()).toBe(true);
148
+ const menuItems = await menu.visibleMenuItems();
149
+ (0, test_1.expect)(menuItems).toContain('New File...');
150
+ (0, test_1.expect)(menuItems).toContain('New Folder...');
151
+ (0, test_1.expect)(menuItems).toContain('Open in Integrated Terminal');
152
+ (0, test_1.expect)(menuItems).toContain('Find in Folder...');
153
+ await menu.close();
154
+ (0, test_1.expect)(await menu.isOpen()).toBe(false);
155
+ });
156
+ (0, test_1.test)('should rename compact folder "sampleFolderCompact" to "sampleDirectoryCompact', async () => {
157
+ (0, test_1.expect)(await explorer.existsDirectoryNode('sampleFolderCompact/nestedFolder1/nestedFolder2', true /* compact */)).toBe(true);
158
+ await explorer.renameNode('sampleFolderCompact/nestedFolder1/nestedFolder2', 'sampleDirectoryCompact', true /* confirm */, 'sampleFolderCompact' /* nodeSegmentLabel */);
159
+ (0, test_1.expect)(await explorer.existsDirectoryNode('sampleDirectoryCompact/nestedFolder1/nestedFolder2', true /* compact */)).toBe(true);
160
+ });
161
+ (0, test_1.test)('should delete nested folder "sampleDirectoryCompact/nestedFolder1/nestedFolder2"', async () => {
162
+ const fileStatElements = await explorer.visibleFileStatNodes();
163
+ (0, test_1.expect)(await explorer.existsDirectoryNode('sampleDirectoryCompact/nestedFolder1/nestedFolder2', true /* compact */)).toBe(true);
164
+ await explorer.deleteNode('sampleDirectoryCompact/nestedFolder1/nestedFolder2', true /* confirm */, 'nestedFolder2' /* nodeSegmentLabel */);
165
+ await explorer.waitForFileNodesToDecrease(fileStatElements.length);
166
+ const updatedFileStatElements = await explorer.visibleFileStatNodes();
167
+ (0, test_1.expect)(updatedFileStatElements.length).toBe(fileStatElements.length - 1);
168
+ });
169
+ (0, test_1.test)('should delete compact folder "sampleDirectoryCompact/nestedFolder1"', async () => {
170
+ const fileStatElements = await explorer.visibleFileStatNodes();
171
+ (0, test_1.expect)(await explorer.existsDirectoryNode('sampleDirectoryCompact/nestedFolder1', true /* compact */)).toBe(true);
172
+ await explorer.deleteNode('sampleDirectoryCompact/nestedFolder1', true /* confirm */, 'sampleDirectoryCompact' /* nodeSegmentLabel */);
173
+ await explorer.waitForFileNodesToDecrease(fileStatElements.length);
174
+ const updatedFileStatElements = await explorer.visibleFileStatNodes();
175
+ (0, test_1.expect)(updatedFileStatElements.length).toBe(fileStatElements.length - 1);
176
+ });
177
+ (0, test_1.test)('open "sample.txt" via the context menu', async () => {
178
+ (0, test_1.expect)(await explorer.existsFileNode('sample.txt')).toBe(true);
179
+ await explorer.clickContextMenuItem('sample.txt', ['Open']);
180
+ const span = await app.page.waitForSelector('span:has-text("content line 2")');
181
+ (0, test_1.expect)(await span.isVisible()).toBe(true);
182
+ });
183
+ });
184
184
  //# sourceMappingURL=theia-explorer-view.test.js.map
@@ -1,2 +1,2 @@
1
- export {};
1
+ export {};
2
2
  //# sourceMappingURL=theia-getting-started.test.d.ts.map
@@ -1,46 +1,46 @@
1
- "use strict";
2
- // *****************************************************************************
3
- // Copyright (C) 2024 TypeFox and others.
4
- //
5
- // This program and the accompanying materials are made available under the
6
- // terms of the Eclipse Public License v. 2.0 which is available at
7
- // http://www.eclipse.org/legal/epl-2.0.
8
- //
9
- // This Source Code may also be made available under the following Secondary
10
- // Licenses when the conditions for such availability set forth in the Eclipse
11
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
- // with the GNU Classpath Exception which is available at
13
- // https://www.gnu.org/software/classpath/license.html.
14
- //
15
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
- // *****************************************************************************
17
- Object.defineProperty(exports, "__esModule", { value: true });
18
- const test_1 = require("@playwright/test");
19
- const theia_app_loader_1 = require("../theia-app-loader");
20
- const theia_explorer_view_1 = require("../theia-explorer-view");
21
- /**
22
- * Test the Theia welcome page from the getting-started package.
23
- */
24
- test_1.test.describe('Theia Welcome Page', () => {
25
- let app;
26
- test_1.test.beforeAll(async ({ playwright, browser }) => {
27
- app = await theia_app_loader_1.TheiaAppLoader.load({ playwright, browser });
28
- await app.isMainContentPanelVisible();
29
- });
30
- test_1.test.afterAll(async () => {
31
- await app.page.close();
32
- });
33
- (0, test_1.test)('New File... entry should create a new file.', async () => {
34
- await app.page.getByRole('button', { name: 'New File...' }).click();
35
- const quickPicker = app.page.getByPlaceholder('Select File Type or Enter');
36
- await quickPicker.fill('testfile.txt');
37
- await quickPicker.press('Enter');
38
- await app.page.getByRole('button', { name: 'Create File' }).click();
39
- // check file in workspace exists
40
- const explorer = await app.openView(theia_explorer_view_1.TheiaExplorerView);
41
- await explorer.refresh();
42
- await explorer.waitForVisibleFileNodes();
43
- (0, test_1.expect)(await explorer.existsFileNode('testfile.txt')).toBe(true);
44
- });
45
- });
1
+ "use strict";
2
+ // *****************************************************************************
3
+ // Copyright (C) 2024 TypeFox and others.
4
+ //
5
+ // This program and the accompanying materials are made available under the
6
+ // terms of the Eclipse Public License v. 2.0 which is available at
7
+ // http://www.eclipse.org/legal/epl-2.0.
8
+ //
9
+ // This Source Code may also be made available under the following Secondary
10
+ // Licenses when the conditions for such availability set forth in the Eclipse
11
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
+ // with the GNU Classpath Exception which is available at
13
+ // https://www.gnu.org/software/classpath/license.html.
14
+ //
15
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
+ // *****************************************************************************
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const test_1 = require("@playwright/test");
19
+ const theia_app_loader_1 = require("../theia-app-loader");
20
+ const theia_explorer_view_1 = require("../theia-explorer-view");
21
+ /**
22
+ * Test the Theia welcome page from the getting-started package.
23
+ */
24
+ test_1.test.describe('Theia Welcome Page', () => {
25
+ let app;
26
+ test_1.test.beforeAll(async ({ playwright, browser }) => {
27
+ app = await theia_app_loader_1.TheiaAppLoader.load({ playwright, browser });
28
+ await app.isMainContentPanelVisible();
29
+ });
30
+ test_1.test.afterAll(async () => {
31
+ await app.page.close();
32
+ });
33
+ (0, test_1.test)('New File... entry should create a new file.', async () => {
34
+ await app.page.getByRole('button', { name: 'New File...' }).click();
35
+ const quickPicker = app.page.getByPlaceholder('Select File Type or Enter');
36
+ await quickPicker.fill('testfile.txt');
37
+ await quickPicker.press('Enter');
38
+ await app.page.getByRole('button', { name: 'Create File' }).click();
39
+ // check file in workspace exists
40
+ const explorer = await app.openView(theia_explorer_view_1.TheiaExplorerView);
41
+ await explorer.refresh();
42
+ await explorer.waitForVisibleFileNodes();
43
+ (0, test_1.expect)(await explorer.existsFileNode('testfile.txt')).toBe(true);
44
+ });
45
+ });
46
46
  //# sourceMappingURL=theia-getting-started.test.js.map
@@ -1,2 +1,2 @@
1
- export {};
1
+ export {};
2
2
  //# sourceMappingURL=theia-main-menu.test.d.ts.map