From 1adbb686bc4af35faf969b40ff86eaeba0d7888a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jonas=20=C3=85dahl?= Date: Mon, 6 Dec 2021 22:00:02 +0100 Subject: [PATCH] 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: --- 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(+) create mode 100644 src/tests/icc-profiles/vx239-calibrated.icc diff --git a/src/tests/color-management-tests.c b/src/tests/color-management-tests.c index 12509514c..9d838630e 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 (¶ms_builder, G_VARIANT_TYPE ("(u)")); + g_variant_builder_add (¶ms_builder, "u", temperature); + + if (!g_dbus_proxy_call_sync (proxy, + "SetTemperature", + g_variant_builder_end (¶ms_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 (¶ms_builder, G_VARIANT_TYPE ("(b)")); + g_variant_builder_add (¶ms_builder, "b", active); + + if (!g_dbus_proxy_call_sync (proxy, + "SetNightLightActive", + g_variant_builder_end (¶ms_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 9db39dcf0..953e20601 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 0000000000000000000000000000000000000000..7c4ccd1f664ba25b83398d02bcf3750c77114481 GIT binary patch literal 3068 zcmcguc{tQx7r#Sj3L!}$qqJw=Qg*Ur--Q}uW-ysWGh<05%DzO_Mk*?jLLw!F7KKP8 zZCZ$winqkCB=er3?RlTy@BQQbw+w2?q$1sOXy*r2~}7=*^VfeY=v5-(Saz2d^JaaYA_vf{Ee&Ybo9 z`>l$+J^~X%xVbfF(oOLBQe55|nQdyd=@%w2*(|WH1$an;ZsnN600B!omeH8GaNh83)jhNhaeMez-t7Bb1IKGJJe=cPbd8n!H6@zC1DayRgV!}#mGu^t-=CR!zdmRUYV~kUwbG=KOYo}YQ zd!0w|mLyMqF9UCJ@0VN8ZVSO1`e1!J2}gYciTWf7(tC2NU#0)?01kz-{X}3jwS)GV zAs1w`Ba&Ie8V}YA2@S2?iNeixCG2jE5ZP-T85?zV-$=AfjB%__TxfhuLTuu$BvP_T zige1rfitOrX)Ds6AIwNMPyd=xn(3RhIO}2dp&a}nWsU&nb#BMuro7f8y~nWmrUl8z z`%hXHUOJ^(Tv4KP=6b1p*|T$j72}nAs<_oVFTSgBynMFy>s9SKLVb8cbAKc2nO>SD*G|*ho;(bTz&b`*8HjBGLcU#)i@8LVtJB2%k??38lebCa~@v!gF z#FIr&4SE8e`A@7{k98kQMZ@vl`M6+Vf68Xax_ zd}53~t~UPRuYxbOUp{?Jn^-w<@tg6t#z~XOn(u4B=X{@%(3-@xJJ#7L$t%58 zu2hLowN#T(d!~L$gQ=;fC8*V*eOSkDz3Tc2-Np^68$IHR(O3Mb;4?29C0B@gv?L=;y2{~G@zMMwLLFzFBMPIrHj$~ z80Ui`c33j!F(0rvZ0}&X;1?msLJ46@!v=O1htqax?)tvFc~4FRWv@Y`bmUl6_rA;f z3!)QZ*l>dE;`I}h66KOaleozrQ~C~cre04wckpO>Vg@_YJIf?{d5&OC|Dk#gCzo~D zE^pNl{v*$hUOJYZPb;uEu5f(vMEA*x!lWX(zM|LoYejth+3Dxwp3VO4ik&y3O^=>$we2u2o%6y+OHY+PI|g z%dPvjOPk`GeOvVJEWGonwY9D2ZdAM1J?##$j(44n_w&2LAGma@Jj6cie^mFF1N)zd zS%5jor^VOIPvD=Nl_y{*FesQQWG*x{yB525j^$kGxg)}DB9)@~^RmP;#5oeh^BW|e zOQD6Uq@5S-TU;eGB&V>%OFkRdxpW@veZum_m1xz5)jQS{t$m~`Z;wea>`Pj~n2c^xsZ_gQ3n zRPDaw`(vVsF$S?xvG3y=;xiJ+iP}lnq@Lu8l=uULRD-l72l)?vNbkw$$ZXB($nMLT zadGjFB#Ry*L=JDptkHv%vG;C)q27Drw!+?C0-}qFt{mubF%T}t)|hgHt*6sSx^^x0Sk0;(weR}+#(VvIDhzE>Hw)gX4cWb;zEA#8I(%@iNVYeI6=II;e#89<)@)O(;Zlj zkeLRT+g--x8jd1NHN1DQz`%}ixx=9dBa}&k`+J6qW`h<3Ndu7rDFT@Ta_&d}7HDCR zP7pcepXPc#edX_ha4mn25|()L;|e@ zZ2I(gOoW5n45)|(b