aboutsummaryrefslogtreecommitdiff
path: root/e2e/lib/Console.ts
blob: 4d017cca5a2d2f71eddaea1702035d032ff55ada (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
import { WebDriver, By, Key } from "selenium-webdriver";

export type CompletionGroups = {
  title: string;
  items: Array<CompletionItem>;
};

export type CompletionItem = {
  text: string;
  highlight: boolean;
};

export class Console {
  constructor(private webdriver: WebDriver) {}

  async sendKeys(...keys: string[]) {
    const input = await this.webdriver.findElement(By.css("input"));
    input.sendKeys(...keys);
  }

  async currentValue() {
    return await this.webdriver.executeScript(() => {
      const input = document.querySelector("input");
      if (input === null) {
        throw new Error("could not find input element");
      }
      return input.value;
    });
  }

  async execCommand(command: string): Promise<void> {
    const input = await this.webdriver.findElement(By.css("input"));
    await input.sendKeys(command, Key.ENTER);
  }

  async getErrorMessage(): Promise<string> {
    const p = await this.webdriver.findElement(By.css("[role=alert]"));
    return p.getText();
  }

  async getInformationMessage(): Promise<string> {
    const p = await this.webdriver.findElement(By.css("[role=status]"));
    return p.getText();
  }

  async inputKeys(...keys: string[]) {
    const input = await this.webdriver.findElement(By.css("input"));
    await input.sendKeys(...keys);
  }

  getCompletions(): Promise<CompletionGroups[]> {
    return this.webdriver.executeScript(() => {
      const groups = document.querySelectorAll("[role=group]");
      if (groups.length === 0) {
        throw new Error("completion items not found");
      }

      return Array.from(groups).map((group) => {
        const describedby = group.getAttribute("aria-describedby") as string;
        const title = document.getElementById(describedby)!;
        const items = group.querySelectorAll("[role=menuitem]");

        return {
          title: title.textContent!.trim(),
          items: Array.from(items).map((item) => ({
            text: document.getElementById(
              item.getAttribute("aria-labelledby")!
            )!.textContent,
            highlight: item.getAttribute("aria-selected") === "true",
          })),
        };
      });
    });
  }

  async getTheme(): Promise<string> {
    const color = (await this.webdriver.executeScript(() => {
      const input = document.querySelector("input")!;
      return window.getComputedStyle(input).backgroundColor;
    })) as string;
    if (color === "rgb(5, 32, 39)") {
      return "dark";
    } else if (color === "rgb(255, 255, 255)") {
      return "light";
    }
    throw new Error(`unknown input color: ${color}`);
  }

  async close(): Promise<void> {
    const input = await this.webdriver.findElement(By.css("input"));
    await input.sendKeys(Key.ESCAPE);
    // TODO remove sleep
    await new Promise((resolve) => setTimeout(resolve, 100));
    await (this.webdriver.switchTo() as any).parentFrame();
  }
}