@theia/playwright 1.48.1 → 1.48.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (159) hide show
  1. package/README.md +54 -54
  2. package/lib/index.d.ts +30 -30
  3. package/lib/index.js +48 -48
  4. package/lib/tests/theia-app.test.d.ts +1 -1
  5. package/lib/tests/theia-app.test.js +29 -29
  6. package/lib/tests/theia-application-shell.test.d.ts +1 -1
  7. package/lib/tests/theia-application-shell.test.js +57 -57
  8. package/lib/tests/theia-explorer-view.test.d.ts +1 -1
  9. package/lib/tests/theia-explorer-view.test.js +183 -183
  10. package/lib/tests/theia-getting-started.test.d.ts +1 -1
  11. package/lib/tests/theia-getting-started.test.js +45 -45
  12. package/lib/tests/theia-main-menu.test.d.ts +1 -1
  13. package/lib/tests/theia-main-menu.test.js +111 -111
  14. package/lib/tests/theia-output-view.test.d.ts +1 -1
  15. package/lib/tests/theia-output-view.test.js +78 -78
  16. package/lib/tests/theia-preference-view.test.d.ts +1 -1
  17. package/lib/tests/theia-preference-view.test.js +101 -101
  18. package/lib/tests/theia-problems-view.test.d.ts +1 -1
  19. package/lib/tests/theia-problems-view.test.js +54 -54
  20. package/lib/tests/theia-quick-command.test.d.ts +1 -1
  21. package/lib/tests/theia-quick-command.test.js +69 -69
  22. package/lib/tests/theia-sample-app.test.d.ts +1 -1
  23. package/lib/tests/theia-sample-app.test.js +57 -57
  24. package/lib/tests/theia-status-bar.test.d.ts +1 -1
  25. package/lib/tests/theia-status-bar.test.js +44 -44
  26. package/lib/tests/theia-terminal-view.test.d.ts +1 -1
  27. package/lib/tests/theia-terminal-view.test.js +78 -78
  28. package/lib/tests/theia-text-editor.test.d.ts +1 -1
  29. package/lib/tests/theia-text-editor.test.js +155 -155
  30. package/lib/tests/theia-toolbar.test.d.ts +1 -1
  31. package/lib/tests/theia-toolbar.test.js +61 -61
  32. package/lib/tests/theia-workspace.test.d.ts +1 -1
  33. package/lib/tests/theia-workspace.test.js +72 -72
  34. package/lib/theia-about-dialog.d.ts +4 -4
  35. package/lib/theia-about-dialog.js +26 -26
  36. package/lib/theia-app-loader.d.ts +19 -19
  37. package/lib/theia-app-loader.js +129 -129
  38. package/lib/theia-app.d.ts +50 -50
  39. package/lib/theia-app.js +153 -153
  40. package/lib/theia-context-menu.d.ts +8 -8
  41. package/lib/theia-context-menu.js +37 -37
  42. package/lib/theia-dialog.d.ts +28 -28
  43. package/lib/theia-dialog.js +99 -99
  44. package/lib/theia-editor.d.ts +9 -9
  45. package/lib/theia-editor.js +68 -68
  46. package/lib/theia-explorer-view.d.ts +47 -47
  47. package/lib/theia-explorer-view.js +273 -273
  48. package/lib/theia-main-menu.d.ts +12 -12
  49. package/lib/theia-main-menu.js +53 -53
  50. package/lib/theia-menu-item.d.ts +14 -14
  51. package/lib/theia-menu-item.js +66 -66
  52. package/lib/theia-menu.d.ts +16 -16
  53. package/lib/theia-menu.js +86 -86
  54. package/lib/theia-monaco-editor.d.ts +15 -15
  55. package/lib/theia-monaco-editor.js +75 -75
  56. package/lib/theia-notification-indicator.d.ts +7 -7
  57. package/lib/theia-notification-indicator.js +44 -44
  58. package/lib/theia-notification-overlay.d.ts +22 -22
  59. package/lib/theia-notification-overlay.js +79 -79
  60. package/lib/theia-output-channel.d.ts +24 -24
  61. package/lib/theia-output-channel.js +71 -71
  62. package/lib/theia-output-view.d.ts +9 -9
  63. package/lib/theia-output-view.js +81 -81
  64. package/lib/theia-page-object.d.ts +7 -7
  65. package/lib/theia-page-object.js +27 -27
  66. package/lib/theia-preference-view.d.ts +84 -84
  67. package/lib/theia-preference-view.js +209 -209
  68. package/lib/theia-problem-indicator.d.ts +8 -8
  69. package/lib/theia-problem-indicator.js +38 -38
  70. package/lib/theia-problem-view.d.ts +5 -5
  71. package/lib/theia-problem-view.js +30 -30
  72. package/lib/theia-quick-command-palette.d.ts +12 -12
  73. package/lib/theia-quick-command-palette.js +78 -78
  74. package/lib/theia-rename-dialog.d.ts +5 -5
  75. package/lib/theia-rename-dialog.js +34 -34
  76. package/lib/theia-status-bar.d.ts +13 -13
  77. package/lib/theia-status-bar.js +39 -39
  78. package/lib/theia-status-indicator.d.ts +10 -10
  79. package/lib/theia-status-indicator.js +48 -48
  80. package/lib/theia-terminal.d.ts +13 -13
  81. package/lib/theia-terminal.js +59 -59
  82. package/lib/theia-text-editor.d.ts +26 -26
  83. package/lib/theia-text-editor.js +120 -120
  84. package/lib/theia-toggle-bottom-indicator.d.ts +4 -4
  85. package/lib/theia-toggle-bottom-indicator.js +26 -26
  86. package/lib/theia-toolbar-item.d.ts +10 -10
  87. package/lib/theia-toolbar-item.js +39 -39
  88. package/lib/theia-toolbar.d.ts +19 -19
  89. package/lib/theia-toolbar.js +90 -90
  90. package/lib/theia-tree-node.d.ts +19 -19
  91. package/lib/theia-tree-node.js +72 -72
  92. package/lib/theia-view.d.ts +32 -32
  93. package/lib/theia-view.js +149 -149
  94. package/lib/theia-welcome-view.d.ts +5 -5
  95. package/lib/theia-welcome-view.js +30 -30
  96. package/lib/theia-workspace.d.ts +18 -18
  97. package/lib/theia-workspace.js +69 -69
  98. package/lib/util.d.ts +19 -19
  99. package/lib/util.js +93 -93
  100. package/package.json +2 -2
  101. package/src/index.ts +46 -46
  102. package/src/tests/resources/sample-files1/sample.txt +4 -4
  103. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-1.txt +1 -1
  104. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-1/sampleFile1-1-2.txt +1 -1
  105. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-1.txt +1 -1
  106. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder1/sampleFolder1-2/sampleFile1-2-2.txt +1 -1
  107. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-1/sampleFile2-1-1.txt +1 -1
  108. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-1/sampleFile2-1-2.txt +1 -1
  109. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-2/sampleFile2-2-1.txt +1 -1
  110. package/src/tests/resources/sample-files1/sampleFolder/sampleFolder2/sampleFolder2-2/sampleFile2-2-2.txt +1 -1
  111. package/src/tests/resources/sample-files2/another-sample.txt +1 -1
  112. package/src/tests/theia-app.test.ts +33 -33
  113. package/src/tests/theia-application-shell.test.ts +67 -67
  114. package/src/tests/theia-explorer-view.test.ts +211 -211
  115. package/src/tests/theia-getting-started.test.ts +50 -50
  116. package/src/tests/theia-main-menu.test.ts +133 -133
  117. package/src/tests/theia-output-view.test.ts +85 -85
  118. package/src/tests/theia-preference-view.test.ts +122 -122
  119. package/src/tests/theia-problems-view.test.ts +64 -64
  120. package/src/tests/theia-quick-command.test.ts +80 -80
  121. package/src/tests/theia-sample-app.test.ts +66 -66
  122. package/src/tests/theia-status-bar.test.ts +52 -52
  123. package/src/tests/theia-terminal-view.test.ts +90 -90
  124. package/src/tests/theia-text-editor.test.ts +187 -187
  125. package/src/tests/theia-toolbar.test.ts +69 -69
  126. package/src/tests/theia-workspace.test.ts +80 -80
  127. package/src/theia-about-dialog.ts +26 -26
  128. package/src/theia-app-loader.ts +167 -167
  129. package/src/theia-app.ts +188 -188
  130. package/src/theia-context-menu.ts +42 -42
  131. package/src/theia-dialog.ts +114 -114
  132. package/src/theia-editor.ts +73 -73
  133. package/src/theia-explorer-view.ts +311 -311
  134. package/src/theia-main-menu.ts +54 -54
  135. package/src/theia-menu-item.ts +75 -75
  136. package/src/theia-menu.ts +96 -96
  137. package/src/theia-monaco-editor.ts +83 -83
  138. package/src/theia-notification-indicator.ts +44 -44
  139. package/src/theia-notification-overlay.ts +94 -94
  140. package/src/theia-output-channel.ts +88 -88
  141. package/src/theia-output-view.ts +87 -87
  142. package/src/theia-page-object.ts +29 -29
  143. package/src/theia-preference-view.ts +240 -240
  144. package/src/theia-problem-indicator.ts +37 -37
  145. package/src/theia-problem-view.ts +30 -30
  146. package/src/theia-quick-command-palette.ts +81 -81
  147. package/src/theia-rename-dialog.ts +35 -35
  148. package/src/theia-status-bar.ts +44 -44
  149. package/src/theia-status-indicator.ts +50 -50
  150. package/src/theia-terminal.ts +69 -69
  151. package/src/theia-text-editor.ts +141 -141
  152. package/src/theia-toggle-bottom-indicator.ts +21 -21
  153. package/src/theia-toolbar-item.ts +41 -41
  154. package/src/theia-toolbar.ts +99 -99
  155. package/src/theia-tree-node.ts +81 -81
  156. package/src/theia-view.ts +177 -177
  157. package/src/theia-welcome-view.ts +31 -31
  158. package/src/theia-workspace.ts +76 -76
  159. package/src/util.ts +91 -91
