Skip to content

Commit

Permalink
issue-835: Fix could not paste from clipboard issue only on Windows
Browse files Browse the repository at this point in the history
Signed-off-by: Dominik Jelinek <[email protected]>
  • Loading branch information
djelinek committed Jun 8, 2023
1 parent e4f15ee commit 2564a8d
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 10 deletions.
12 changes: 10 additions & 2 deletions page-objects/src/components/bottomBar/AbstractViews.ts
Original file line number Diff line number Diff line change
Expand Up @@ -92,14 +92,22 @@ export abstract class TextView extends ChannelView {
* @returns Promise resolving to the view's text
*/
async getText(): Promise<string> {
const originalClipboard = clipboard.readSync();
let originalClipboard = '';
try {
originalClipboard = clipboard.readSync();
} catch (error) {
// workaround issue https://github.com/redhat-developer/vscode-extension-tester/issues/835
// do not fail if clipboard is empty
}
let textarea = await this.findElement(ChannelView.locators.BottomBarViews.textArea);
await textarea.sendKeys(Key.chord(TextView.ctlKey, 'a'));
await textarea.sendKeys(Key.chord(TextView.ctlKey, 'c'));
const text = clipboard.readSync();
// workaround as we are getting "element click intercepted" during the send keys actions.
// await textarea.click();
clipboard.writeSync(originalClipboard);
if(originalClipboard.length > 0) {
clipboard.writeSync(originalClipboard);
}
return text;
}

Expand Down
12 changes: 10 additions & 2 deletions page-objects/src/components/bottomBar/Views.ts
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,13 @@ export class TerminalView extends ChannelView {
* @returns Promise resolving to all terminal text
*/
async getText(): Promise<string> {
const originalClipboard = clipboard.readSync();
let originalClipboard = '';
try {
originalClipboard = clipboard.readSync();
} catch (error) {
// workaround issue https://github.com/redhat-developer/vscode-extension-tester/issues/835
// do not fail if clipboard is empty
}
const workbench = new Workbench();
await workbench.executeCommand('terminal select all');
await workbench.getDriver().sleep(500);
Expand All @@ -138,7 +144,9 @@ export class TerminalView extends ChannelView {
await workbench.getDriver().sleep(500);
}
const text = clipboard.readSync();
clipboard.writeSync(originalClipboard);
if(originalClipboard.length > 0) {
clipboard.writeSync(originalClipboard);
}
return text;
}

Expand Down
36 changes: 30 additions & 6 deletions page-objects/src/components/editor/TextEditor.ts
Original file line number Diff line number Diff line change
Expand Up @@ -100,13 +100,21 @@ export class TextEditor extends Editor {
* @returns Promise resolving to editor text
*/
async getText(): Promise<string> {
const originalClipboard = clipboard.readSync();
let originalClipboard = '';
try {
originalClipboard = clipboard.readSync();
} catch (error) {
// workaround issue https://github.com/redhat-developer/vscode-extension-tester/issues/835
// do not fail if clipboard is empty
}
const inputarea = await this.findElement(TextEditor.locators.Editor.inputArea);
await inputarea.sendKeys(Key.chord(TextEditor.ctlKey, 'a'), Key.chord(TextEditor.ctlKey, 'c'));
await new Promise(res => setTimeout(res, 500));
const text = clipboard.readSync();
await inputarea.sendKeys(Key.UP);
clipboard.writeSync(originalClipboard);
if(originalClipboard.length > 0) {
clipboard.writeSync(originalClipboard);
}
return text;
}

Expand All @@ -117,11 +125,19 @@ export class TextEditor extends Editor {
* @returns Promise resolving once the new text is copied over
*/
async setText(text: string, formatText: boolean = false): Promise<void> {
const originalClipboard = clipboard.readSync();
let originalClipboard = '';
try {
originalClipboard = clipboard.readSync();
} catch (error) {
// workaround issue https://github.com/redhat-developer/vscode-extension-tester/issues/835
// do not fail if clipboard is empty
}
const inputarea = await this.findElement(TextEditor.locators.Editor.inputArea);
clipboard.writeSync(text);
await inputarea.sendKeys(Key.chord(TextEditor.ctlKey, 'a'), Key.chord(TextEditor.ctlKey, 'v'));
clipboard.writeSync(originalClipboard);
if(originalClipboard.length > 0) {
clipboard.writeSync(originalClipboard);
}
if (formatText) {
await this.formatDocument();
}
Expand Down Expand Up @@ -225,7 +241,13 @@ export class TextEditor extends Editor {
* Get the text that is currently selected as string
*/
async getSelectedText(): Promise<string> {
const originalClipboard = clipboard.readSync();
let originalClipboard = '';
try {
originalClipboard = clipboard.readSync();
} catch (error) {
// workaround issue https://github.com/redhat-developer/vscode-extension-tester/issues/835
// do not fail if clipboard is empty
}
if(process.platform !== 'darwin') {
const selection = await this.getSelection();
if (!selection) {
Expand All @@ -241,7 +263,9 @@ export class TextEditor extends Editor {
}
await new Promise(res => setTimeout(res, 500));
const text = clipboard.readSync();
clipboard.writeSync(originalClipboard);
if(originalClipboard.length > 0) {
clipboard.writeSync(originalClipboard);
}
return text;
}

Expand Down

0 comments on commit 2564a8d

Please sign in to comment.