-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathplugin_test.ts
More file actions
49 lines (41 loc) · 1.3 KB
/
plugin_test.ts
File metadata and controls
49 lines (41 loc) · 1.3 KB
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
import { assertEquals } from "@std/assert";
import plugin from "./plugin.ts";
Deno.test("no-inline-styles - catches inline style object", () => {
const diagnostics = Deno.lint.runPlugin(
plugin,
"component.tsx",
'<div style={{ color: "red" }}>Content</div>',
);
assertEquals(diagnostics.length, 1);
const d = diagnostics[0];
assertEquals(d.id, "no-inline-styles/no-inline-styles");
assertEquals(
d.message,
"Inline styles are not allowed. Use CSS classes (Tailwind, CSS modules, etc.) instead.",
);
});
Deno.test("no-inline-styles - catches inline style string", () => {
const diagnostics = Deno.lint.runPlugin(
plugin,
"component.tsx",
'<div style="color: red;">Content</div>',
);
assertEquals(diagnostics.length, 1);
assertEquals(diagnostics[0].id, "no-inline-styles/no-inline-styles");
});
Deno.test("no-inline-styles - allows className", () => {
const diagnostics = Deno.lint.runPlugin(
plugin,
"component.tsx",
'<div className="text-red-500">Content</div>',
);
assertEquals(diagnostics.length, 0);
});
Deno.test("no-inline-styles - allows other attributes", () => {
const diagnostics = Deno.lint.runPlugin(
plugin,
"component.tsx",
'<div id="test" data-value="123">Content</div>',
);
assertEquals(diagnostics.length, 0);
});