[mutter] tests/color: Add test for night light



commit 1adbb686bc4af35faf969b40ff86eaeba0d7888a
Author: Jonas Ã…dahl <jadahl gmail com>
Date:   Mon Dec 6 22:00:02 2021 +0100

    tests/color: Add test for night light
    
    This mocks gsd-colord to enable night ligth at a given temperature. The
    test then verifies that the result exactly matches that of the gamma
    ramps gsd-color generated for the same temperature and ICC profile.
    
    There are two types of profiles tested; ones with VCGT, i.e. calibrated
    profiles, and ones without. These are tested as the VCGT affects how the
    gamma curve looks, while the non-VCGT profiles all only rely on
    the blackbody temperature to generate a gamma ramp.
    
    Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/2165>

 src/tests/color-management-tests.c          | 629 ++++++++++++++++++++++++++++
 src/tests/dbusmock-templates/gsd-color.py   |   9 +
 src/tests/icc-profiles/vx239-calibrated.icc | Bin 0 -> 3068 bytes
 3 files changed, 638 insertions(+)
---
diff --git a/src/tests/color-management-tests.c b/src/tests/color-management-tests.c
index 12509514c0..9d838630e6 100644
--- a/src/tests/color-management-tests.c
+++ b/src/tests/color-management-tests.c
@@ -30,6 +30,7 @@ static MetaContext *test_context;
 
 /* Profile ID is 'icc-$(md5sum sRGB.icc)' */
 #define SRGB_ICC_PROFILE_ID "icc-112034c661b5e0c91c51f109684612a0";
+#define VX239_ICC_PROFILE_ID "icc-c5e479355c02452dd30c1256a154a8f4";
 
 #define PRIMARY_EPSILON 0.000015
 
@@ -180,6 +181,71 @@ add_colord_system_profile (const char *cd_profile_id,
     g_error ("Failed to add system profile: %s", error->message);
 }
 
+static GDBusProxy *
+get_gsd_color_mock_proxy (void)
+{
+  GDBusProxy *proxy;
+  g_autoptr (GError) error = NULL;
+  g_autoptr (GVariant) ret = NULL;
+
+  proxy =
+    g_dbus_proxy_new_for_bus_sync (G_BUS_TYPE_SESSION,
+                                   G_DBUS_PROXY_FLAGS_DO_NOT_AUTO_START |
+                                   G_DBUS_PROXY_FLAGS_DO_NOT_CONNECT_SIGNALS,
+                                   NULL,
+                                   "org.gnome.SettingsDaemon.Color",
+                                   "/org/gnome/SettingsDaemon/Color",
+                                   "org.freedesktop.DBus.Mock",
+                                   NULL, &error);
+  if (!proxy)
+    {
+      g_error ("Failed to find mocked gsd-color service, %s",
+               error->message);
+    }
+
+  return proxy;
+}
+
+static void
+set_night_light_temperature (unsigned int temperature)
+{
+  GDBusProxy *proxy;
+  g_autoptr (GError) error = NULL;
+  GVariantBuilder params_builder;
+
+  proxy = get_gsd_color_mock_proxy ();
+
+  g_variant_builder_init (&params_builder, G_VARIANT_TYPE ("(u)"));
+  g_variant_builder_add (&params_builder, "u", temperature);
+
+  if (!g_dbus_proxy_call_sync (proxy,
+                               "SetTemperature",
+                               g_variant_builder_end (&params_builder),
+                               G_DBUS_CALL_FLAGS_NO_AUTO_START, -1, NULL,
+                               &error))
+    g_error ("Failed to set gsd-color temperature devices: %s", error->message);
+}
+
+static void
+set_night_light_active (gboolean active)
+{
+  GDBusProxy *proxy;
+  g_autoptr (GError) error = NULL;
+  GVariantBuilder params_builder;
+
+  proxy = get_gsd_color_mock_proxy ();
+
+  g_variant_builder_init (&params_builder, G_VARIANT_TYPE ("(b)"));
+  g_variant_builder_add (&params_builder, "b", active);
+
+  if (!g_dbus_proxy_call_sync (proxy,
+                               "SetNightLightActive",
+                               g_variant_builder_end (&params_builder),
+                               G_DBUS_CALL_FLAGS_NO_AUTO_START, -1, NULL,
+                               &error))
+    g_error ("Failed to set enable or disable night light: %s", error->message);
+}
+
 static void
 prepare_color_test (void)
 {
@@ -449,6 +515,565 @@ meta_test_color_management_profile_system (void)
                    srgb_profile_id);
 }
 
