@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.
- 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,79 +1,79 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// *****************************************************************************
|
|
3
|
-
// Copyright (C) 2023 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_workspace_1 = require("../theia-workspace");
|
|
21
|
-
const theia_terminal_1 = require("../theia-terminal");
|
|
22
|
-
let app;
|
|
23
|
-
test_1.test.describe('Theia Terminal View', () => {
|
|
24
|
-
test_1.test.beforeAll(async ({ playwright, browser }) => {
|
|
25
|
-
const ws = new theia_workspace_1.TheiaWorkspace(['src/tests/resources/sample-files1']);
|
|
26
|
-
app = await theia_app_loader_1.TheiaAppLoader.load({ playwright, browser }, ws);
|
|
27
|
-
});
|
|
28
|
-
test_1.test.afterAll(async () => {
|
|
29
|
-
await app.page.close();
|
|
30
|
-
});
|
|
31
|
-
(0, test_1.test)('should be possible to open a new terminal', async () => {
|
|
32
|
-
const terminal = await app.openTerminal(theia_terminal_1.TheiaTerminal);
|
|
33
|
-
(0, test_1.expect)(await terminal.isTabVisible()).toBe(true);
|
|
34
|
-
(0, test_1.expect)(await terminal.isDisplayed()).toBe(true);
|
|
35
|
-
(0, test_1.expect)(await terminal.isActive()).toBe(true);
|
|
36
|
-
});
|
|
37
|
-
(0, test_1.test)('should be possible to open two terminals, switch among them, and close them', async () => {
|
|
38
|
-
const terminal1 = await app.openTerminal(theia_terminal_1.TheiaTerminal);
|
|
39
|
-
const terminal2 = await app.openTerminal(theia_terminal_1.TheiaTerminal);
|
|
40
|
-
const allTerminals = [terminal1, terminal2];
|
|
41
|
-
// all terminal tabs should be visible
|
|
42
|
-
for (const terminal of allTerminals) {
|
|
43
|
-
(0, test_1.expect)(await terminal.isTabVisible()).toBe(true);
|
|
44
|
-
}
|
|
45
|
-
// activate one terminal after the other and check that only this terminal is active
|
|
46
|
-
for (const terminal of allTerminals) {
|
|
47
|
-
await terminal.activate();
|
|
48
|
-
(0, test_1.expect)(await terminal1.isActive()).toBe(terminal1 === terminal);
|
|
49
|
-
(0, test_1.expect)(await terminal2.isActive()).toBe(terminal2 === terminal);
|
|
50
|
-
}
|
|
51
|
-
// close all terminals
|
|
52
|
-
for (const terminal of allTerminals) {
|
|
53
|
-
await terminal.activate();
|
|
54
|
-
await terminal.close();
|
|
55
|
-
}
|
|
56
|
-
// check that all terminals are closed
|
|
57
|
-
for (const terminal of allTerminals) {
|
|
58
|
-
(0, test_1.expect)(await terminal.isTabVisible()).toBe(false);
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
(0, test_1.test)('should allow to write and read terminal contents', async () => {
|
|
62
|
-
const terminal = await app.openTerminal(theia_terminal_1.TheiaTerminal);
|
|
63
|
-
await terminal.write('hello');
|
|
64
|
-
const contents = await terminal.contents();
|
|
65
|
-
(0, test_1.expect)(contents).toContain('hello');
|
|
66
|
-
});
|
|
67
|
-
(0, test_1.test)('should allow to submit a command and read output', async () => {
|
|
68
|
-
const terminal = await app.openTerminal(theia_terminal_1.TheiaTerminal);
|
|
69
|
-
if (process.platform === 'win32') {
|
|
70
|
-
await terminal.submit('dir');
|
|
71
|
-
}
|
|
72
|
-
else {
|
|
73
|
-
await terminal.submit('ls');
|
|
74
|
-
}
|
|
75
|
-
const contents = await terminal.contents();
|
|
76
|
-
(0, test_1.expect)(contents).toContain('sample.txt');
|
|
77
|
-
});
|
|
78
|
-
});
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2023 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_workspace_1 = require("../theia-workspace");
|
|
21
|
+
const theia_terminal_1 = require("../theia-terminal");
|
|
22
|
+
let app;
|
|
23
|
+
test_1.test.describe('Theia Terminal View', () => {
|
|
24
|
+
test_1.test.beforeAll(async ({ playwright, browser }) => {
|
|
25
|
+
const ws = new theia_workspace_1.TheiaWorkspace(['src/tests/resources/sample-files1']);
|
|
26
|
+
app = await theia_app_loader_1.TheiaAppLoader.load({ playwright, browser }, ws);
|
|
27
|
+
});
|
|
28
|
+
test_1.test.afterAll(async () => {
|
|
29
|
+
await app.page.close();
|
|
30
|
+
});
|
|
31
|
+
(0, test_1.test)('should be possible to open a new terminal', async () => {
|
|
32
|
+
const terminal = await app.openTerminal(theia_terminal_1.TheiaTerminal);
|
|
33
|
+
(0, test_1.expect)(await terminal.isTabVisible()).toBe(true);
|
|
34
|
+
(0, test_1.expect)(await terminal.isDisplayed()).toBe(true);
|
|
35
|
+
(0, test_1.expect)(await terminal.isActive()).toBe(true);
|
|
36
|
+
});
|
|
37
|
+
(0, test_1.test)('should be possible to open two terminals, switch among them, and close them', async () => {
|
|
38
|
+
const terminal1 = await app.openTerminal(theia_terminal_1.TheiaTerminal);
|
|
39
|
+
const terminal2 = await app.openTerminal(theia_terminal_1.TheiaTerminal);
|
|
40
|
+
const allTerminals = [terminal1, terminal2];
|
|
41
|
+
// all terminal tabs should be visible
|
|
42
|
+
for (const terminal of allTerminals) {
|
|
43
|
+
(0, test_1.expect)(await terminal.isTabVisible()).toBe(true);
|
|
44
|
+
}
|
|
45
|
+
// activate one terminal after the other and check that only this terminal is active
|
|
46
|
+
for (const terminal of allTerminals) {
|
|
47
|
+
await terminal.activate();
|
|
48
|
+
(0, test_1.expect)(await terminal1.isActive()).toBe(terminal1 === terminal);
|
|
49
|
+
(0, test_1.expect)(await terminal2.isActive()).toBe(terminal2 === terminal);
|
|
50
|
+
}
|
|
51
|
+
// close all terminals
|
|
52
|
+
for (const terminal of allTerminals) {
|
|
53
|
+
await terminal.activate();
|
|
54
|
+
await terminal.close();
|
|
55
|
+
}
|
|
56
|
+
// check that all terminals are closed
|
|
57
|
+
for (const terminal of allTerminals) {
|
|
58
|
+
(0, test_1.expect)(await terminal.isTabVisible()).toBe(false);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
(0, test_1.test)('should allow to write and read terminal contents', async () => {
|
|
62
|
+
const terminal = await app.openTerminal(theia_terminal_1.TheiaTerminal);
|
|
63
|
+
await terminal.write('hello');
|
|
64
|
+
const contents = await terminal.contents();
|
|
65
|
+
(0, test_1.expect)(contents).toContain('hello');
|
|
66
|
+
});
|
|
67
|
+
(0, test_1.test)('should allow to submit a command and read output', async () => {
|
|
68
|
+
const terminal = await app.openTerminal(theia_terminal_1.TheiaTerminal);
|
|
69
|
+
if (process.platform === 'win32') {
|
|
70
|
+
await terminal.submit('dir');
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
await terminal.submit('ls');
|
|
74
|
+
}
|
|
75
|
+
const contents = await terminal.contents();
|
|
76
|
+
(0, test_1.expect)(contents).toContain('sample.txt');
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
79
|
//# sourceMappingURL=theia-terminal-view.test.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=theia-text-editor.test.d.ts.map
|
|
@@ -1,156 +1,156 @@
|
|
|
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_text_editor_1 = require("../theia-text-editor");
|
|
22
|
-
const theia_workspace_1 = require("../theia-workspace");
|
|
23
|
-
test_1.test.describe('Theia Text Editor', () => {
|
|
24
|
-
let app;
|
|
25
|
-
test_1.test.beforeAll(async ({ playwright, browser }) => {
|
|
26
|
-
const ws = new theia_workspace_1.TheiaWorkspace(['src/tests/resources/sample-files1']);
|
|
27
|
-
app = await theia_app_loader_1.TheiaAppLoader.load({ playwright, browser }, ws);
|
|
28
|
-
// set auto-save preference to off
|
|
29
|
-
const preferenceView = await app.openPreferences(theia_preference_view_1.TheiaPreferenceView);
|
|
30
|
-
await preferenceView.setOptionsPreferenceById(theia_preference_view_1.PreferenceIds.Editor.AutoSave, theia_preference_view_1.DefaultPreferences.Editor.AutoSave.Off);
|
|
31
|
-
await preferenceView.close();
|
|
32
|
-
});
|
|
33
|
-
test_1.test.afterAll(async () => {
|
|
34
|
-
await app.page.close();
|
|
35
|
-
});
|
|
36
|
-
(0, test_1.test)('should be visible and active after opening "sample.txt"', async () => {
|
|
37
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
38
|
-
(0, test_1.expect)(await sampleTextEditor.isTabVisible()).toBe(true);
|
|
39
|
-
(0, test_1.expect)(await sampleTextEditor.isDisplayed()).toBe(true);
|
|
40
|
-
(0, test_1.expect)(await sampleTextEditor.isActive()).toBe(true);
|
|
41
|
-
});
|
|
42
|
-
(0, test_1.test)('should be possible to open "sample.txt" when already opened and then close it', async () => {
|
|
43
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
44
|
-
(0, test_1.expect)(await sampleTextEditor.isTabVisible()).toBe(true);
|
|
45
|
-
await sampleTextEditor.close();
|
|
46
|
-
(0, test_1.expect)(await sampleTextEditor.isTabVisible()).toBe(false);
|
|
47
|
-
});
|
|
48
|
-
(0, test_1.test)('should be possible to open four text editors, switch among them, and close them', async () => {
|
|
49
|
-
const textEditor1_1_1 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt', theia_text_editor_1.TheiaTextEditor);
|
|
50
|
-
const textEditor1_1_2 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-2.txt', theia_text_editor_1.TheiaTextEditor);
|
|
51
|
-
const textEditor1_2_1 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-1.txt', theia_text_editor_1.TheiaTextEditor);
|
|
52
|
-
const textEditor1_2_2 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-2.txt', theia_text_editor_1.TheiaTextEditor);
|
|
53
|
-
const allEditors = [textEditor1_1_1, textEditor1_1_2, textEditor1_2_1, textEditor1_2_2];
|
|
54
|
-
// all editor tabs should be visible
|
|
55
|
-
for (const editor of allEditors) {
|
|
56
|
-
(0, test_1.expect)(await editor.isTabVisible()).toBe(true);
|
|
57
|
-
}
|
|
58
|
-
// activate one editor after the other and check that only this editor is active
|
|
59
|
-
for (const editor of allEditors) {
|
|
60
|
-
await editor.activate();
|
|
61
|
-
(0, test_1.expect)(await textEditor1_1_1.isActive()).toBe(textEditor1_1_1 === editor);
|
|
62
|
-
(0, test_1.expect)(await textEditor1_1_2.isActive()).toBe(textEditor1_1_2 === editor);
|
|
63
|
-
(0, test_1.expect)(await textEditor1_2_1.isActive()).toBe(textEditor1_2_1 === editor);
|
|
64
|
-
(0, test_1.expect)(await textEditor1_2_2.isActive()).toBe(textEditor1_2_2 === editor);
|
|
65
|
-
}
|
|
66
|
-
// close all editors
|
|
67
|
-
for (const editor of allEditors) {
|
|
68
|
-
await editor.activate();
|
|
69
|
-
await editor.close();
|
|
70
|
-
}
|
|
71
|
-
// check that all editors are closed
|
|
72
|
-
for (const editor of allEditors) {
|
|
73
|
-
(0, test_1.expect)(await editor.isTabVisible()).toBe(false);
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
(0, test_1.test)('should return the contents of lines by line number', async () => {
|
|
77
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
78
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 2');
|
|
79
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(3)).toBe('content line 3');
|
|
80
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(4)).toBe('content line 4');
|
|
81
|
-
await sampleTextEditor.close();
|
|
82
|
-
});
|
|
83
|
-
(0, test_1.test)('should return the contents of lines containing text', async () => {
|
|
84
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
85
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineContainingText('line 2')).toBe('content line 2');
|
|
86
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineContainingText('line 3')).toBe('content line 3');
|
|
87
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineContainingText('line 4')).toBe('content line 4');
|
|
88
|
-
await sampleTextEditor.close();
|
|
89
|
-
});
|
|
90
|
-
(0, test_1.test)('should be dirty after changing the file contents and clean after save', async () => {
|
|
91
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
92
|
-
await sampleTextEditor.replaceLineWithLineNumber('this is just a sample file', 1);
|
|
93
|
-
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(true);
|
|
94
|
-
await sampleTextEditor.save();
|
|
95
|
-
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(false);
|
|
96
|
-
await sampleTextEditor.close();
|
|
97
|
-
});
|
|
98
|
-
(0, test_1.test)('should replace the line with line number 2 with new text "new -- content line 2 -- new"', async () => {
|
|
99
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
100
|
-
await sampleTextEditor.replaceLineWithLineNumber('new -- content line 2 -- new', 2);
|
|
101
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('new -- content line 2 -- new');
|
|
102
|
-
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(true);
|
|
103
|
-
await sampleTextEditor.save();
|
|
104
|
-
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(false);
|
|
105
|
-
await sampleTextEditor.close();
|
|
106
|
-
});
|
|
107
|
-
(0, test_1.test)('should replace the line with containing text "content line 2" with "even newer -- content line 2 -- even newer"', async () => {
|
|
108
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
109
|
-
await sampleTextEditor.replaceLineContainingText('even newer -- content line 2 -- even newer', 'content line 2');
|
|
110
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('even newer -- content line 2 -- even newer');
|
|
111
|
-
await sampleTextEditor.saveAndClose();
|
|
112
|
-
});
|
|
113
|
-
(0, test_1.test)('should delete the line with containing text "content line 2"', async () => {
|
|
114
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
115
|
-
await sampleTextEditor.deleteLineContainingText('content line 2');
|
|
116
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 3');
|
|
117
|
-
await sampleTextEditor.saveAndClose();
|
|
118
|
-
});
|
|
119
|
-
(0, test_1.test)('should delete the line with line number 2', async () => {
|
|
120
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
121
|
-
await sampleTextEditor.deleteLineByLineNumber(2);
|
|
122
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 4');
|
|
123
|
-
await sampleTextEditor.saveAndClose();
|
|
124
|
-
});
|
|
125
|
-
(0, test_1.test)('should have more lines after adding text in new line after line containing text "sample file"', async () => {
|
|
126
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
127
|
-
const numberOfLinesBefore = await sampleTextEditor.numberOfLines();
|
|
128
|
-
await sampleTextEditor.addTextToNewLineAfterLineContainingText('sample file', 'new content for line 2');
|
|
129
|
-
const numberOfLinesAfter = await sampleTextEditor.numberOfLines();
|
|
130
|
-
(0, test_1.expect)(numberOfLinesBefore).not.toBeUndefined();
|
|
131
|
-
(0, test_1.expect)(numberOfLinesAfter).not.toBeUndefined();
|
|
132
|
-
(0, test_1.expect)(numberOfLinesAfter).toBeGreaterThan(numberOfLinesBefore);
|
|
133
|
-
await sampleTextEditor.saveAndClose();
|
|
134
|
-
});
|
|
135
|
-
(0, test_1.test)('should undo and redo text changes with correctly updated dirty states', async () => {
|
|
136
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
137
|
-
await sampleTextEditor.replaceLineWithLineNumber('change', 1);
|
|
138
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('change');
|
|
139
|
-
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(true);
|
|
140
|
-
await sampleTextEditor.undo(2);
|
|
141
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('this is just a sample file');
|
|
142
|
-
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(false);
|
|
143
|
-
await sampleTextEditor.redo(2);
|
|
144
|
-
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('change');
|
|
145
|
-
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(true);
|
|
146
|
-
await sampleTextEditor.saveAndClose();
|
|
147
|
-
});
|
|
148
|
-
(0, test_1.test)('should close without saving', async () => {
|
|
149
|
-
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
150
|
-
await sampleTextEditor.replaceLineWithLineNumber('change again', 1);
|
|
151
|
-
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(true);
|
|
152
|
-
await sampleTextEditor.closeWithoutSave();
|
|
153
|
-
(0, test_1.expect)(await sampleTextEditor.isTabVisible()).toBe(false);
|
|
154
|
-
});
|
|
155
|
-
});
|
|
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_text_editor_1 = require("../theia-text-editor");
|
|
22
|
+
const theia_workspace_1 = require("../theia-workspace");
|
|
23
|
+
test_1.test.describe('Theia Text Editor', () => {
|
|
24
|
+
let app;
|
|
25
|
+
test_1.test.beforeAll(async ({ playwright, browser }) => {
|
|
26
|
+
const ws = new theia_workspace_1.TheiaWorkspace(['src/tests/resources/sample-files1']);
|
|
27
|
+
app = await theia_app_loader_1.TheiaAppLoader.load({ playwright, browser }, ws);
|
|
28
|
+
// set auto-save preference to off
|
|
29
|
+
const preferenceView = await app.openPreferences(theia_preference_view_1.TheiaPreferenceView);
|
|
30
|
+
await preferenceView.setOptionsPreferenceById(theia_preference_view_1.PreferenceIds.Editor.AutoSave, theia_preference_view_1.DefaultPreferences.Editor.AutoSave.Off);
|
|
31
|
+
await preferenceView.close();
|
|
32
|
+
});
|
|
33
|
+
test_1.test.afterAll(async () => {
|
|
34
|
+
await app.page.close();
|
|
35
|
+
});
|
|
36
|
+
(0, test_1.test)('should be visible and active after opening "sample.txt"', async () => {
|
|
37
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
38
|
+
(0, test_1.expect)(await sampleTextEditor.isTabVisible()).toBe(true);
|
|
39
|
+
(0, test_1.expect)(await sampleTextEditor.isDisplayed()).toBe(true);
|
|
40
|
+
(0, test_1.expect)(await sampleTextEditor.isActive()).toBe(true);
|
|
41
|
+
});
|
|
42
|
+
(0, test_1.test)('should be possible to open "sample.txt" when already opened and then close it', async () => {
|
|
43
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
44
|
+
(0, test_1.expect)(await sampleTextEditor.isTabVisible()).toBe(true);
|
|
45
|
+
await sampleTextEditor.close();
|
|
46
|
+
(0, test_1.expect)(await sampleTextEditor.isTabVisible()).toBe(false);
|
|
47
|
+
});
|
|
48
|
+
(0, test_1.test)('should be possible to open four text editors, switch among them, and close them', async () => {
|
|
49
|
+
const textEditor1_1_1 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt', theia_text_editor_1.TheiaTextEditor);
|
|
50
|
+
const textEditor1_1_2 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-2.txt', theia_text_editor_1.TheiaTextEditor);
|
|
51
|
+
const textEditor1_2_1 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-1.txt', theia_text_editor_1.TheiaTextEditor);
|
|
52
|
+
const textEditor1_2_2 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-2.txt', theia_text_editor_1.TheiaTextEditor);
|
|
53
|
+
const allEditors = [textEditor1_1_1, textEditor1_1_2, textEditor1_2_1, textEditor1_2_2];
|
|
54
|
+
// all editor tabs should be visible
|
|
55
|
+
for (const editor of allEditors) {
|
|
56
|
+
(0, test_1.expect)(await editor.isTabVisible()).toBe(true);
|
|
57
|
+
}
|
|
58
|
+
// activate one editor after the other and check that only this editor is active
|
|
59
|
+
for (const editor of allEditors) {
|
|
60
|
+
await editor.activate();
|
|
61
|
+
(0, test_1.expect)(await textEditor1_1_1.isActive()).toBe(textEditor1_1_1 === editor);
|
|
62
|
+
(0, test_1.expect)(await textEditor1_1_2.isActive()).toBe(textEditor1_1_2 === editor);
|
|
63
|
+
(0, test_1.expect)(await textEditor1_2_1.isActive()).toBe(textEditor1_2_1 === editor);
|
|
64
|
+
(0, test_1.expect)(await textEditor1_2_2.isActive()).toBe(textEditor1_2_2 === editor);
|
|
65
|
+
}
|
|
66
|
+
// close all editors
|
|
67
|
+
for (const editor of allEditors) {
|
|
68
|
+
await editor.activate();
|
|
69
|
+
await editor.close();
|
|
70
|
+
}
|
|
71
|
+
// check that all editors are closed
|
|
72
|
+
for (const editor of allEditors) {
|
|
73
|
+
(0, test_1.expect)(await editor.isTabVisible()).toBe(false);
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
(0, test_1.test)('should return the contents of lines by line number', async () => {
|
|
77
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
78
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 2');
|
|
79
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(3)).toBe('content line 3');
|
|
80
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(4)).toBe('content line 4');
|
|
81
|
+
await sampleTextEditor.close();
|
|
82
|
+
});
|
|
83
|
+
(0, test_1.test)('should return the contents of lines containing text', async () => {
|
|
84
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
85
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineContainingText('line 2')).toBe('content line 2');
|
|
86
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineContainingText('line 3')).toBe('content line 3');
|
|
87
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineContainingText('line 4')).toBe('content line 4');
|
|
88
|
+
await sampleTextEditor.close();
|
|
89
|
+
});
|
|
90
|
+
(0, test_1.test)('should be dirty after changing the file contents and clean after save', async () => {
|
|
91
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
92
|
+
await sampleTextEditor.replaceLineWithLineNumber('this is just a sample file', 1);
|
|
93
|
+
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(true);
|
|
94
|
+
await sampleTextEditor.save();
|
|
95
|
+
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(false);
|
|
96
|
+
await sampleTextEditor.close();
|
|
97
|
+
});
|
|
98
|
+
(0, test_1.test)('should replace the line with line number 2 with new text "new -- content line 2 -- new"', async () => {
|
|
99
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
100
|
+
await sampleTextEditor.replaceLineWithLineNumber('new -- content line 2 -- new', 2);
|
|
101
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('new -- content line 2 -- new');
|
|
102
|
+
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(true);
|
|
103
|
+
await sampleTextEditor.save();
|
|
104
|
+
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(false);
|
|
105
|
+
await sampleTextEditor.close();
|
|
106
|
+
});
|
|
107
|
+
(0, test_1.test)('should replace the line with containing text "content line 2" with "even newer -- content line 2 -- even newer"', async () => {
|
|
108
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
109
|
+
await sampleTextEditor.replaceLineContainingText('even newer -- content line 2 -- even newer', 'content line 2');
|
|
110
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('even newer -- content line 2 -- even newer');
|
|
111
|
+
await sampleTextEditor.saveAndClose();
|
|
112
|
+
});
|
|
113
|
+
(0, test_1.test)('should delete the line with containing text "content line 2"', async () => {
|
|
114
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
115
|
+
await sampleTextEditor.deleteLineContainingText('content line 2');
|
|
116
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 3');
|
|
117
|
+
await sampleTextEditor.saveAndClose();
|
|
118
|
+
});
|
|
119
|
+
(0, test_1.test)('should delete the line with line number 2', async () => {
|
|
120
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
121
|
+
await sampleTextEditor.deleteLineByLineNumber(2);
|
|
122
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 4');
|
|
123
|
+
await sampleTextEditor.saveAndClose();
|
|
124
|
+
});
|
|
125
|
+
(0, test_1.test)('should have more lines after adding text in new line after line containing text "sample file"', async () => {
|
|
126
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
127
|
+
const numberOfLinesBefore = await sampleTextEditor.numberOfLines();
|
|
128
|
+
await sampleTextEditor.addTextToNewLineAfterLineContainingText('sample file', 'new content for line 2');
|
|
129
|
+
const numberOfLinesAfter = await sampleTextEditor.numberOfLines();
|
|
130
|
+
(0, test_1.expect)(numberOfLinesBefore).not.toBeUndefined();
|
|
131
|
+
(0, test_1.expect)(numberOfLinesAfter).not.toBeUndefined();
|
|
132
|
+
(0, test_1.expect)(numberOfLinesAfter).toBeGreaterThan(numberOfLinesBefore);
|
|
133
|
+
await sampleTextEditor.saveAndClose();
|
|
134
|
+
});
|
|
135
|
+
(0, test_1.test)('should undo and redo text changes with correctly updated dirty states', async () => {
|
|
136
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
137
|
+
await sampleTextEditor.replaceLineWithLineNumber('change', 1);
|
|
138
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('change');
|
|
139
|
+
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(true);
|
|
140
|
+
await sampleTextEditor.undo(2);
|
|
141
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('this is just a sample file');
|
|
142
|
+
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(false);
|
|
143
|
+
await sampleTextEditor.redo(2);
|
|
144
|
+
(0, test_1.expect)(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('change');
|
|
145
|
+
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(true);
|
|
146
|
+
await sampleTextEditor.saveAndClose();
|
|
147
|
+
});
|
|
148
|
+
(0, test_1.test)('should close without saving', async () => {
|
|
149
|
+
const sampleTextEditor = await app.openEditor('sample.txt', theia_text_editor_1.TheiaTextEditor);
|
|
150
|
+
await sampleTextEditor.replaceLineWithLineNumber('change again', 1);
|
|
151
|
+
(0, test_1.expect)(await sampleTextEditor.isDirty()).toBe(true);
|
|
152
|
+
await sampleTextEditor.closeWithoutSave();
|
|
153
|
+
(0, test_1.expect)(await sampleTextEditor.isTabVisible()).toBe(false);
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
156
|
//# sourceMappingURL=theia-text-editor.test.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=theia-toolbar.test.d.ts.map
|
|
@@ -1,62 +1,62 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// *****************************************************************************
|
|
3
|
-
// Copyright (C) 2023 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_toolbar_1 = require("../theia-toolbar");
|
|
21
|
-
let app;
|
|
22
|
-
let toolbar;
|
|
23
|
-
test_1.test.describe('Theia Toolbar', () => {
|
|
24
|
-
test_1.test.beforeAll(async ({ playwright, browser }) => {
|
|
25
|
-
app = await theia_app_loader_1.TheiaAppLoader.load({ playwright, browser });
|
|
26
|
-
toolbar = new theia_toolbar_1.TheiaToolbar(app);
|
|
27
|
-
});
|
|
28
|
-
test_1.test.afterAll(async () => {
|
|
29
|
-
await app.page.close();
|
|
30
|
-
});
|
|
31
|
-
(0, test_1.test)('should toggle the toolbar and check visibility', async () => {
|
|
32
|
-
// depending on the user settings we have different starting conditions for the toolbar
|
|
33
|
-
const isShownInitially = await toolbar.isShown();
|
|
34
|
-
(0, test_1.expect)(await toolbar.isShown()).toBe(isShownInitially);
|
|
35
|
-
await toolbar.toggle();
|
|
36
|
-
(0, test_1.expect)(await toolbar.isShown()).toBe(!isShownInitially);
|
|
37
|
-
await toolbar.hide();
|
|
38
|
-
(0, test_1.expect)(await toolbar.isShown()).toBe(false);
|
|
39
|
-
await toolbar.show();
|
|
40
|
-
(0, test_1.expect)(await toolbar.isShown()).toBe(true);
|
|
41
|
-
});
|
|
42
|
-
(0, test_1.test)('should show the default toolbar tools of the sample Theia application', async () => {
|
|
43
|
-
(0, test_1.expect)(await toolbar.toolbarItems()).toHaveLength(5);
|
|
44
|
-
(0, test_1.expect)(await toolbar.toolbarItemIds()).toStrictEqual([
|
|
45
|
-
'textEditor.commands.go.back',
|
|
46
|
-
'textEditor.commands.go.forward',
|
|
47
|
-
'workbench.action.splitEditorRight',
|
|
48
|
-
'theia-sample-toolbar-contribution',
|
|
49
|
-
'workbench.action.showCommands'
|
|
50
|
-
]);
|
|
51
|
-
});
|
|
52
|
-
(0, test_1.test)('should trigger the "Command Palette" toolbar tool as expect the command palette to open', async () => {
|
|
53
|
-
const commandPaletteTool = await toolbar.toolBarItem('workbench.action.showCommands');
|
|
54
|
-
(0, test_1.expect)(commandPaletteTool).toBeDefined;
|
|
55
|
-
(0, test_1.expect)(await commandPaletteTool.isEnabled()).toBe(true);
|
|
56
|
-
await commandPaletteTool.trigger();
|
|
57
|
-
(0, test_1.expect)(await app.quickCommandPalette.isOpen()).toBe(true);
|
|
58
|
-
await app.quickCommandPalette.hide();
|
|
59
|
-
(0, test_1.expect)(await app.quickCommandPalette.isOpen()).toBe(false);
|
|
60
|
-
});
|
|
61
|
-
});
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2023 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_toolbar_1 = require("../theia-toolbar");
|
|
21
|
+
let app;
|
|
22
|
+
let toolbar;
|
|
23
|
+
test_1.test.describe('Theia Toolbar', () => {
|
|
24
|
+
test_1.test.beforeAll(async ({ playwright, browser }) => {
|
|
25
|
+
app = await theia_app_loader_1.TheiaAppLoader.load({ playwright, browser });
|
|
26
|
+
toolbar = new theia_toolbar_1.TheiaToolbar(app);
|
|
27
|
+
});
|
|
28
|
+
test_1.test.afterAll(async () => {
|
|
29
|
+
await app.page.close();
|
|
30
|
+
});
|
|
31
|
+
(0, test_1.test)('should toggle the toolbar and check visibility', async () => {
|
|
32
|
+
// depending on the user settings we have different starting conditions for the toolbar
|
|
33
|
+
const isShownInitially = await toolbar.isShown();
|
|
34
|
+
(0, test_1.expect)(await toolbar.isShown()).toBe(isShownInitially);
|
|
35
|
+
await toolbar.toggle();
|
|
36
|
+
(0, test_1.expect)(await toolbar.isShown()).toBe(!isShownInitially);
|
|
37
|
+
await toolbar.hide();
|
|
38
|
+
(0, test_1.expect)(await toolbar.isShown()).toBe(false);
|
|
39
|
+
await toolbar.show();
|
|
40
|
+
(0, test_1.expect)(await toolbar.isShown()).toBe(true);
|
|
41
|
+
});
|
|
42
|
+
(0, test_1.test)('should show the default toolbar tools of the sample Theia application', async () => {
|
|
43
|
+
(0, test_1.expect)(await toolbar.toolbarItems()).toHaveLength(5);
|
|
44
|
+
(0, test_1.expect)(await toolbar.toolbarItemIds()).toStrictEqual([
|
|
45
|
+
'textEditor.commands.go.back',
|
|
46
|
+
'textEditor.commands.go.forward',
|
|
47
|
+
'workbench.action.splitEditorRight',
|
|
48
|
+
'theia-sample-toolbar-contribution',
|
|
49
|
+
'workbench.action.showCommands'
|
|
50
|
+
]);
|
|
51
|
+
});
|
|
52
|
+
(0, test_1.test)('should trigger the "Command Palette" toolbar tool as expect the command palette to open', async () => {
|
|
53
|
+
const commandPaletteTool = await toolbar.toolBarItem('workbench.action.showCommands');
|
|
54
|
+
(0, test_1.expect)(commandPaletteTool).toBeDefined;
|
|
55
|
+
(0, test_1.expect)(await commandPaletteTool.isEnabled()).toBe(true);
|
|
56
|
+
await commandPaletteTool.trigger();
|
|
57
|
+
(0, test_1.expect)(await app.quickCommandPalette.isOpen()).toBe(true);
|
|
58
|
+
await app.quickCommandPalette.hide();
|
|
59
|
+
(0, test_1.expect)(await app.quickCommandPalette.isOpen()).toBe(false);
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
62
|
//# sourceMappingURL=theia-toolbar.test.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=theia-workspace.test.d.ts.map
|