-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathadvanced_color_test.ts
140 lines (115 loc) · 4.28 KB
/
advanced_color_test.ts
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
// Copyright 2023 mineejo. All rights reserved. MIT license.
import { assertEquals } from "./dev_deps.ts";
import { AdvancedColor } from "./advanced_color.ts";
import { Rgb } from "./color/mod.ts";
import { getTruncComponents } from "./util.ts";
Deno.test("class contains correct fields", async (t) => {
const red = 31;
const green = 10;
const blue = 0;
const hue = 10;
const saturation = 20;
const lightness = 30;
const color: AdvancedColor = new AdvancedColor(hue, saturation, lightness);
assertEquals(Math.trunc(color.red), red, `"color.red"`);
assertEquals(Math.trunc(color.green), green, `"color.green"`);
assertEquals(Math.trunc(color.blue), blue, `"color.blue"`);
assertEquals(color.hue, hue, `"color.hue"`);
assertEquals(color.saturation, saturation, `"color.saturation"`);
assertEquals(color.lightness, lightness, `"color.lightness"`);
await t.step("dependent field contains correct values", () => {
assertEquals(
getTruncComponents(color.rgbColor),
[red, green, blue],
`"color.rgbColor"`,
);
assertEquals(
getTruncComponents(color),
[red, green, blue],
`"color"`,
);
});
});
Deno.test("HSL conversion of red, green and blue correct", async (t) => {
const red: Rgb = [255, 0, 0];
const green: Rgb = [0, 255, 0];
const blue: Rgb = [0, 0, 255];
const hue: AdvancedColor = new AdvancedColor(0);
assertEquals(getTruncComponents(hue), red, `"hue"`);
await t.step("no lightness or saturation values do not change hue", () => {
const hueSaturation: AdvancedColor = new AdvancedColor(0, 100);
assertEquals(getTruncComponents(hueSaturation), red, `"hueSaturation"`);
const hueLightness: AdvancedColor = new AdvancedColor(0, undefined, 50);
assertEquals(getTruncComponents(hueLightness), red, `"hueLightness"`);
});
await t.step("default values do not change hue", () => {
const hueSaturationLightness: AdvancedColor = new AdvancedColor(0, 100, 50);
assertEquals(
getTruncComponents(hueSaturationLightness),
red,
`"hueSaturationLightness"`,
);
});
await t.step("hue range correct", () => {
const startRedColor: AdvancedColor = new AdvancedColor(0);
assertEquals(getTruncComponents(startRedColor), red, `"startRedColor"`);
const greenColor: AdvancedColor = new AdvancedColor(33.33);
assertEquals(getTruncComponents(greenColor), green, `"greenColor"`);
const blueColor: AdvancedColor = new AdvancedColor(66.66);
assertEquals(getTruncComponents(blueColor), blue, `"blueColor"`);
const endRedColor: AdvancedColor = new AdvancedColor(100);
assertEquals(getTruncComponents(endRedColor), red, `"endRedColor"`);
});
await t.step("saturation range correct", () => {
const redSaturated: Rgb = [255, 0, 0];
const saturatedColor: AdvancedColor = new AdvancedColor(0, 100);
assertEquals(
getTruncComponents(saturatedColor),
redSaturated,
`"saturatedColor"`,
);
const redUnsaturated: Rgb = [63, 63, 63];
const unsaturatedColor: AdvancedColor = new AdvancedColor(0, 0);
assertEquals(
getTruncComponents(unsaturatedColor),
redUnsaturated,
`"unsaturatedColor"`,
);
});
await t.step("lightness range correct", () => {
const black: Rgb = [0, 0, 0];
const blackColor: AdvancedColor = new AdvancedColor(0, undefined, 0);
assertEquals(
getTruncComponents(blackColor),
black,
`"blackColor"`,
);
const white: Rgb = [255, 255, 255];
const whiteColor: AdvancedColor = new AdvancedColor(0, undefined, 100);
assertEquals(
getTruncComponents(whiteColor),
white,
`"whiteColor"`,
);
});
});
for (let i = 0; i < 100; i++) {
const hue = new AdvancedColor(i, 100).components.toString()
.replace(/,/g, ";")
.replace(/\.\d+/gm, "");
const saturation = new AdvancedColor(i, 0).components.toString()
.replace(/,/g, ";")
.replace(/\.\d+/gm, "");
const lighntess = new AdvancedColor(i, undefined, 80).components.toString()
.replace(/,/g, ";")
.replace(/\.\d+/gm, "");
console.log(
`${i}.`.padEnd(4),
`[${hue}]`.padEnd(11),
`[${saturation}]`.padEnd(13),
`[${lighntess}]:`.padEnd(14),
`\x1b[48;2;${hue}m \x1b[0m`,
`\x1b[48;2;${saturation}m \x1b[0m`,
`\x1b[48;2;${lighntess}m \x1b[0m`,
);
}