@theia/playwright 1.45.0 → 1.46.0-next.72
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 +57 -57
- package/lib/tests/fixtures/theia-fixture.d.ts +4 -0
- package/lib/tests/fixtures/theia-fixture.d.ts.map +1 -0
- package/lib/tests/fixtures/theia-fixture.js +24 -0
- package/lib/tests/fixtures/theia-fixture.js.map +1 -0
- 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 +2 -0
- package/lib/tests/theia-application-shell.test.d.ts.map +1 -0
- package/lib/tests/theia-application-shell.test.js +58 -0
- package/lib/tests/theia-application-shell.test.js.map +1 -0
- 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-main-menu.test.d.ts +1 -1
- package/lib/tests/theia-main-menu.test.js +92 -92
- 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 +80 -80
- package/lib/theia-rename-dialog.d.ts +5 -5
- package/lib/theia-rename-dialog.js +35 -35
- 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 +6 -0
- package/lib/theia-welcome-view.d.ts.map +1 -0
- package/lib/theia-welcome-view.js +31 -0
- package/lib/theia-welcome-view.js.map +1 -0
- 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 -0
- package/src/tests/theia-explorer-view.test.ts +211 -211
- package/src/tests/theia-main-menu.test.ts +112 -112
- 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 +83 -83
- package/src/theia-rename-dialog.ts +36 -36
- 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 -0
- package/src/theia-workspace.ts +76 -76
- package/src/util.ts +91 -91
|
@@ -1,90 +1,90 @@
|
|
|
1
|
-
// *****************************************************************************
|
|
2
|
-
// Copyright (C) 2023 EclipseSource and others.
|
|
3
|
-
//
|
|
4
|
-
// This program and the accompanying materials are made available under the
|
|
5
|
-
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
-
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
-
//
|
|
8
|
-
// This Source Code may also be made available under the following Secondary
|
|
9
|
-
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
-
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
-
// with the GNU Classpath Exception which is available at
|
|
12
|
-
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
-
//
|
|
14
|
-
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
15
|
-
// *****************************************************************************
|
|
16
|
-
|
|
17
|
-
import { expect, test } from '@playwright/test';
|
|
18
|
-
import { TheiaApp } from '../theia-app';
|
|
19
|
-
import { TheiaAppLoader } from '../theia-app-loader';
|
|
20
|
-
import { TheiaWorkspace } from '../theia-workspace';
|
|
21
|
-
import { TheiaTerminal } from '../theia-terminal';
|
|
22
|
-
|
|
23
|
-
let app: TheiaApp;
|
|
24
|
-
|
|
25
|
-
test.describe('Theia Terminal View', () => {
|
|
26
|
-
|
|
27
|
-
test.beforeAll(async ({ playwright, browser }) => {
|
|
28
|
-
const ws = new TheiaWorkspace(['src/tests/resources/sample-files1']);
|
|
29
|
-
app = await TheiaAppLoader.load({ playwright, browser }, ws);
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
test.afterAll(async () => {
|
|
33
|
-
await app.page.close();
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
test('should be possible to open a new terminal', async () => {
|
|
37
|
-
const terminal = await app.openTerminal(TheiaTerminal);
|
|
38
|
-
expect(await terminal.isTabVisible()).toBe(true);
|
|
39
|
-
expect(await terminal.isDisplayed()).toBe(true);
|
|
40
|
-
expect(await terminal.isActive()).toBe(true);
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
test('should be possible to open two terminals, switch among them, and close them', async () => {
|
|
44
|
-
const terminal1 = await app.openTerminal(TheiaTerminal);
|
|
45
|
-
const terminal2 = await app.openTerminal(TheiaTerminal);
|
|
46
|
-
const allTerminals = [terminal1, terminal2];
|
|
47
|
-
|
|
48
|
-
// all terminal tabs should be visible
|
|
49
|
-
for (const terminal of allTerminals) {
|
|
50
|
-
expect(await terminal.isTabVisible()).toBe(true);
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
// activate one terminal after the other and check that only this terminal is active
|
|
54
|
-
for (const terminal of allTerminals) {
|
|
55
|
-
await terminal.activate();
|
|
56
|
-
expect(await terminal1.isActive()).toBe(terminal1 === terminal);
|
|
57
|
-
expect(await terminal2.isActive()).toBe(terminal2 === terminal);
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
// close all terminals
|
|
61
|
-
for (const terminal of allTerminals) {
|
|
62
|
-
await terminal.activate();
|
|
63
|
-
await terminal.close();
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
// check that all terminals are closed
|
|
67
|
-
for (const terminal of allTerminals) {
|
|
68
|
-
expect(await terminal.isTabVisible()).toBe(false);
|
|
69
|
-
}
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
test('should allow to write and read terminal contents', async () => {
|
|
73
|
-
const terminal = await app.openTerminal(TheiaTerminal);
|
|
74
|
-
await terminal.write('hello');
|
|
75
|
-
const contents = await terminal.contents();
|
|
76
|
-
expect(contents).toContain('hello');
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
test('should allow to submit a command and read output', async () => {
|
|
80
|
-
const terminal = await app.openTerminal(TheiaTerminal);
|
|
81
|
-
if (process.platform === 'win32') {
|
|
82
|
-
await terminal.submit('dir');
|
|
83
|
-
} else {
|
|
84
|
-
await terminal.submit('ls');
|
|
85
|
-
}
|
|
86
|
-
const contents = await terminal.contents();
|
|
87
|
-
expect(contents).toContain('sample.txt');
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
});
|
|
1
|
+
// *****************************************************************************
|
|
2
|
+
// Copyright (C) 2023 EclipseSource and others.
|
|
3
|
+
//
|
|
4
|
+
// This program and the accompanying materials are made available under the
|
|
5
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
+
//
|
|
8
|
+
// This Source Code may also be made available under the following Secondary
|
|
9
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
+
// with the GNU Classpath Exception which is available at
|
|
12
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
+
//
|
|
14
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
15
|
+
// *****************************************************************************
|
|
16
|
+
|
|
17
|
+
import { expect, test } from '@playwright/test';
|
|
18
|
+
import { TheiaApp } from '../theia-app';
|
|
19
|
+
import { TheiaAppLoader } from '../theia-app-loader';
|
|
20
|
+
import { TheiaWorkspace } from '../theia-workspace';
|
|
21
|
+
import { TheiaTerminal } from '../theia-terminal';
|
|
22
|
+
|
|
23
|
+
let app: TheiaApp;
|
|
24
|
+
|
|
25
|
+
test.describe('Theia Terminal View', () => {
|
|
26
|
+
|
|
27
|
+
test.beforeAll(async ({ playwright, browser }) => {
|
|
28
|
+
const ws = new TheiaWorkspace(['src/tests/resources/sample-files1']);
|
|
29
|
+
app = await TheiaAppLoader.load({ playwright, browser }, ws);
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
test.afterAll(async () => {
|
|
33
|
+
await app.page.close();
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
test('should be possible to open a new terminal', async () => {
|
|
37
|
+
const terminal = await app.openTerminal(TheiaTerminal);
|
|
38
|
+
expect(await terminal.isTabVisible()).toBe(true);
|
|
39
|
+
expect(await terminal.isDisplayed()).toBe(true);
|
|
40
|
+
expect(await terminal.isActive()).toBe(true);
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
test('should be possible to open two terminals, switch among them, and close them', async () => {
|
|
44
|
+
const terminal1 = await app.openTerminal(TheiaTerminal);
|
|
45
|
+
const terminal2 = await app.openTerminal(TheiaTerminal);
|
|
46
|
+
const allTerminals = [terminal1, terminal2];
|
|
47
|
+
|
|
48
|
+
// all terminal tabs should be visible
|
|
49
|
+
for (const terminal of allTerminals) {
|
|
50
|
+
expect(await terminal.isTabVisible()).toBe(true);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
// activate one terminal after the other and check that only this terminal is active
|
|
54
|
+
for (const terminal of allTerminals) {
|
|
55
|
+
await terminal.activate();
|
|
56
|
+
expect(await terminal1.isActive()).toBe(terminal1 === terminal);
|
|
57
|
+
expect(await terminal2.isActive()).toBe(terminal2 === terminal);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// close all terminals
|
|
61
|
+
for (const terminal of allTerminals) {
|
|
62
|
+
await terminal.activate();
|
|
63
|
+
await terminal.close();
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// check that all terminals are closed
|
|
67
|
+
for (const terminal of allTerminals) {
|
|
68
|
+
expect(await terminal.isTabVisible()).toBe(false);
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
test('should allow to write and read terminal contents', async () => {
|
|
73
|
+
const terminal = await app.openTerminal(TheiaTerminal);
|
|
74
|
+
await terminal.write('hello');
|
|
75
|
+
const contents = await terminal.contents();
|
|
76
|
+
expect(contents).toContain('hello');
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
test('should allow to submit a command and read output', async () => {
|
|
80
|
+
const terminal = await app.openTerminal(TheiaTerminal);
|
|
81
|
+
if (process.platform === 'win32') {
|
|
82
|
+
await terminal.submit('dir');
|
|
83
|
+
} else {
|
|
84
|
+
await terminal.submit('ls');
|
|
85
|
+
}
|
|
86
|
+
const contents = await terminal.contents();
|
|
87
|
+
expect(contents).toContain('sample.txt');
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
});
|
|
@@ -1,187 +1,187 @@
|
|
|
1
|
-
// *****************************************************************************
|
|
2
|
-
// Copyright (C) 2021 logi.cals GmbH, EclipseSource and others.
|
|
3
|
-
//
|
|
4
|
-
// This program and the accompanying materials are made available under the
|
|
5
|
-
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
-
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
-
//
|
|
8
|
-
// This Source Code may also be made available under the following Secondary
|
|
9
|
-
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
-
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
-
// with the GNU Classpath Exception which is available at
|
|
12
|
-
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
-
//
|
|
14
|
-
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
15
|
-
// *****************************************************************************
|
|
16
|
-
|
|
17
|
-
import { expect, test } from '@playwright/test';
|
|
18
|
-
import { TheiaApp } from '../theia-app';
|
|
19
|
-
import { TheiaAppLoader } from '../theia-app-loader';
|
|
20
|
-
import { DefaultPreferences, PreferenceIds, TheiaPreferenceView } from '../theia-preference-view';
|
|
21
|
-
import { TheiaTextEditor } from '../theia-text-editor';
|
|
22
|
-
import { TheiaWorkspace } from '../theia-workspace';
|
|
23
|
-
|
|
24
|
-
test.describe('Theia Text Editor', () => {
|
|
25
|
-
|
|
26
|
-
let app: TheiaApp;
|
|
27
|
-
|
|
28
|
-
test.beforeAll(async ({ playwright, browser }) => {
|
|
29
|
-
const ws = new TheiaWorkspace(['src/tests/resources/sample-files1']);
|
|
30
|
-
app = await TheiaAppLoader.load({ playwright, browser }, ws);
|
|
31
|
-
|
|
32
|
-
// set auto-save preference to off
|
|
33
|
-
const preferenceView = await app.openPreferences(TheiaPreferenceView);
|
|
34
|
-
await preferenceView.setOptionsPreferenceById(PreferenceIds.Editor.AutoSave, DefaultPreferences.Editor.AutoSave.Off);
|
|
35
|
-
await preferenceView.close();
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
test.afterAll(async () => {
|
|
39
|
-
await app.page.close();
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
test('should be visible and active after opening "sample.txt"', async () => {
|
|
43
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
44
|
-
expect(await sampleTextEditor.isTabVisible()).toBe(true);
|
|
45
|
-
expect(await sampleTextEditor.isDisplayed()).toBe(true);
|
|
46
|
-
expect(await sampleTextEditor.isActive()).toBe(true);
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
test('should be possible to open "sample.txt" when already opened and then close it', async () => {
|
|
50
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
51
|
-
expect(await sampleTextEditor.isTabVisible()).toBe(true);
|
|
52
|
-
|
|
53
|
-
await sampleTextEditor.close();
|
|
54
|
-
expect(await sampleTextEditor.isTabVisible()).toBe(false);
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
test('should be possible to open four text editors, switch among them, and close them', async () => {
|
|
58
|
-
const textEditor1_1_1 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt', TheiaTextEditor);
|
|
59
|
-
const textEditor1_1_2 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-2.txt', TheiaTextEditor);
|
|
60
|
-
const textEditor1_2_1 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-1.txt', TheiaTextEditor);
|
|
61
|
-
const textEditor1_2_2 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-2.txt', TheiaTextEditor);
|
|
62
|
-
const allEditors = [textEditor1_1_1, textEditor1_1_2, textEditor1_2_1, textEditor1_2_2];
|
|
63
|
-
|
|
64
|
-
// all editor tabs should be visible
|
|
65
|
-
for (const editor of allEditors) {
|
|
66
|
-
expect(await editor.isTabVisible()).toBe(true);
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
// activate one editor after the other and check that only this editor is active
|
|
70
|
-
for (const editor of allEditors) {
|
|
71
|
-
await editor.activate();
|
|
72
|
-
expect(await textEditor1_1_1.isActive()).toBe(textEditor1_1_1 === editor);
|
|
73
|
-
expect(await textEditor1_1_2.isActive()).toBe(textEditor1_1_2 === editor);
|
|
74
|
-
expect(await textEditor1_2_1.isActive()).toBe(textEditor1_2_1 === editor);
|
|
75
|
-
expect(await textEditor1_2_2.isActive()).toBe(textEditor1_2_2 === editor);
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
// close all editors
|
|
79
|
-
for (const editor of allEditors) {
|
|
80
|
-
await editor.activate();
|
|
81
|
-
await editor.close();
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
// check that all editors are closed
|
|
85
|
-
for (const editor of allEditors) {
|
|
86
|
-
expect(await editor.isTabVisible()).toBe(false);
|
|
87
|
-
}
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
test('should return the contents of lines by line number', async () => {
|
|
91
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
92
|
-
expect(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 2');
|
|
93
|
-
expect(await sampleTextEditor.textContentOfLineByLineNumber(3)).toBe('content line 3');
|
|
94
|
-
expect(await sampleTextEditor.textContentOfLineByLineNumber(4)).toBe('content line 4');
|
|
95
|
-
await sampleTextEditor.close();
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
test('should return the contents of lines containing text', async () => {
|
|
99
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
100
|
-
expect(await sampleTextEditor.textContentOfLineContainingText('line 2')).toBe('content line 2');
|
|
101
|
-
expect(await sampleTextEditor.textContentOfLineContainingText('line 3')).toBe('content line 3');
|
|
102
|
-
expect(await sampleTextEditor.textContentOfLineContainingText('line 4')).toBe('content line 4');
|
|
103
|
-
await sampleTextEditor.close();
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
test('should be dirty after changing the file contents and clean after save', async () => {
|
|
107
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
108
|
-
await sampleTextEditor.replaceLineWithLineNumber('this is just a sample file', 1);
|
|
109
|
-
expect(await sampleTextEditor.isDirty()).toBe(true);
|
|
110
|
-
|
|
111
|
-
await sampleTextEditor.save();
|
|
112
|
-
expect(await sampleTextEditor.isDirty()).toBe(false);
|
|
113
|
-
await sampleTextEditor.close();
|
|
114
|
-
});
|
|
115
|
-
|
|
116
|
-
test('should replace the line with line number 2 with new text "new -- content line 2 -- new"', async () => {
|
|
117
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
118
|
-
await sampleTextEditor.replaceLineWithLineNumber('new -- content line 2 -- new', 2);
|
|
119
|
-
expect(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('new -- content line 2 -- new');
|
|
120
|
-
expect(await sampleTextEditor.isDirty()).toBe(true);
|
|
121
|
-
|
|
122
|
-
await sampleTextEditor.save();
|
|
123
|
-
expect(await sampleTextEditor.isDirty()).toBe(false);
|
|
124
|
-
await sampleTextEditor.close();
|
|
125
|
-
});
|
|
126
|
-
|
|
127
|
-
test('should replace the line with containing text "content line 2" with "even newer -- content line 2 -- even newer"', async () => {
|
|
128
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
129
|
-
await sampleTextEditor.replaceLineContainingText('even newer -- content line 2 -- even newer', 'content line 2');
|
|
130
|
-
expect(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('even newer -- content line 2 -- even newer');
|
|
131
|
-
await sampleTextEditor.saveAndClose();
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
test('should delete the line with containing text "content line 2"', async () => {
|
|
135
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
136
|
-
await sampleTextEditor.deleteLineContainingText('content line 2');
|
|
137
|
-
expect(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 3');
|
|
138
|
-
await sampleTextEditor.saveAndClose();
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
test('should delete the line with line number 2', async () => {
|
|
142
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
143
|
-
await sampleTextEditor.deleteLineByLineNumber(2);
|
|
144
|
-
expect(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 4');
|
|
145
|
-
await sampleTextEditor.saveAndClose();
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
test('should have more lines after adding text in new line after line containing text "sample file"', async () => {
|
|
149
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
150
|
-
const numberOfLinesBefore = await sampleTextEditor.numberOfLines();
|
|
151
|
-
|
|
152
|
-
await sampleTextEditor.addTextToNewLineAfterLineContainingText('sample file', 'new content for line 2');
|
|
153
|
-
const numberOfLinesAfter = await sampleTextEditor.numberOfLines();
|
|
154
|
-
expect(numberOfLinesBefore).not.toBeUndefined();
|
|
155
|
-
expect(numberOfLinesAfter).not.toBeUndefined();
|
|
156
|
-
expect(numberOfLinesAfter).toBeGreaterThan(numberOfLinesBefore!);
|
|
157
|
-
|
|
158
|
-
await sampleTextEditor.saveAndClose();
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
test('should undo and redo text changes with correctly updated dirty states', async () => {
|
|
162
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
163
|
-
await sampleTextEditor.replaceLineWithLineNumber('change', 1);
|
|
164
|
-
expect(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('change');
|
|
165
|
-
expect(await sampleTextEditor.isDirty()).toBe(true);
|
|
166
|
-
|
|
167
|
-
await sampleTextEditor.undo(2);
|
|
168
|
-
expect(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('this is just a sample file');
|
|
169
|
-
expect(await sampleTextEditor.isDirty()).toBe(false);
|
|
170
|
-
|
|
171
|
-
await sampleTextEditor.redo(2);
|
|
172
|
-
expect(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('change');
|
|
173
|
-
expect(await sampleTextEditor.isDirty()).toBe(true);
|
|
174
|
-
|
|
175
|
-
await sampleTextEditor.saveAndClose();
|
|
176
|
-
});
|
|
177
|
-
|
|
178
|
-
test('should close without saving', async () => {
|
|
179
|
-
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
180
|
-
await sampleTextEditor.replaceLineWithLineNumber('change again', 1);
|
|
181
|
-
expect(await sampleTextEditor.isDirty()).toBe(true);
|
|
182
|
-
|
|
183
|
-
await sampleTextEditor.closeWithoutSave();
|
|
184
|
-
expect(await sampleTextEditor.isTabVisible()).toBe(false);
|
|
185
|
-
});
|
|
186
|
-
|
|
187
|
-
});
|
|
1
|
+
// *****************************************************************************
|
|
2
|
+
// Copyright (C) 2021 logi.cals GmbH, EclipseSource and others.
|
|
3
|
+
//
|
|
4
|
+
// This program and the accompanying materials are made available under the
|
|
5
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
+
//
|
|
8
|
+
// This Source Code may also be made available under the following Secondary
|
|
9
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
+
// with the GNU Classpath Exception which is available at
|
|
12
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
+
//
|
|
14
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
15
|
+
// *****************************************************************************
|
|
16
|
+
|
|
17
|
+
import { expect, test } from '@playwright/test';
|
|
18
|
+
import { TheiaApp } from '../theia-app';
|
|
19
|
+
import { TheiaAppLoader } from '../theia-app-loader';
|
|
20
|
+
import { DefaultPreferences, PreferenceIds, TheiaPreferenceView } from '../theia-preference-view';
|
|
21
|
+
import { TheiaTextEditor } from '../theia-text-editor';
|
|
22
|
+
import { TheiaWorkspace } from '../theia-workspace';
|
|
23
|
+
|
|
24
|
+
test.describe('Theia Text Editor', () => {
|
|
25
|
+
|
|
26
|
+
let app: TheiaApp;
|
|
27
|
+
|
|
28
|
+
test.beforeAll(async ({ playwright, browser }) => {
|
|
29
|
+
const ws = new TheiaWorkspace(['src/tests/resources/sample-files1']);
|
|
30
|
+
app = await TheiaAppLoader.load({ playwright, browser }, ws);
|
|
31
|
+
|
|
32
|
+
// set auto-save preference to off
|
|
33
|
+
const preferenceView = await app.openPreferences(TheiaPreferenceView);
|
|
34
|
+
await preferenceView.setOptionsPreferenceById(PreferenceIds.Editor.AutoSave, DefaultPreferences.Editor.AutoSave.Off);
|
|
35
|
+
await preferenceView.close();
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
test.afterAll(async () => {
|
|
39
|
+
await app.page.close();
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
test('should be visible and active after opening "sample.txt"', async () => {
|
|
43
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
44
|
+
expect(await sampleTextEditor.isTabVisible()).toBe(true);
|
|
45
|
+
expect(await sampleTextEditor.isDisplayed()).toBe(true);
|
|
46
|
+
expect(await sampleTextEditor.isActive()).toBe(true);
|
|
47
|
+
});
|
|
48
|
+
|
|
49
|
+
test('should be possible to open "sample.txt" when already opened and then close it', async () => {
|
|
50
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
51
|
+
expect(await sampleTextEditor.isTabVisible()).toBe(true);
|
|
52
|
+
|
|
53
|
+
await sampleTextEditor.close();
|
|
54
|
+
expect(await sampleTextEditor.isTabVisible()).toBe(false);
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
test('should be possible to open four text editors, switch among them, and close them', async () => {
|
|
58
|
+
const textEditor1_1_1 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt', TheiaTextEditor);
|
|
59
|
+
const textEditor1_1_2 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-2.txt', TheiaTextEditor);
|
|
60
|
+
const textEditor1_2_1 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-1.txt', TheiaTextEditor);
|
|
61
|
+
const textEditor1_2_2 = await app.openEditor('sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-2.txt', TheiaTextEditor);
|
|
62
|
+
const allEditors = [textEditor1_1_1, textEditor1_1_2, textEditor1_2_1, textEditor1_2_2];
|
|
63
|
+
|
|
64
|
+
// all editor tabs should be visible
|
|
65
|
+
for (const editor of allEditors) {
|
|
66
|
+
expect(await editor.isTabVisible()).toBe(true);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
// activate one editor after the other and check that only this editor is active
|
|
70
|
+
for (const editor of allEditors) {
|
|
71
|
+
await editor.activate();
|
|
72
|
+
expect(await textEditor1_1_1.isActive()).toBe(textEditor1_1_1 === editor);
|
|
73
|
+
expect(await textEditor1_1_2.isActive()).toBe(textEditor1_1_2 === editor);
|
|
74
|
+
expect(await textEditor1_2_1.isActive()).toBe(textEditor1_2_1 === editor);
|
|
75
|
+
expect(await textEditor1_2_2.isActive()).toBe(textEditor1_2_2 === editor);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
// close all editors
|
|
79
|
+
for (const editor of allEditors) {
|
|
80
|
+
await editor.activate();
|
|
81
|
+
await editor.close();
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
// check that all editors are closed
|
|
85
|
+
for (const editor of allEditors) {
|
|
86
|
+
expect(await editor.isTabVisible()).toBe(false);
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
test('should return the contents of lines by line number', async () => {
|
|
91
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
92
|
+
expect(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 2');
|
|
93
|
+
expect(await sampleTextEditor.textContentOfLineByLineNumber(3)).toBe('content line 3');
|
|
94
|
+
expect(await sampleTextEditor.textContentOfLineByLineNumber(4)).toBe('content line 4');
|
|
95
|
+
await sampleTextEditor.close();
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
test('should return the contents of lines containing text', async () => {
|
|
99
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
100
|
+
expect(await sampleTextEditor.textContentOfLineContainingText('line 2')).toBe('content line 2');
|
|
101
|
+
expect(await sampleTextEditor.textContentOfLineContainingText('line 3')).toBe('content line 3');
|
|
102
|
+
expect(await sampleTextEditor.textContentOfLineContainingText('line 4')).toBe('content line 4');
|
|
103
|
+
await sampleTextEditor.close();
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
test('should be dirty after changing the file contents and clean after save', async () => {
|
|
107
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
108
|
+
await sampleTextEditor.replaceLineWithLineNumber('this is just a sample file', 1);
|
|
109
|
+
expect(await sampleTextEditor.isDirty()).toBe(true);
|
|
110
|
+
|
|
111
|
+
await sampleTextEditor.save();
|
|
112
|
+
expect(await sampleTextEditor.isDirty()).toBe(false);
|
|
113
|
+
await sampleTextEditor.close();
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
test('should replace the line with line number 2 with new text "new -- content line 2 -- new"', async () => {
|
|
117
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
118
|
+
await sampleTextEditor.replaceLineWithLineNumber('new -- content line 2 -- new', 2);
|
|
119
|
+
expect(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('new -- content line 2 -- new');
|
|
120
|
+
expect(await sampleTextEditor.isDirty()).toBe(true);
|
|
121
|
+
|
|
122
|
+
await sampleTextEditor.save();
|
|
123
|
+
expect(await sampleTextEditor.isDirty()).toBe(false);
|
|
124
|
+
await sampleTextEditor.close();
|
|
125
|
+
});
|
|
126
|
+
|
|
127
|
+
test('should replace the line with containing text "content line 2" with "even newer -- content line 2 -- even newer"', async () => {
|
|
128
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
129
|
+
await sampleTextEditor.replaceLineContainingText('even newer -- content line 2 -- even newer', 'content line 2');
|
|
130
|
+
expect(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('even newer -- content line 2 -- even newer');
|
|
131
|
+
await sampleTextEditor.saveAndClose();
|
|
132
|
+
});
|
|
133
|
+
|
|
134
|
+
test('should delete the line with containing text "content line 2"', async () => {
|
|
135
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
136
|
+
await sampleTextEditor.deleteLineContainingText('content line 2');
|
|
137
|
+
expect(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 3');
|
|
138
|
+
await sampleTextEditor.saveAndClose();
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
test('should delete the line with line number 2', async () => {
|
|
142
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
143
|
+
await sampleTextEditor.deleteLineByLineNumber(2);
|
|
144
|
+
expect(await sampleTextEditor.textContentOfLineByLineNumber(2)).toBe('content line 4');
|
|
145
|
+
await sampleTextEditor.saveAndClose();
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
test('should have more lines after adding text in new line after line containing text "sample file"', async () => {
|
|
149
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
150
|
+
const numberOfLinesBefore = await sampleTextEditor.numberOfLines();
|
|
151
|
+
|
|
152
|
+
await sampleTextEditor.addTextToNewLineAfterLineContainingText('sample file', 'new content for line 2');
|
|
153
|
+
const numberOfLinesAfter = await sampleTextEditor.numberOfLines();
|
|
154
|
+
expect(numberOfLinesBefore).not.toBeUndefined();
|
|
155
|
+
expect(numberOfLinesAfter).not.toBeUndefined();
|
|
156
|
+
expect(numberOfLinesAfter).toBeGreaterThan(numberOfLinesBefore!);
|
|
157
|
+
|
|
158
|
+
await sampleTextEditor.saveAndClose();
|
|
159
|
+
});
|
|
160
|
+
|
|
161
|
+
test('should undo and redo text changes with correctly updated dirty states', async () => {
|
|
162
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
163
|
+
await sampleTextEditor.replaceLineWithLineNumber('change', 1);
|
|
164
|
+
expect(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('change');
|
|
165
|
+
expect(await sampleTextEditor.isDirty()).toBe(true);
|
|
166
|
+
|
|
167
|
+
await sampleTextEditor.undo(2);
|
|
168
|
+
expect(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('this is just a sample file');
|
|
169
|
+
expect(await sampleTextEditor.isDirty()).toBe(false);
|
|
170
|
+
|
|
171
|
+
await sampleTextEditor.redo(2);
|
|
172
|
+
expect(await sampleTextEditor.textContentOfLineByLineNumber(1)).toBe('change');
|
|
173
|
+
expect(await sampleTextEditor.isDirty()).toBe(true);
|
|
174
|
+
|
|
175
|
+
await sampleTextEditor.saveAndClose();
|
|
176
|
+
});
|
|
177
|
+
|
|
178
|
+
test('should close without saving', async () => {
|
|
179
|
+
const sampleTextEditor = await app.openEditor('sample.txt', TheiaTextEditor);
|
|
180
|
+
await sampleTextEditor.replaceLineWithLineNumber('change again', 1);
|
|
181
|
+
expect(await sampleTextEditor.isDirty()).toBe(true);
|
|
182
|
+
|
|
183
|
+
await sampleTextEditor.closeWithoutSave();
|
|
184
|
+
expect(await sampleTextEditor.isTabVisible()).toBe(false);
|
|
185
|
+
});
|
|
186
|
+
|
|
187
|
+
});
|