@@ -1,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
+ });
@@ -1,69 +1,69 @@
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 { TheiaToolbar } from '../theia-toolbar';
21
-
22
- let app: TheiaApp;
23
- let toolbar: TheiaToolbar;
24
-
25
- test.describe('Theia Toolbar', () => {
26
-
27
- test.beforeAll(async ({ playwright, browser }) => {
28
- app = await TheiaAppLoader.load({ playwright, browser });
29
- toolbar = new TheiaToolbar(app);
30
- });
31
-
32
- test.afterAll(async () => {
33
- await app.page.close();
34
- });
35
-
36
- test('should toggle the toolbar and check visibility', async () => {
37
- // depending on the user settings we have different starting conditions for the toolbar
38
- const isShownInitially = await toolbar.isShown();
39
- expect(await toolbar.isShown()).toBe(isShownInitially);
40
- await toolbar.toggle();
41
- expect(await toolbar.isShown()).toBe(!isShownInitially);
42
- await toolbar.hide();
43
- expect(await toolbar.isShown()).toBe(false);
44
- await toolbar.show();
45
- expect(await toolbar.isShown()).toBe(true);
46
- });
47
-
48
- test('should show the default toolbar tools of the sample Theia application', async () => {
49
- expect(await toolbar.toolbarItems()).toHaveLength(5);
50
- expect(await toolbar.toolbarItemIds()).toStrictEqual([
51
- 'textEditor.commands.go.back',
52
- 'textEditor.commands.go.forward',
53
- 'workbench.action.splitEditorRight',
54
- 'theia-sample-toolbar-contribution',
55
- 'workbench.action.showCommands'
56
- ]);
57
- });
58
-
59
- test('should trigger the "Command Palette" toolbar tool as expect the command palette to open', async () => {
60
- const commandPaletteTool = await toolbar.toolBarItem('workbench.action.showCommands');
61
- expect(commandPaletteTool).toBeDefined;
62
- expect(await commandPaletteTool!.isEnabled()).toBe(true);
63
-
64
- await commandPaletteTool!.trigger();
65
- expect(await app.quickCommandPalette.isOpen()).toBe(true);
66
- await app.quickCommandPalette.hide();
67
- expect(await app.quickCommandPalette.isOpen()).toBe(false);
68
- });
69
- });
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 { TheiaToolbar } from '../theia-toolbar';
21
+
22
+ let app: TheiaApp;
23
+ let toolbar: TheiaToolbar;
24
+
25
+ test.describe('Theia Toolbar', () => {
26
+
27
+ test.beforeAll(async ({ playwright, browser }) => {
28
+ app = await TheiaAppLoader.load({ playwright, browser });
29
+ toolbar = new TheiaToolbar(app);
30
+ });
31
+
32
+ test.afterAll(async () => {
33
+ await app.page.close();
34
+ });
35
+
36
+ test('should toggle the toolbar and check visibility', async () => {
37
+ // depending on the user settings we have different starting conditions for the toolbar
38
+ const isShownInitially = await toolbar.isShown();
39
+ expect(await toolbar.isShown()).toBe(isShownInitially);
40
+ await toolbar.toggle();
41
+ expect(await toolbar.isShown()).toBe(!isShownInitially);
42
+ await toolbar.hide();
43
+ expect(await toolbar.isShown()).toBe(false);
44
+ await toolbar.show();
45
+ expect(await toolbar.isShown()).toBe(true);
46
+ });
47
+
48
+ test('should show the default toolbar tools of the sample Theia application', async () => {
49
+ expect(await toolbar.toolbarItems()).toHaveLength(5);
50
+ expect(await toolbar.toolbarItemIds()).toStrictEqual([
51
+ 'textEditor.commands.go.back',
52
+ 'textEditor.commands.go.forward',
53
+ 'workbench.action.splitEditorRight',
54
+ 'theia-sample-toolbar-contribution',
55
+ 'workbench.action.showCommands'
56
+ ]);
57
+ });
58
+
59
+ test('should trigger the "Command Palette" toolbar tool as expect the command palette to open', async () => {
60
+ const commandPaletteTool = await toolbar.toolBarItem('workbench.action.showCommands');
61
+ expect(commandPaletteTool).toBeDefined;
62
+ expect(await commandPaletteTool!.isEnabled()).toBe(true);
63
+
64
+ await commandPaletteTool!.trigger();
65
+ expect(await app.quickCommandPalette.isOpen()).toBe(true);
66
+ await app.quickCommandPalette.hide();
67
+ expect(await app.quickCommandPalette.isOpen()).toBe(false);
68
+ });
69
+ });