File: test-colours.cc

package info (click to toggle)
conky 1.22.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 10,376 kB
  • sloc: cpp: 64,271; ansic: 18,382; python: 813; xml: 324; sh: 248; makefile: 143; javascript: 139
file content (111 lines) | stat: -rw-r--r-- 3,069 bytes parent folder | download | duplicates (2)
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
#include "catch2/catch.hpp"

#include <content/colours.hh>
#include <config.h>

TEST_CASE("parse_color correctly parses colours", "[colours][parse_color]") {
  SECTION("parsing abbreviated hex color") {
    auto colour = parse_color("#abc");
    REQUIRE(colour.alpha == 255);
    REQUIRE(colour.red == 0xaa);
    REQUIRE(colour.green == 0xbb);
    REQUIRE(colour.blue == 0xcc);
  }

  SECTION("parsing abbreviated hex color with alpha") {
    auto colour = parse_color("#4abc");
    REQUIRE(colour.alpha == 0x44);
    REQUIRE(colour.red == 0xaa);
    REQUIRE(colour.green == 0xbb);
    REQUIRE(colour.blue == 0xcc);
  }

  SECTION("parsing hex red") {
    auto colour = parse_color("#ff0000");
    REQUIRE(colour.alpha == 255);
    REQUIRE(colour.red == 255);
    REQUIRE(colour.green == 0);
    REQUIRE(colour.blue == 0);
  }

  SECTION("parsing hex green") {
    auto colour = parse_color("#00ff00");
    REQUIRE(colour.alpha == 255);
    REQUIRE(colour.red == 0);
    REQUIRE(colour.green == 255);
    REQUIRE(colour.blue == 0);
  }

  SECTION("parsing hex blue") {
    auto colour = parse_color("#0000ff");
    REQUIRE(colour.alpha == 255);
    REQUIRE(colour.red == 0);
    REQUIRE(colour.green == 0);
    REQUIRE(colour.blue == 255);
  }

  SECTION("parsing red") {
    auto colour = parse_color("ff0000");
    REQUIRE(colour.alpha == 255);
    REQUIRE(colour.red == 255);
    REQUIRE(colour.green == 0);
    REQUIRE(colour.blue == 0);
  }

  SECTION("parsing green") {
    auto colour = parse_color("00ff00");
    REQUIRE(colour.alpha == 255);
    REQUIRE(colour.red == 0);
    REQUIRE(colour.green == 255);
    REQUIRE(colour.blue == 0);
  }

  SECTION("parsing blue") {
    auto colour = parse_color("0000ff");
    REQUIRE(colour.alpha == 255);
    REQUIRE(colour.red == 0);
    REQUIRE(colour.green == 0);
    REQUIRE(colour.blue == 255);
  }

  SECTION("argb values produce the expected result") {
    auto colour = Colour::from_argb32(0x11223344);
    REQUIRE(colour.alpha == 0x11);
    REQUIRE(colour.red == 0x22);
    REQUIRE(colour.green == 0x33);
    REQUIRE(colour.blue == 0x44);
  }

#ifdef BUILD_COLOUR_NAME_MAP
  SECTION("it parses the colour 'red'") {
    auto colour = parse_color("red");
    REQUIRE(colour.alpha == 255);
    REQUIRE(colour.red == 255);
    REQUIRE(colour.green == 0);
    REQUIRE(colour.blue == 0);
  }

  SECTION("it parses the colour 'green'") {
    auto colour = parse_color("green");
    REQUIRE(colour.alpha == 255);
    REQUIRE(colour.red == 0);
    REQUIRE(colour.green == 255);
    REQUIRE(colour.blue == 0);
  }

  SECTION("it parses the colour 'blue'") {
    auto colour = parse_color("blue");
    REQUIRE(colour.alpha == 255);
    REQUIRE(colour.red == 0);
    REQUIRE(colour.green == 0);
    REQUIRE(colour.blue == 255);
  }
#endif /* BUILD_COLOUR_NAME_MAP */

  SECTION("two identical colours should be equal") {
    auto c = GENERATE(take(100, random((uint32_t)0, (uint32_t)0xffffffff)));
    auto colour1 = Colour::from_argb32(c);
    auto colour2 = Colour::from_argb32(c);
    REQUIRE(colour1 == colour2);
  }
}