@theia/playwright 1.48.0 → 1.48.1
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.
- package/README.md +54 -54
- package/lib/index.d.ts +30 -30
- package/lib/index.js +48 -48
- package/lib/tests/theia-app.test.d.ts +1 -1
- package/lib/tests/theia-app.test.js +29 -29
- package/lib/tests/theia-application-shell.test.d.ts +1 -1
- package/lib/tests/theia-application-shell.test.js +57 -57
- package/lib/tests/theia-explorer-view.test.d.ts +1 -1
- package/lib/tests/theia-explorer-view.test.js +183 -183
- package/lib/tests/theia-getting-started.test.d.ts +1 -1
- package/lib/tests/theia-getting-started.test.js +45 -45
- package/lib/tests/theia-main-menu.test.d.ts +1 -1
- package/lib/tests/theia-main-menu.test.js +111 -111
- package/lib/tests/theia-output-view.test.d.ts +1 -1
- package/lib/tests/theia-output-view.test.js +78 -78
- package/lib/tests/theia-preference-view.test.d.ts +1 -1
- package/lib/tests/theia-preference-view.test.js +101 -101
- package/lib/tests/theia-problems-view.test.d.ts +1 -1
- package/lib/tests/theia-problems-view.test.js +54 -54
- package/lib/tests/theia-quick-command.test.d.ts +1 -1
- package/lib/tests/theia-quick-command.test.js +69 -69
- package/lib/tests/theia-sample-app.test.d.ts +1 -1
- package/lib/tests/theia-sample-app.test.js +57 -57
- package/lib/tests/theia-status-bar.test.d.ts +1 -1
- package/lib/tests/theia-status-bar.test.js +44 -44
- package/lib/tests/theia-terminal-view.test.d.ts +1 -1
- package/lib/tests/theia-terminal-view.test.js +78 -78
- package/lib/tests/theia-text-editor.test.d.ts +1 -1
- package/lib/tests/theia-text-editor.test.js +155 -155
- package/lib/tests/theia-toolbar.test.d.ts +1 -1
- package/lib/tests/theia-toolbar.test.js +61 -61
- package/lib/tests/theia-workspace.test.d.ts +1 -1
- package/lib/tests/theia-workspace.test.js +72 -72
- package/lib/theia-about-dialog.d.ts +4 -4
- package/lib/theia-about-dialog.js +26 -26
- package/lib/theia-app-loader.d.ts +19 -19
- package/lib/theia-app-loader.js +129 -129
- package/lib/theia-app.d.ts +50 -50
- package/lib/theia-app.js +153 -153
- package/lib/theia-context-menu.d.ts +8 -8
- package/lib/theia-context-menu.js +37 -37
- package/lib/theia-dialog.d.ts +28 -28
- package/lib/theia-dialog.js +99 -99
- package/lib/theia-editor.d.ts +9 -9
- package/lib/theia-editor.js +68 -68
- package/lib/theia-explorer-view.d.ts +47 -47
- package/lib/theia-explorer-view.js +273 -273
- package/lib/theia-main-menu.d.ts +12 -12
- package/lib/theia-main-menu.js +53 -53
- package/lib/theia-menu-item.d.ts +14 -14
- package/lib/theia-menu-item.js +66 -66
- package/lib/theia-menu.d.ts +16 -16
- package/lib/theia-menu.js +86 -86
- package/lib/theia-monaco-editor.d.ts +15 -15
- package/lib/theia-monaco-editor.js +75 -75
- package/lib/theia-notification-indicator.d.ts +7 -7
- package/lib/theia-notification-indicator.js +44 -44
- package/lib/theia-notification-overlay.d.ts +22 -22
- package/lib/theia-notification-overlay.js +79 -79
- package/lib/theia-output-channel.d.ts +24 -24
- package/lib/theia-output-channel.js +71 -71
- package/lib/theia-output-view.d.ts +9 -9
- package/lib/theia-output-view.js +81 -81
- package/lib/theia-page-object.d.ts +7 -7
- package/lib/theia-page-object.js +27 -27
- package/lib/theia-preference-view.d.ts +84 -84
- package/lib/theia-preference-view.js +209 -209
- package/lib/theia-problem-indicator.d.ts +8 -8
- package/lib/theia-problem-indicator.js +38 -38
- package/lib/theia-problem-view.d.ts +5 -5
- package/lib/theia-problem-view.js +30 -30
- package/lib/theia-quick-command-palette.d.ts +12 -12
- package/lib/theia-quick-command-palette.js +78 -78
- package/lib/theia-rename-dialog.d.ts +5 -5
- package/lib/theia-rename-dialog.js +34 -34
- package/lib/theia-status-bar.d.ts +13 -13
- package/lib/theia-status-bar.js +39 -39
- package/lib/theia-status-indicator.d.ts +10 -10
- package/lib/theia-status-indicator.js +48 -48
- package/lib/theia-terminal.d.ts +13 -13
- package/lib/theia-terminal.js +59 -59
- package/lib/theia-text-editor.d.ts +26 -26
- package/lib/theia-text-editor.js +120 -120
- package/lib/theia-toggle-bottom-indicator.d.ts +4 -4
- package/lib/theia-toggle-bottom-indicator.js +26 -26
- package/lib/theia-toolbar-item.d.ts +10 -10
- package/lib/theia-toolbar-item.js +39 -39
- package/lib/theia-toolbar.d.ts +19 -19
- package/lib/theia-toolbar.js +90 -90
- package/lib/theia-tree-node.d.ts +19 -19
- package/lib/theia-tree-node.js +72 -72
- package/lib/theia-view.d.ts +32 -32
- package/lib/theia-view.js +149 -149
- package/lib/theia-welcome-view.d.ts +5 -5
- package/lib/theia-welcome-view.js +30 -30
- package/lib/theia-workspace.d.ts +18 -18
- package/lib/theia-workspace.js +69 -69
- package/lib/util.d.ts +19 -19
- package/lib/util.js +93 -93
- package/package.json +2 -2
- package/src/index.ts +46 -46
- package/src/tests/resources/sample-files1/sample.txt +4 -4
- package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt +1 -1
- package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-2.txt +1 -1
- package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-1.txt +1 -1
- package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-2.txt +1 -1
- package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-1/sampleFile2-1-1.txt +1 -1
- package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-1/sampleFile2-1-2.txt +1 -1
- package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-2/sampleFile2-2-1.txt +1 -1
- package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-2/sampleFile2-2-2.txt +1 -1
- package/src/tests/resources/sample-files2/another-sample.txt +1 -1
- package/src/tests/theia-app.test.ts +33 -33
- package/src/tests/theia-application-shell.test.ts +67 -67
- package/src/tests/theia-explorer-view.test.ts +211 -211
- package/src/tests/theia-getting-started.test.ts +50 -50
- package/src/tests/theia-main-menu.test.ts +133 -133
- package/src/tests/theia-output-view.test.ts +85 -85
- package/src/tests/theia-preference-view.test.ts +122 -122
- package/src/tests/theia-problems-view.test.ts +64 -64
- package/src/tests/theia-quick-command.test.ts +80 -80
- package/src/tests/theia-sample-app.test.ts +66 -66
- package/src/tests/theia-status-bar.test.ts +52 -52
- package/src/tests/theia-terminal-view.test.ts +90 -90
- package/src/tests/theia-text-editor.test.ts +187 -187
- package/src/tests/theia-toolbar.test.ts +69 -69
- package/src/tests/theia-workspace.test.ts +80 -80
- package/src/theia-about-dialog.ts +26 -26
- package/src/theia-app-loader.ts +167 -167
- package/src/theia-app.ts +188 -188
- package/src/theia-context-menu.ts +42 -42
- package/src/theia-dialog.ts +114 -114
- package/src/theia-editor.ts +73 -73
- package/src/theia-explorer-view.ts +311 -311
- package/src/theia-main-menu.ts +54 -54
- package/src/theia-menu-item.ts +75 -75
- package/src/theia-menu.ts +96 -96
- package/src/theia-monaco-editor.ts +83 -83
- package/src/theia-notification-indicator.ts +44 -44
- package/src/theia-notification-overlay.ts +94 -94
- package/src/theia-output-channel.ts +88 -88
- package/src/theia-output-view.ts +87 -87
- package/src/theia-page-object.ts +29 -29
- package/src/theia-preference-view.ts +240 -240
- package/src/theia-problem-indicator.ts +37 -37
- package/src/theia-problem-view.ts +30 -30
- package/src/theia-quick-command-palette.ts +81 -81
- package/src/theia-rename-dialog.ts +35 -35
- package/src/theia-status-bar.ts +44 -44
- package/src/theia-status-indicator.ts +50 -50
- package/src/theia-terminal.ts +69 -69
- package/src/theia-text-editor.ts +141 -141
- package/src/theia-toggle-bottom-indicator.ts +21 -21
- package/src/theia-toolbar-item.ts +41 -41
- package/src/theia-toolbar.ts +99 -99
- package/src/theia-tree-node.ts +81 -81
- package/src/theia-view.ts +177 -177
- package/src/theia-welcome-view.ts +31 -31
- package/src/theia-workspace.ts +76 -76
- 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
|