+static void
+wait_for_profile_assigned (MetaColorDevice *color_device,
+                           const char      *profile_id)
+{
+  while (TRUE)
+    {
+      MetaColorProfile *color_profile;
+
+      color_profile = meta_color_device_get_assigned_profile (color_device);
+      if (color_profile &&
+          g_strcmp0 (meta_color_profile_get_id (color_profile),
+                     profile_id) == 0)
+        break;
+
+      g_main_context_iteration (NULL, TRUE);
+    }
+}
+
+static void
+on_device_updated (MetaColorDevice *color_device,
+                   gboolean        *run)
+{
+  *run = FALSE;
+}
+
+static void
+wait_for_device_updated (MetaColorDevice *color_device)
+{
+  gulong handler_id;
+  gboolean run = TRUE;
+
+  handler_id = g_signal_connect (color_device, "updated",
+                                 G_CALLBACK (on_device_updated),
+                                 &run);
+  while (run)
+    g_main_context_iteration (NULL, TRUE);
+
+  g_signal_handler_disconnect (color_device, handler_id);
+}
+
+static void
+assert_gamma_array (uint16_t *expected,
+                    uint16_t *values,
+                    size_t    size)
+{
+  size_t i;
+
+  for (i = 0; i < size; i++)
+    {
+      if (expected[i] != values[i])
+        {
+          g_error ("Expected %hu at but got %hu at index %zu",
+                   expected[i], values[i], i);
+        }
+    }
+}
+
+static void
+meta_test_color_management_night_light_calibrated (void)
+{
+  MetaBackend *backend = meta_context_get_backend (test_context);
+  MetaMonitorManager *monitor_manager =
+    meta_backend_get_monitor_manager (backend);
+  MetaMonitorManagerTest *monitor_manager_test =
+    META_MONITOR_MANAGER_TEST (monitor_manager);
+  MetaColorManager *color_manager =
+    meta_backend_get_color_manager (backend);
+  MetaEdidInfo edid_info;
+  MonitorTestCaseSetup test_case_setup = base_monitor_setup;
+  MetaMonitorTestSetup *test_setup;
+  MetaMonitor *monitor;
+  MetaOutput *output;
+  MetaCrtc *crtc;
+  MetaCrtcTest *crtc_test;
+  MetaColorDevice *color_device;
+  const char *path;
+  const char *color_profiles[1];
+  const char *profile_id = VX239_ICC_PROFILE_ID;
+
+  /* Night light disabled */
+  uint16_t night_light_off_red[] = {
+    0, 248, 499, 751, 1002, 1255, 1508, 1761, 2016, 2271, 2527, 2783, 3040,
+    3298, 3556, 3814, 4074, 4333, 4593, 4854, 5114, 5375, 5636, 5897, 6160,
+    6422, 6685, 6947, 7212, 7479, 7745, 8013, 8282, 8553, 8824, 9095, 9367,
+    9641, 9915, 10189, 10465, 10741, 11016, 11292, 11571, 11847, 12125, 12403,
+    12681, 12960, 13238, 13516, 13798, 14084, 14377, 14672, 14974, 15279,
+    15586, 15896, 16209, 16523, 16840, 17156, 17475, 17792, 18109, 18426,
+    18740, 19054, 19364, 19673, 19977, 20278, 20577, 20868, 21156, 21438,
+    21709, 21970, 22220, 22461, 22695, 22922, 23143, 23357, 23568, 23776,
+    23979, 24182, 24382, 24584, 24786, 24989, 25195, 25404, 25617, 25836,
+    26060, 26290, 26529, 26776, 27032, 27298, 27573, 27857, 28148, 28444,
+    28748, 29055, 29368, 29686, 30004, 30327, 30650, 30975, 31300, 31624,
+    31948, 32268, 32587, 32902, 33213, 33519, 33818, 34112, 34399, 34678,
+    34949, 35206, 35450, 35683, 35905, 36119, 36325, 36523, 36714, 36901,
+    37086, 37267, 37445, 37625, 37805, 37985, 38169, 38359, 38552, 38750,
+    38957, 39172, 39398, 39633, 39880, 40140, 40417, 40712, 41026, 41356,
+    41700, 42055, 42424, 42799, 43185, 43574, 43970, 44366, 44765, 45162,
+    45558, 45948, 46335, 46712, 47083, 47440, 47788, 48121, 48437, 48736,
+    49017, 49280, 49529, 49768, 49999, 50221, 50436, 50645, 50848, 51044,
+    51238, 51429, 51617, 51803, 51989, 52176, 52363, 52550, 52742, 52938,
+    53138, 53342, 53553, 53771, 53998, 54232, 54476, 54730, 54993, 55266,
+    55546, 55832, 56125, 56423, 56727, 57033, 57342, 57652, 57964, 58277,
+    58588, 58897, 59205, 59509, 59811, 60106, 60396, 60678, 60954, 61221,
+    61479, 61728, 61965, 62195, 62415, 62627, 62829, 63024, 63213, 63393,
+    63564, 63730, 63888, 64038, 64183, 64320, 64453, 64577, 64697, 64810,
+    64919, 65022, 65118, 65211, 65298, 65381, 65461, 65535
+  };
+  uint16_t night_light_off_green[] = {
+    0, 147, 297, 451, 607, 767, 928, 1094, 1262, 1433, 1608, 1785, 1967, 2152,
+    2339, 2530, 2724, 2923, 3124, 3329, 3537, 3749, 3966, 4186, 4409, 4636,
+    4867, 5109, 5358, 5618, 5884, 6156, 6434, 6718, 7004, 7294, 7584, 7876,
+    8168, 8459, 8750, 9035, 9320, 9598, 9870, 10137, 10396, 10647, 10889,
+    11121, 11341, 11550, 11753, 11955, 12158, 12359, 12561, 12764, 12967,
+    13170, 13372, 13573, 13776, 13978, 14182, 14384, 14586, 14788, 14990,
+    15193, 15396, 15598, 15801, 16002, 16204, 16407, 16610, 16812, 17015,
+    17217, 17419, 17622, 17824, 18027, 18228, 18431, 18634, 18835, 19039,
+    19240, 19444, 19645, 19847, 20051, 20252, 20456, 20657, 20860, 21063,
+    21264, 21468, 21669, 21872, 22077, 22288, 22506, 22728, 22953, 23183,
+    23418, 23655, 23895, 24137, 24380, 24625, 24872, 25119, 25366, 25612,
+    25858, 26104, 26346, 26587, 26825, 27059, 27291, 27519, 27743, 27960,
+    28175, 28386, 28593, 28798, 29000, 29198, 29397, 29592, 29788, 29980,
+    30175, 30366, 30561, 30753, 30949, 31143, 31341, 31539, 31741, 31945,
+    32150, 32361, 32573, 32791, 33013, 33238, 33466, 33697, 33929, 34163,
+    34399, 34637, 34876, 35116, 35356, 35597, 35839, 36081, 36322, 36562,
+    36802, 37040, 37278, 37514, 37747, 37979, 38209, 38436, 38661, 38884,
+    39103, 39321, 39538, 39757, 39975, 40194, 40413, 40632, 40850, 41068,
+    41286, 41504, 41724, 41942, 42161, 42379, 42597, 42815, 43034, 43253,
+    43472, 43690, 43908, 44126, 44344, 44563, 44782, 45001, 45219, 45437,
+    45655, 45873, 46092, 46311, 46530, 46748, 46966, 47184, 47403, 47621,
+    47841, 48059, 48277, 48495, 48713, 48932, 49151, 49370, 49588, 49807,
+    50024, 50242, 50461, 50680, 50899, 51117, 51336, 51553, 51772, 51990,
+    52210, 52428, 52646, 52865, 53082, 53301, 53519, 53739, 53957, 54176,
+    54393, 54611, 54830, 55048, 55268, 55486, 55705
+  };
+  uint16_t night_light_off_blue[] = {
+    0, 137, 277, 419, 564, 712, 864, 1019, 1180, 1343, 1511, 1684, 1862, 2046,
+    2235, 2431, 2632, 2840, 3055, 3277, 3506, 3743, 3988, 4243, 4505, 4775,
+    5055, 5342, 5631, 5927, 6227, 6529, 6836, 7145, 7456, 7771, 8086, 8401,
+    8718, 9035, 9352, 9668, 9983, 10298, 10609, 10918, 11223, 11526, 11827,
+    12121, 12412, 12696, 12980, 13262, 13545, 13826, 14108, 14390, 14670,
+    14951, 15231, 15509, 15787, 16063, 16339, 16615, 16888, 17159, 17429,
+    17699, 17966, 18232, 18497, 18759, 19019, 19277, 19533, 19787, 20034,
+    20275, 20512, 20744, 20973, 21197, 21417, 21635, 21851, 22064, 22277,
+    22490, 22701, 22913, 23126, 23339, 23554, 23772, 23991, 24214, 24442,
+    24673, 24908, 25148, 25394, 25645, 25902, 26162, 26427, 26697, 26968,
+    27243, 27519, 27798, 28078, 28362, 28645, 28927, 29211, 29494, 29778,
+    30060, 30339, 30617, 30894, 31169, 31439, 31707, 31970, 32230, 32485,
+    32733, 32975, 33211, 33442, 33669, 33890, 34109, 34325, 34540, 34752,
+    34963, 35172, 35381, 35592, 35804, 36017, 36232, 36448, 36669, 36893,
+    37122, 37357, 37596, 37841, 38092, 38353, 38626, 38908, 39200, 39500,
+    39809, 40124, 40443, 40767, 41095, 41426, 41756, 42088, 42421, 42751,
+    43077, 43402, 43722, 44035, 44342, 44642, 44935, 45217, 45489, 45749,
+    45998, 46240, 46478, 46711, 46940, 47167, 47390, 47611, 47829, 48046,
+    48261, 48474, 48687, 48901, 49115, 49330, 49546, 49762, 49981, 50203,
+    50428, 50656, 50888, 51123, 51364, 51609, 51857, 52105, 52353, 52601,
+    52850, 53100, 53351, 53602, 53853, 54106, 54359, 54613, 54868, 55124,
+    55381, 55639, 55899, 56159, 56422, 56685, 56950, 57217, 57485, 57755,
+    58026, 58299, 58575, 58852, 59132, 59412, 59696, 59981, 60267, 60556,
+    60845, 61136, 61427, 61718, 62011, 62305, 62600, 62894, 63188, 63483,
+    63776, 64071, 64364, 64659, 64952, 65244, 65535
+  };
+  /* Night light at 3305K */
+  uint16_t night_light_on_red[] = {
+    0, 248, 499, 751, 1002, 1255, 1508, 1761, 2016, 2271, 2527, 2783, 3040,
+    3298, 3556, 3814, 4074, 4333, 4593, 4854, 5114, 5375, 5636, 5897, 6160,
+    6422, 6685, 6947, 7212, 7479, 7745, 8013, 8282, 8553, 8824, 9095, 9367,
+    9641, 9915, 10189, 10465, 10741, 11016, 11292, 11571, 11847, 12125, 12403,
+    12681, 12960, 13238, 13516, 13798, 14084, 14377, 14672, 14974, 15279,
+    15586, 15896, 16209, 16523, 16840, 17156, 17475, 17792, 18109, 18426,
+    18740, 19054, 19364, 19673, 19977, 20278, 20577, 20868, 21156, 21438,
+    21709, 21970, 22220, 22461, 22695, 22922, 23143, 23357, 23568, 23776,
+    23979, 24182, 24382, 24584, 24786, 24989, 25195, 25404, 25617, 25836,
+    26060, 26290, 26529, 26776, 27032, 27298, 27573, 27857, 28148, 28444,
+    28748, 29055, 29368, 29686, 30004, 30327, 30650, 30975, 31300, 31624,
+    31948, 32268, 32587, 32902, 33213, 33519, 33818, 34112, 34399, 34678,
+    34949, 35206, 35450, 35683, 35905, 36119, 36325, 36523, 36714, 36901,
+    37086, 37267, 37445, 37625, 37805, 37985, 38169, 38359, 38552, 38750,
+    38957, 39172, 39398, 39633, 39880, 40140, 40417, 40712, 41026, 41356,
+    41700, 42055, 42424, 42799, 43185, 43574, 43970, 44366, 44765, 45162,
+    45558, 45948, 46335, 46712, 47083, 47440, 47788, 48121, 48437, 48736,
+    49017, 49280, 49529, 49768, 49999, 50221, 50436, 50645, 50848, 51044,
+    51238, 51429, 51617, 51803, 51989, 52176, 52363, 52550, 52742, 52938,
+    53138, 53342, 53553, 53771, 53998, 54232, 54476, 54730, 54993, 55266,
+    55546, 55832, 56125, 56423, 56727, 57033, 57342, 57652, 57964, 58277,
+    58588, 58897, 59205, 59509, 59811, 60106, 60396, 60678, 60954, 61221,
+    61479, 61728, 61965, 62195, 62415, 62627, 62829, 63024, 63213, 63393,
+    63564, 63730, 63888, 64038, 64183, 64320, 64453, 64577, 64697, 64810,
+    64919, 65022, 65118, 65211, 65298, 65381, 65461, 65535,
+  };
+  uint16_t night_light_on_green[] = {
+    0, 112, 225, 341, 460, 581, 704, 829, 956, 1086, 1219, 1353, 1490, 1631,
+    1773, 1918, 2065, 2215, 2368, 2524, 2681, 2842, 3006, 3172, 3341, 3513,
+    3689, 3872, 4061, 4258, 4459, 4666, 4877, 5092, 5308, 5528, 5749, 5970,
+    6191, 6412, 6632, 6849, 7064, 7275, 7481, 7684, 7880, 8070, 8254, 8429,
+    8596, 8755, 8908, 9061, 9215, 9368, 9521, 9675, 9828, 9982, 10135, 10288,
+    10442, 10595, 10749, 10902, 11055, 11209, 11362, 11516, 11669, 11822,
+    11976, 12129, 12282, 12436, 12589, 12743, 12896, 13050, 13203, 13357,
+    13510, 13664, 13817, 13970, 14124, 14277, 14431, 14584, 14738, 14891,
+    15044, 15198, 15351, 15505, 15658, 15811, 15965, 16118, 16272, 16425,
+    16578, 16734, 16894, 17058, 17227, 17398, 17572, 17750, 17929, 18111,
+    18295, 18480, 18665, 18853, 19040, 19227, 19414, 19600, 19786, 19969,
+    20152, 20332, 20510, 20686, 20858, 21028, 21193, 21356, 21515, 21673,
+    21828, 21981, 22132, 22282, 22430, 22578, 22724, 22871, 23017, 23164,
+    23310, 23458, 23606, 23755, 23906, 24058, 24213, 24369, 24528, 24690,
+    24855, 25023, 25193, 25366, 25541, 25717, 25895, 26074, 26254, 26435,
+    26617, 26799, 26982, 27165, 27348, 27531, 27713, 27894, 28075, 28255,
+    28434, 28612, 28787, 28962, 29134, 29304, 29473, 29639, 29804, 29969,
+    30135, 30300, 30466, 30632, 30798, 30963, 31129, 31294, 31459, 31625,
+    31790, 31956, 32122, 32288, 32453, 32619, 32784, 32950, 33115, 33281,
+    33447, 33612, 33778, 33943, 34109, 34274, 34440, 34606, 34771, 34937,
+    35102, 35268, 35433, 35599, 35765, 35931, 36096, 36262, 36427, 36592,
+    36758, 36923, 37089, 37255, 37421, 37586, 37752, 37917, 38082, 38248,
+    38414, 38580, 38745, 38911, 39076, 39242, 39407, 39573, 39739, 39904,
+    40070, 40235, 40401, 40566, 40732, 40898, 41064, 41229, 41394, 41560,
+    41725, 41891, 42057, 42222
+  };
+  uint16_t night_light_on_blue[] = {
+    0, 69, 139, 211, 283, 358, 434, 512, 593, 675, 759, 846, 935, 1028, 1123,
+    1221, 1322, 1427, 1535, 1647, 1762, 1881, 2005, 2132, 2264, 2400, 2541,
+    2685, 2830, 2979, 3129, 3282, 3436, 3591, 3748, 3906, 4064, 4223, 4382,
+    4541, 4701, 4860, 5018, 5176, 5332, 5487, 5641, 5793, 5944, 6093, 6238,
+    6382, 6524, 6666, 6808, 6950, 7091, 7232, 7374, 7514, 7655, 7795, 7935,
+    8074, 8213, 8351, 8488, 8625, 8761, 8896, 9030, 9164, 9297, 9429, 9559,
+    9689, 9818, 9945, 10069, 10191, 10310, 10427, 10541, 10654, 10765, 10875,
+    10983, 11090, 11197, 11304, 11410, 11517, 11624, 11731, 11839, 11948,
+    12059, 12171, 12285, 12401, 12519, 12640, 12764, 12890, 13019, 13150,
+    13283, 13418, 13555, 13693, 13832, 13972, 14113, 14255, 14398, 14540,
+    14683, 14825, 14967, 15109, 15250, 15389, 15529, 15666, 15802, 15937,
+    16069, 16200, 16328, 16452, 16574, 16693, 16809, 16923, 17034, 17145,
+    17253, 17361, 17467, 17573, 17679, 17784, 17890, 17996, 18103, 18211,
+    18320, 18431, 18544, 18659, 18777, 18897, 19020, 19146, 19277, 19414,
+    19556, 19703, 19854, 20009, 20167, 20328, 20491, 20655, 20822, 20988,
+    21155, 21322, 21488, 21652, 21815, 21976, 22134, 22288, 22439, 22586,
+    22727, 22864, 22995, 23120, 23242, 23361, 23479, 23594, 23708, 23820,
+    23931, 24040, 24149, 24257, 24365, 24472, 24580, 24687, 24795, 24903,
+    25012, 25122, 25234, 25347, 25461, 25578, 25696, 25817, 25940, 26065,
+    26190, 26314, 26439, 26565, 26690, 26816, 26943, 27069, 27196, 27323,
+    27451, 27579, 27708, 27837, 27966, 28097, 28228, 28360, 28492, 28625,
+    28759, 28894, 29029, 29166, 29303, 29442, 29581, 29722, 29863, 30006,
+    30149, 30293, 30437, 30583, 30729, 30875, 31022, 31169, 31317, 31465,
+    31613, 31760, 31909, 32056, 32205, 32352, 32500, 32647, 32794, 32940
+  };
+  unsigned int temperature = 3305;
+
+  G_STATIC_ASSERT (G_N_ELEMENTS (night_light_off_red) ==
+                   G_N_ELEMENTS (night_light_off_green));
+  G_STATIC_ASSERT (G_N_ELEMENTS (night_light_off_red) ==
+                   G_N_ELEMENTS (night_light_off_blue));
+  G_STATIC_ASSERT (G_N_ELEMENTS (night_light_off_red) ==
+                   G_N_ELEMENTS (night_light_on_red));
+  G_STATIC_ASSERT (G_N_ELEMENTS (night_light_off_red) ==
+                   G_N_ELEMENTS (night_light_on_green));
+  G_STATIC_ASSERT (G_N_ELEMENTS (night_light_off_red) ==
+                   G_N_ELEMENTS (night_light_on_blue));
+
+  edid_info = ANCOR_VX239_EDID;
+  test_case_setup.outputs[0].edid_info = edid_info;
+  test_case_setup.outputs[0].has_edid_info = TRUE;
+  test_setup = meta_create_monitor_test_setup (backend, &test_case_setup,
+                                               MONITOR_TEST_FLAG_NO_STORED);
+  meta_monitor_manager_test_emulate_hotplug (monitor_manager_test, test_setup);
+
+  monitor = meta_monitor_manager_get_monitors (monitor_manager)->data;
+  color_device = meta_color_manager_get_color_device (color_manager, monitor);
+  g_assert_nonnull (color_device);
+
+  while (!meta_color_device_is_ready (color_device))
+    g_main_context_iteration (NULL, TRUE);
+
+  set_night_light_temperature (6500);
+  set_night_light_active (FALSE);
+  path = g_test_get_filename (G_TEST_DIST,
+                              "tests", "icc-profiles", "vx239-calibrated.icc",
+                              NULL);
+  add_colord_system_profile (profile_id, path);
+  color_profiles[0] = profile_id;
+  set_colord_device_profiles (meta_color_device_get_id (color_device),
+                              color_profiles, G_N_ELEMENTS (color_profiles));
+
+  wait_for_profile_assigned (color_device, profile_id);
+
+  output = meta_monitor_get_main_output (monitor);
+  crtc = meta_output_get_assigned_crtc (output);
+  crtc_test = META_CRTC_TEST (crtc);
+
+  g_assert_cmpuint (crtc_test->gamma.size,
+                    ==,
+                    G_N_ELEMENTS (night_light_off_red));
+
+  assert_gamma_array (night_light_off_red, crtc_test->gamma.red,
+                      crtc_test->gamma.size);
+  assert_gamma_array (night_light_off_green, crtc_test->gamma.green,
+                      crtc_test->gamma.size);
+  assert_gamma_array (night_light_off_blue, crtc_test->gamma.blue,
+                      crtc_test->gamma.size);
+
+  set_night_light_temperature (temperature);
+  set_night_light_active (TRUE);
+  wait_for_device_updated (color_device);
+
+  assert_gamma_array (night_light_on_red, crtc_test->gamma.red,
+                      crtc_test->gamma.size);
+  assert_gamma_array (night_light_on_green, crtc_test->gamma.green,
+                      crtc_test->gamma.size);
+  assert_gamma_array (night_light_on_blue, crtc_test->gamma.blue,
+                      crtc_test->gamma.size);
+}
+
+static void
+meta_test_color_management_night_light_uncalibrated (void)
+{
+  MetaBackend *backend = meta_context_get_backend (test_context);
+  MetaMonitorManager *monitor_manager =
+    meta_backend_get_monitor_manager (backend);
+  MetaMonitorManagerTest *monitor_manager_test =
+    META_MONITOR_MANAGER_TEST (monitor_manager);
+  MetaColorManager *color_manager =
+    meta_backend_get_color_manager (backend);
+  MetaEdidInfo edid_info;
+  MonitorTestCaseSetup test_case_setup = base_monitor_setup;
+  MetaMonitorTestSetup *test_setup;
+  MetaMonitor *monitor;
+  MetaOutput *output;
+  MetaCrtc *crtc;
+  MetaCrtcTest *crtc_test;
+  MetaColorDevice *color_device;
+  const char *path;
+  const char *color_profiles[1];
+  const char *srgb_profile_id = SRGB_ICC_PROFILE_ID;
+
+  /* Night light disabled */
+  uint16_t night_light_off_red[] = {
+    0, 257, 514, 771, 1028, 1285, 1542, 1799, 2056, 2313, 2570, 2827, 3084,
+    3341, 3598, 3855, 4112, 4369, 4626, 4883, 5140, 5397, 5654, 5911, 6168,
+    6425, 6682, 6939, 7196, 7453, 7710, 7967, 8224, 8481, 8738, 8995, 9252,
+    9509, 9766, 10023, 10280, 10537, 10794, 11051, 11308, 11565, 11822, 12079,
+    12336, 12593, 12850, 13107, 13364, 13621, 13878, 14135, 14392, 14649,
+    14906, 15163, 15420, 15677, 15934, 16191, 16448, 16705, 16962, 17219,
+    17476, 17733, 17990, 18247, 18504, 18761, 19018, 19275, 19532, 19789,
+    20046, 20303, 20560, 20817, 21074, 21331, 21588, 21845, 22102, 22359,
+    22616, 22873, 23130, 23387, 23644, 23901, 24158, 24415, 24672, 24929,
+    25186, 25443, 25700, 25957, 26214, 26471, 26728, 26985, 27242, 27499,
+    27756, 28013, 28270, 28527, 28784, 29041, 29298, 29555, 29812, 30069,
+    30326, 30583, 30840, 31097, 31354, 31611, 31868, 32125, 32382, 32639,
+    32896, 33153, 33410, 33667, 33924, 34181, 34438, 34695, 34952, 35209,
+    35466, 35723, 35980, 36237, 36494, 36751, 37008, 37265, 37522, 37779,
+    38036, 38293, 38550, 38807, 39064, 39321, 39578, 39835, 40092, 40349,
+    40606, 40863, 41120, 41377, 41634, 41891, 42148, 42405, 42662, 42919,
+    43176, 43433, 43690, 43947, 44204, 44461, 44718, 44975, 45232, 45489,
+    45746, 46003, 46260, 46517, 46774, 47031, 47288, 47545, 47802, 48059,
+    48316, 48573, 48830, 49087, 49344, 49601, 49858, 50115, 50372, 50629,
+    50886, 51143, 51400, 51657, 51914, 52171, 52428, 52685, 52942, 53199,
+    53456, 53713, 53970, 54227, 54484, 54741, 54998, 55255, 55512, 55769,
+    56026, 56283, 56540, 56797, 57054, 57311, 57568, 57825, 58082, 58339,
+    58596, 58853, 59110, 59367, 59624, 59881, 60138, 60395, 60652, 60909,
+    61166, 61423, 61680, 61937, 62194, 62451, 62708, 62965, 63222, 63479,
+    63736, 63993, 64250, 64507, 64764, 65021, 65278, 65535
+  };
+  uint16_t night_light_off_green[] = {
+    0, 257, 514, 771, 1028, 1285, 1542, 1799, 2056, 2313, 2570, 2827, 3084,
+    3341, 3598, 3855, 4112, 4369, 4626, 4883, 5140, 5397, 5654, 5911, 6168,
+    6425, 6682, 6939, 7196, 7453, 7710, 7967, 8224, 8481, 8738, 8995, 9252,
+    9509, 9766, 10023, 10280, 10537, 10794, 11051, 11308, 11565, 11822, 12079,
+    12336, 12593, 12850, 13107, 13364, 13621, 13878, 14135, 14392, 14649,
+    14906, 15163, 15420, 15677, 15934, 16191, 16448, 16705, 16962, 17219,
+    17476, 17733, 17990, 18247, 18504, 18761, 19018, 19275, 19532, 19789,
+    20046, 20303, 20560, 20817, 21074, 21331, 21588, 21845, 22102, 22359,
+    22616, 22873, 23130, 23387, 23644, 23901, 24158, 24415, 24672, 24929,
+    25186, 25443, 25700, 25957, 26214, 26471, 26728, 26985, 27242, 27499,
+    27756, 28013, 28270, 28527, 28784, 29041, 29298, 29555, 29812, 30069,
+    30326, 30583, 30840, 31097, 31354, 31611, 31868, 32125, 32382, 32639,
+    32896, 33153, 33410, 33667, 33924, 34181, 34438, 34695, 34952, 35209,
+    35466, 35723, 35980, 36237, 36494, 36751, 37008, 37265, 37522, 37779,
+    38036, 38293, 38550, 38807, 39064, 39321, 39578, 39835, 40092, 40349,
+    40606, 40863, 41120, 41377, 41634, 41891, 42148, 42405, 42662, 42919,
+    43176, 43433, 43690, 43947, 44204, 44461, 44718, 44975, 45232, 45489,
+    45746, 46003, 46260, 46517, 46774, 47031, 47288, 47545, 47802, 48059,
+    48316, 48573, 48830, 49087, 49344, 49601, 49858, 50115, 50372, 50629,
+    50886, 51143, 51400, 51657, 51914, 52171, 52428, 52685, 52942, 53199,
+    53456, 53713, 53970, 54227, 54484, 54741, 54998, 55255, 55512, 55769,
+    56026, 56283, 56540, 56797, 57054, 57311, 57568, 57825, 58082, 58339,
+    58596, 58853, 59110, 59367, 59624, 59881, 60138, 60395, 60652, 60909,
+    61166, 61423, 61680, 61937, 62194, 62451, 62708, 62965, 63222, 63479,
+    63736, 63993, 64250, 64507, 64764, 65021, 65278, 65535
+  };
+  uint16_t night_light_off_blue[] = {
+    0, 257, 514, 771, 1028, 1285, 1542, 1799, 2056, 2313, 2570, 2827, 3084,
+    3341, 3598, 3855, 4112, 4369, 4626, 4883, 5140, 5397, 5654, 5911, 6168,
+    6425, 6682, 6939, 7196, 7453, 7710, 7967, 8224, 8481, 8738, 8995, 9252,
+    9509, 9766, 10023, 10280, 10537, 10794, 11051, 11308, 11565, 11822, 12079,
+    12336, 12593, 12850, 13107, 13364, 13621, 13878, 14135, 14392, 14649,
+    14906, 15163, 15420, 15677, 15934, 16191, 16448, 16705, 16962, 17219,
+    17476, 17733, 17990, 18247, 18504, 18761, 19018, 19275, 19532, 19789,
+    20046, 20303, 20560, 20817, 21074, 21331, 21588, 21845, 22102, 22359,
+    22616, 22873, 23130, 23387, 23644, 23901, 24158, 24415, 24672, 24929,
+    25186, 25443, 25700, 25957, 26214, 26471, 26728, 26985, 27242, 27499,
+    27756, 28013, 28270, 28527, 28784, 29041, 29298, 29555, 29812, 30069,
+    30326, 30583, 30840, 31097, 31354, 31611, 31868, 32125, 32382, 32639,
+    32896, 33153, 33410, 33667, 33924, 34181, 34438, 34695, 34952, 35209,
+    35466, 35723, 35980, 36237, 36494, 36751, 37008, 37265, 37522, 37779,
+    38036, 38293, 38550, 38807, 39064, 39321, 39578, 39835, 40092, 40349,
+    40606, 40863, 41120, 41377, 41634, 41891, 42148, 42405, 42662, 42919,
+    43176, 43433, 43690, 43947, 44204, 44461, 44718, 44975, 45232, 45489,
+    45746, 46003, 46260, 46517, 46774, 47031, 47288, 47545, 47802, 48059,
+    48316, 48573, 48830, 49087, 49344, 49601, 49858, 50115, 50372, 50629,
+    50886, 51143, 51400, 51657, 51914, 52171, 52428, 52685, 52942, 53199,
+    53456, 53713, 53970, 54227, 54484, 54741, 54998, 55255, 55512, 55769,
+    56026, 56283, 56540, 56797, 57054, 57311, 57568, 57825, 58082, 58339,
+    58596, 58853, 59110, 59367, 59624, 59881, 60138, 60395, 60652, 60909,
+    61166, 61423, 61680, 61937, 62194, 62451, 62708, 62965, 63222, 63479,
+    63736, 63993, 64250, 64507, 64764, 65021, 65278, 65535
+  };
+  /* Night light at 3305K */
+  uint16_t night_light_on_red[] = {
+    0, 257, 514, 771, 1028, 1285, 1542, 1799, 2056, 2313, 2570, 2827, 3084,
+    3341, 3598, 3855, 4112, 4369, 4626, 4883, 5140, 5397, 5654, 5911, 6168,
+    6425, 6682, 6939, 7196, 7453, 7710, 7967, 8224, 8481, 8738, 8995, 9252,
+    9509, 9766, 10023, 10280, 10537, 10794, 11051, 11308, 11565, 11822, 12079,
+    12336, 12593, 12850, 13107, 13364, 13621, 13878, 14135, 14392, 14649,
+    14906, 15163, 15420, 15677, 15934, 16191, 16448, 16705, 16962, 17219,
+    17476, 17733, 17990, 18247, 18504, 18761, 19018, 19275, 19532, 19789,
+    20046, 20303, 20560, 20817, 21074, 21331, 21588, 21845, 22102, 22359,
+    22616, 22873, 23130, 23387, 23644, 23901, 24158, 24415, 24672, 24929,
+    25186, 25443, 25700, 25957, 26214, 26471, 26728, 26985, 27242, 27499,
+    27756, 28013, 28270, 28527, 28784, 29041, 29298, 29555, 29812, 30069,
+    30326, 30583, 30840, 31097, 31354, 31611, 31868, 32125, 32382, 32639,
+    32896, 33153, 33410, 33667, 33924, 34181, 34438, 34695, 34952, 35209,
+    35466, 35723, 35980, 36237, 36494, 36751, 37008, 37265, 37522, 37779,
+    38036, 38293, 38550, 38807, 39064, 39321, 39578, 39835, 40092, 40349,
+    40606, 40863, 41120, 41377, 41634, 41891, 42148, 42405, 42662, 42919,
+    43176, 43433, 43690, 43947, 44204, 44461, 44718, 44975, 45232, 45489,
+    45746, 46003, 46260, 46517, 46774, 47031, 47288, 47545, 47802, 48059,
+    48316, 48573, 48830, 49087, 49344, 49601, 49858, 50115, 50372, 50629,
+    50886, 51143, 51400, 51657, 51914, 52171, 52428, 52685, 52942, 53199,
+    53456, 53713, 53970, 54227, 54484, 54741, 54998, 55255, 55512, 55769,
+    56026, 56283, 56540, 56797, 57054, 57311, 57568, 57825, 58082, 58339,
+    58596, 58853, 59110, 59367, 59624, 59881, 60138, 60395, 60652, 60909,
+    61166, 61423, 61680, 61937, 62194, 62451, 62708, 62965, 63222, 63479,
+    63736, 63993, 64250, 64507, 64764, 65021, 65278, 65535
+  };
+  uint16_t night_light_on_green[] = {
+    0, 194, 389, 584, 779, 973, 1168, 1363, 1558, 1753, 1947, 2142, 2337, 2532,
+    2727, 2921, 3116, 3311, 3506, 3701, 3895, 4090, 4285, 4480, 4675, 4869,
+    5064, 5259, 5454, 5649, 5843, 6038, 6233, 6428, 6623, 6817, 7012, 7207,
+    7402, 7597, 7791, 7986, 8181, 8376, 8571, 8765, 8960, 9155, 9350, 9545,
+    9739, 9934, 10129, 10324, 10519, 10713, 10908, 11103, 11298, 11493, 11687,
+    11882, 12077, 12272, 12467, 12661, 12856, 13051, 13246, 13441, 13635,
+    13830, 14025, 14220, 14415, 14609, 14804, 14999, 15194, 15389, 15583,
+    15778, 15973, 16168, 16363, 16557, 16752, 16947, 17142, 17337, 17531,
+    17726, 17921, 18116, 18311, 18505, 18700, 18895, 19090, 19285, 19479,
+    19674, 19869, 20064, 20259, 20453, 20648, 20843, 21038, 21233, 21427,
+    21622, 21817, 22012, 22207, 22401, 22596, 22791, 22986, 23181, 23375,
+    23570, 23765, 23960, 24155, 24349, 24544, 24739, 24934, 25129, 25323,
+    25518, 25713, 25908, 26103, 26297, 26492, 26687, 26882, 27077, 27271,
+    27466, 27661, 27856, 28051, 28245, 28440, 28635, 28830, 29025, 29219,
+    29414, 29609, 29804, 29999, 30193, 30388, 30583, 30778, 30973, 31167,
+    31362, 31557, 31752, 31947, 32141, 32336, 32531, 32726, 32921, 33115,
+    33310, 33505, 33700, 33895, 34089, 34284, 34479, 34674, 34869, 35063,
+    35258, 35453, 35648, 35843, 36037, 36232, 36427, 36622, 36817, 37011,
+    37206, 37401, 37596, 37791, 37985, 38180, 38375, 38570, 38765, 38959,
+    39154, 39349, 39544, 39739, 39933, 40128, 40323, 40518, 40713, 40907,
+    41102, 41297, 41492, 41687, 41881, 42076, 42271, 42466, 42661, 42855,
+    43050, 43245, 43440, 43635, 43829, 44024, 44219, 44414, 44609, 44803,
+    44998, 45193, 45388, 45583, 45777, 45972, 46167, 46362, 46557, 46751,
+    46946, 47141, 47336, 47531, 47725, 47920, 48115, 48310, 48505, 48699,
+    48894, 49089, 49284, 49479, 49673
+  };
+  uint16_t night_light_on_blue[] = {
+    0, 129, 258, 387, 516, 645, 775, 904, 1033, 1162, 1291, 1420, 1550, 1679,
+    1808, 1937, 2066, 2196, 2325, 2454, 2583, 2712, 2841, 2971, 3100, 3229,
+    3358, 3487, 3616, 3746, 3875, 4004, 4133, 4262, 4392, 4521, 4650, 4779,
+    4908, 5037, 5167, 5296, 5425, 5554, 5683, 5813, 5942, 6071, 6200, 6329,
+    6458, 6588, 6717, 6846, 6975, 7104, 7233, 7363, 7492, 7621, 7750, 7879,
+    8009, 8138, 8267, 8396, 8525, 8654, 8784, 8913, 9042, 9171, 9300, 9430,
+    9559, 9688, 9817, 9946, 10075, 10205, 10334, 10463, 10592, 10721, 10850,
+    10980, 11109, 11238, 11367, 11496, 11626, 11755, 11884, 12013, 12142,
+    12271, 12401, 12530, 12659, 12788, 12917, 13047, 13176, 13305, 13434,
+    13563, 13692, 13822, 13951, 14080, 14209, 14338, 14467, 14597, 14726,
+    14855, 14984, 15113, 15243, 15372, 15501, 15630, 15759, 15888, 16018,
+    16147, 16276, 16405, 16534, 16664, 16793, 16922, 17051, 17180, 17309,
+    17439, 17568, 17697, 17826, 17955, 18084, 18214, 18343, 18472, 18601,
+    18730, 18860, 18989, 19118, 19247, 19376, 19505, 19635, 19764, 19893,
+    20022, 20151, 20281, 20410, 20539, 20668, 20797, 20926, 21056, 21185,
+    21314, 21443, 21572, 21701, 21831, 21960, 22089, 22218, 22347, 22477,
+    22606, 22735, 22864, 22993, 23122, 23252, 23381, 23510, 23639, 23768,
+    23898, 24027, 24156, 24285, 24414, 24543, 24673, 24802, 24931, 25060,
+    25189, 25318, 25448, 25577, 25706, 25835, 25964, 26094, 26223, 26352,
+    26481, 26610, 26739, 26869, 26998, 27127, 27256, 27385, 27515, 27644,
+    27773, 27902, 28031, 28160, 28290, 28419, 28548, 28677, 28806, 28935,
+    29065, 29194, 29323, 29452, 29581, 29711, 29840, 29969, 30098, 30227,
+    30356, 30486, 30615, 30744, 30873, 31002, 31132, 31261, 31390, 31519,
+    31648, 31777, 31907, 32036, 32165, 32294, 32423, 32552, 32682, 32811,
+    32940
+  };
+  unsigned int temperature = 3305;
+
+  G_STATIC_ASSERT (G_N_ELEMENTS (night_light_off_red) ==
+                   G_N_ELEMENTS (night_light_off_green));
+  G_STATIC_ASSERT (G_N_ELEMENTS (night_light_off_red) ==
+                   G_N_ELEMENTS (night_light_off_blue));
+  G_STATIC_ASSERT (G_N_ELEMENTS (night_light_off_red) ==
+                   G_N_ELEMENTS (night_light_on_red));
+  G_STATIC_ASSERT (G_N_ELEMENTS (night_light_off_red) ==
+                   G_N_ELEMENTS (night_light_on_green));
+  G_STATIC_ASSERT (G_N_ELEMENTS (night_light_off_red) ==
+                   G_N_ELEMENTS (night_light_on_blue));
+
+  edid_info = ANCOR_VX239_EDID;
+  test_case_setup.outputs[0].edid_info = edid_info;
+  test_case_setup.outputs[0].has_edid_info = TRUE;
+  test_setup = meta_create_monitor_test_setup (backend, &test_case_setup,
+                                               MONITOR_TEST_FLAG_NO_STORED);
+  meta_monitor_manager_test_emulate_hotplug (monitor_manager_test, test_setup);
+
+  monitor = meta_monitor_manager_get_monitors (monitor_manager)->data;
+  color_device = meta_color_manager_get_color_device (color_manager, monitor);
+  g_assert_nonnull (color_device);
+
+  while (!meta_color_device_is_ready (color_device))
+    g_main_context_iteration (NULL, TRUE);
+
+  set_night_light_temperature (6500);
+  set_night_light_active (FALSE);
+  path = g_test_get_filename (G_TEST_DIST, "tests", "icc-profiles", "sRGB.icc",
+                              NULL);
+  add_colord_system_profile (srgb_profile_id, path);
+  color_profiles[0] = srgb_profile_id;
+  set_colord_device_profiles (meta_color_device_get_id (color_device),
+                              color_profiles, G_N_ELEMENTS (color_profiles));
+
+  wait_for_profile_assigned (color_device, srgb_profile_id);
+
+  output = meta_monitor_get_main_output (monitor);
+  crtc = meta_output_get_assigned_crtc (output);
+  crtc_test = META_CRTC_TEST (crtc);
+
+  g_assert_cmpuint (crtc_test->gamma.size,
+                    ==,
+                    G_N_ELEMENTS (night_light_off_red));
+
+  assert_gamma_array (night_light_off_red, crtc_test->gamma.red,
+                      crtc_test->gamma.size);
+  assert_gamma_array (night_light_off_green, crtc_test->gamma.green,
+                      crtc_test->gamma.size);
+  assert_gamma_array (night_light_off_blue, crtc_test->gamma.blue,
+                      crtc_test->gamma.size);
+
+  set_night_light_temperature (temperature);
+  set_night_light_active (TRUE);
+  wait_for_device_updated (color_device);
+
+  assert_gamma_array (night_light_on_red, crtc_test->gamma.red,
+                      crtc_test->gamma.size);
+  assert_gamma_array (night_light_on_green, crtc_test->gamma.green,
+                      crtc_test->gamma.size);
+  assert_gamma_array (night_light_on_blue, crtc_test->gamma.blue,
+                      crtc_test->gamma.size);
+}
+
 static MetaMonitorTestSetup *
 create_stage_view_test_setup (MetaBackend *backend)
 {
@@ -499,6 +1124,10 @@ init_tests (void)
                   meta_test_color_management_profile_device);
   add_color_test ("/color-management/profile/system",
                   meta_test_color_management_profile_system);
