File size: 1,083 Bytes
3a65265
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import { readFileSync } from "node:fs";
import { join } from "node:path";
import { describe, expect, test } from "vitest";

function readTerminalCss() {
  // This test is intentionally simple: it guards against regressions where the
  // docs header stops being sticky because sticky elements live inside an
  // overflow-clipped container.
  const path = join(process.cwd(), "docs", "assets", "terminal.css");
  return readFileSync(path, "utf8");
}

describe("docs terminal.css", () => {
  test("keeps the docs header sticky (shell is sticky)", () => {
    const css = readTerminalCss();
    expect(css).toMatch(/\.shell\s*\{[^}]*position:\s*sticky;[^}]*top:\s*0;[^}]*\}/s);
  });

  test("does not rely on making body overflow visible", () => {
    const css = readTerminalCss();
    expect(css).not.toMatch(/body\s*\{[^}]*overflow-x:\s*visible;[^}]*\}/s);
  });

  test("does not make the terminal frame overflow visible (can break layout)", () => {
    const css = readTerminalCss();
    expect(css).not.toMatch(/\.shell__frame\s*\{[^}]*overflow:\s*visible;[^}]*\}/s);
  });
});