+  add_color_test ("/color-management/night-light/calibrated",
+                  meta_test_color_management_night_light_calibrated);
+  add_color_test ("/color-management/night-light/uncalibrated",
+                  meta_test_color_management_night_light_uncalibrated);
 }
 
 int
diff --git a/src/tests/dbusmock-templates/gsd-color.py b/src/tests/dbusmock-templates/gsd-color.py
index 9db39dcf0a..953e206015 100644
--- a/src/tests/dbusmock-templates/gsd-color.py
+++ b/src/tests/dbusmock-templates/gsd-color.py
@@ -29,3 +29,12 @@ def load(mock, parameters=None):
     mock.AddProperty(MAIN_IFACE, 'Temperature', dbus.UInt32())
     mock.Set(MAIN_IFACE, 'NightLightActive', mock.night_light_active)
     mock.Set(MAIN_IFACE, 'Temperature', dbus.UInt32(mock.temperature))
+
+
+@dbus.service.method(MOCK_IFACE, in_signature='b')
+def SetNightLightActive(self, active):
+    self.UpdateProperties(MAIN_IFACE, {'NightLightActive': active})
+
+@dbus.service.method(MOCK_IFACE, in_signature='u')
+def SetTemperature(self, temperature):
+    self.UpdateProperties(MAIN_IFACE, {'Temperature': temperature})
diff --git a/src/tests/icc-profiles/vx239-calibrated.icc b/src/tests/icc-profiles/vx239-calibrated.icc
new file mode 100644
index 0000000000..7c4ccd1f66
Binary files /dev/null and b/src/tests/icc-profiles/vx239-calibrated.icc differ


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]