assert_se(r == 1);
assert_se(streq(ans, "pl"));
+ ans = mfree(ans);
assert_se(find_converted_keymap(
&(X11Context) {
}
TEST(vconsole_convert_to_x11) {
- _cleanup_(context_clear) Context c = {};
- X11Context *xc = &c.x11_from_vc;
-
- log_info("/* test emptying first (:) */");
- assert_se(free_and_strdup(&xc->layout, "foo") >= 0);
- assert_se(free_and_strdup(&xc->variant, "bar") >= 0);
- assert_se(vconsole_convert_to_x11(&c) == 1);
- assert_se(xc->layout == NULL);
- assert_se(xc->variant == NULL);
-
- log_info("/* test emptying second (:) */");
+ _cleanup_(x11_context_clear) X11Context xc = {};
+ _cleanup_(vc_context_clear) VCContext vc = {};
+ int r;
- assert_se(vconsole_convert_to_x11(&c) == 0);
- assert_se(xc->layout == NULL);
- assert_se(xc->variant == NULL);
+ log_info("/* test empty keymap */");
+ assert_se(vconsole_convert_to_x11(&vc, &xc) >= 0);
+ assert_se(x11_context_isempty(&xc));
log_info("/* test without variant, new mapping (es:) */");
- assert_se(free_and_strdup(&c.vc_keymap, "es") >= 0);
-
- assert_se(vconsole_convert_to_x11(&c) == 1);
- assert_se(streq(xc->layout, "es"));
- assert_se(xc->variant == NULL);
+ assert_se(free_and_strdup(&vc.keymap, "es") >= 0);
+ assert_se(vconsole_convert_to_x11(&vc, &xc) >= 0);
+ assert_se(streq(xc.layout, "es"));
+ assert_se(xc.variant == NULL);
+ x11_context_clear(&xc);
log_info("/* test with known variant, new mapping (es:dvorak) */");
- assert_se(free_and_strdup(&c.vc_keymap, "es-dvorak") >= 0);
-
- assert_se(vconsole_convert_to_x11(&c) == 1);
- assert_se(streq(xc->layout, "es"));
- assert_se(streq(xc->variant, "dvorak"));
+ assert_se(free_and_strdup(&vc.keymap, "es-dvorak") >= 0);
+ assert_se(vconsole_convert_to_x11(&vc, &xc) >= 0);
+ assert_se(streq(xc.layout, "es"));
+ assert_se(streq(xc.variant, "dvorak"));
+ x11_context_clear(&xc);
log_info("/* test with old mapping (fr:latin9) */");
- assert_se(free_and_strdup(&c.vc_keymap, "fr-latin9") >= 0);
-
- assert_se(vconsole_convert_to_x11(&c) == 1);
- assert_se(streq(xc->layout, "fr"));
- assert_se(streq(xc->variant, "latin9"));
+ assert_se(free_and_strdup(&vc.keymap, "fr-latin9") >= 0);
+ assert_se(vconsole_convert_to_x11(&vc, &xc) >= 0);
+ assert_se(streq(xc.layout, "fr"));
+ assert_se(streq(xc.variant, "latin9"));
+ x11_context_clear(&xc);
log_info("/* test with a compound mapping (ru,us) */");
- assert_se(free_and_strdup(&c.vc_keymap, "ru") >= 0);
-
- assert_se(vconsole_convert_to_x11(&c) == 1);
- assert_se(streq(xc->layout, "ru,us"));
- assert_se(xc->variant == NULL);
+ assert_se(free_and_strdup(&vc.keymap, "ru") >= 0);
+ assert_se(vconsole_convert_to_x11(&vc, &xc) >= 0);
+ assert_se(streq(xc.layout, "ru,us"));
+ assert_se(xc.variant == NULL);
+ x11_context_clear(&xc);
log_info("/* test with a simple mapping (us) */");
- assert_se(free_and_strdup(&c.vc_keymap, "us") >= 0);
-
- assert_se(vconsole_convert_to_x11(&c) == 1);
- assert_se(streq(xc->layout, "us"));
- assert_se(xc->variant == NULL);
+ assert_se(free_and_strdup(&vc.keymap, "us") >= 0);
+ assert_se(vconsole_convert_to_x11(&vc, &xc) >= 0);
+ assert_se(streq(xc.layout, "us"));
+ assert_se(xc.variant == NULL);
+ x11_context_clear(&xc);
+
+ /* "gh" has no mapping in kbd-model-map and kbd provides a converted keymap for this layout. */
+ log_info("/* test with a converted keymap (gh:) */");
+ assert_se(free_and_strdup(&vc.keymap, "gh") >= 0);
+ r = vconsole_convert_to_x11(&vc, &xc);
+ if (r == 0) {
+ log_info("Skipping rest of %s: keymaps are not installed", __func__);
+ return;
+ }
+ assert_se(r > 0);
+ assert_se(streq(xc.layout, "gh"));
+ assert_se(xc.variant == NULL);
+ x11_context_clear(&xc);
+
+ log_info("/* test with converted keymap and with a known variant (gh:ewe) */");
+ assert_se(free_and_strdup(&vc.keymap, "gh-ewe") >= 0);
+ assert_se(vconsole_convert_to_x11(&vc, &xc) > 0);
+ assert_se(streq(xc.layout, "gh"));
+ assert_se(streq(xc.variant, "ewe"));
+ x11_context_clear(&xc);
+
+ log_info("/* test with converted keymap and with an unknown variant (gh:ewe) */");
+ assert_se(free_and_strdup(&vc.keymap, "gh-foobar") > 0);
+ assert_se(vconsole_convert_to_x11(&vc, &xc) > 0);
+ assert_se(streq(xc.layout, "gh"));
+ assert_se(xc.variant == NULL);
+ x11_context_clear(&xc);
}
TEST(x11_convert_to_vconsole) {
- _cleanup_(context_clear) Context c = {};
- X11Context *xc = &c.x11_from_xorg;
- int r;
+ _cleanup_(x11_context_clear) X11Context xc = {};
+ _cleanup_(vc_context_clear) VCContext vc = {};
- log_info("/* test emptying first (:) */");
- assert_se(free_and_strdup(&c.vc_keymap, "foobar") >= 0);
- assert_se(x11_convert_to_vconsole(&c) == 1);
- assert_se(c.vc_keymap == NULL);
-
- log_info("/* test emptying second (:) */");
-
- assert_se(x11_convert_to_vconsole(&c) == 0);
- assert_se(c.vc_keymap == NULL);
+ log_info("/* test empty layout (:) */");
+ assert_se(x11_convert_to_vconsole(&xc, &vc) >= 0);
+ assert_se(vc_context_isempty(&vc));
log_info("/* test without variant, new mapping (es:) */");
- assert_se(free_and_strdup(&xc->layout, "es") >= 0);
-
- assert_se(x11_convert_to_vconsole(&c) == 1);
- assert_se(streq(c.vc_keymap, "es"));
+ assert_se(free_and_strdup(&xc.layout, "es") >= 0);
+ assert_se(x11_convert_to_vconsole(&xc, &vc) >= 0);
+ assert_se(streq(vc.keymap, "es"));
+ vc_context_clear(&vc);
log_info("/* test with unknown variant, new mapping (es:foobar) */");
- assert_se(free_and_strdup(&xc->variant, "foobar") >= 0);
-
- assert_se(x11_convert_to_vconsole(&c) == 0);
- assert_se(streq(c.vc_keymap, "es"));
+ assert_se(free_and_strdup(&xc.variant, "foobar") >= 0);
+ assert_se(x11_convert_to_vconsole(&xc, &vc) >= 0);
+ assert_se(streq(vc.keymap, "es"));
+ vc_context_clear(&vc);
log_info("/* test with known variant, new mapping (es:dvorak) */");
- assert_se(free_and_strdup(&xc->variant, "dvorak") >= 0);
-
- r = x11_convert_to_vconsole(&c);
- if (r == 0) {
+ assert_se(free_and_strdup(&xc.variant, "dvorak") >= 0);
+ assert_se(x11_convert_to_vconsole(&xc, &vc) >= 0);
+ if (vc_context_isempty(&vc)) {
log_info("Skipping rest of %s: keymaps are not installed", __func__);
return;
}
-
- assert_se(r == 1);
- assert_se(streq(c.vc_keymap, "es-dvorak"));
+ assert_se(streq(vc.keymap, "es-dvorak"));
+ vc_context_clear(&vc);
+
+ /* es no-variant test is not very good as the desired match
+ comes first in the list so will win if both candidates score
+ the same. in this case the desired match comes second so will
+ not win unless we correctly give the no-variant match a bonus
+ */
+ log_info("/* test without variant, desired match second (bg,us:) */");
+ assert_se(free_and_strdup(&xc.layout, "bg,us") >= 0);
+ assert_se(free_and_strdup(&xc.variant, NULL) >= 0);
+ assert_se(x11_convert_to_vconsole(&xc, &vc) >= 0);
+ assert_se(streq(vc.keymap, "bg_bds-utf8"));
+ vc_context_clear(&vc);
log_info("/* test with old mapping (fr:latin9) */");
- assert_se(free_and_strdup(&xc->layout, "fr") >= 0);
- assert_se(free_and_strdup(&xc->variant, "latin9") >= 0);
-
- assert_se(x11_convert_to_vconsole(&c) == 1);
- assert_se(streq(c.vc_keymap, "fr-latin9"));
-
+ assert_se(free_and_strdup(&xc.layout, "fr") >= 0);
+ assert_se(free_and_strdup(&xc.variant, "latin9") >= 0);
+ assert_se(x11_convert_to_vconsole(&xc, &vc) >= 0);
+ assert_se(streq(vc.keymap, "fr-latin9"));
+ vc_context_clear(&vc);
+
+ /* https://bugzilla.redhat.com/show_bug.cgi?id=1039185 */
+ /* us,ru is the x config users want, but they still want ru
+ as the console layout in this case */
log_info("/* test with a compound mapping (us,ru:) */");
- assert_se(free_and_strdup(&xc->layout, "us,ru") >= 0);
- assert_se(free_and_strdup(&xc->variant, NULL) >= 0);
-
- assert_se(x11_convert_to_vconsole(&c) == 1);
- assert_se(streq(c.vc_keymap, "us"));
+ assert_se(free_and_strdup(&xc.layout, "us,ru") >= 0);
+ assert_se(free_and_strdup(&xc.variant, NULL) >= 0);
+ assert_se(x11_convert_to_vconsole(&xc, &vc) >= 0);
+ assert_se(streq(vc.keymap, "ru"));
+ vc_context_clear(&vc);
log_info("/* test with a compound mapping (ru,us:) */");
- assert_se(free_and_strdup(&xc->layout, "ru,us") >= 0);
- assert_se(free_and_strdup(&xc->variant, NULL) >= 0);
-
- assert_se(x11_convert_to_vconsole(&c) == 1);
- assert_se(streq(c.vc_keymap, "ru"));
+ assert_se(free_and_strdup(&xc.layout, "ru,us") >= 0);
+ assert_se(free_and_strdup(&xc.variant, NULL) >= 0);
+ assert_se(x11_convert_to_vconsole(&xc, &vc) >= 0);
+ assert_se(streq(vc.keymap, "ru"));
+ vc_context_clear(&vc);
/* https://bugzilla.redhat.com/show_bug.cgi?id=1333998 */
log_info("/* test with a simple new mapping (ru:) */");
- assert_se(free_and_strdup(&xc->layout, "ru") >= 0);
- assert_se(free_and_strdup(&xc->variant, NULL) >= 0);
-
- assert_se(x11_convert_to_vconsole(&c) == 0);
- assert_se(streq(c.vc_keymap, "ru"));
+ assert_se(free_and_strdup(&xc.layout, "ru") >= 0);
+ assert_se(free_and_strdup(&xc.variant, NULL) >= 0);
+ assert_se(x11_convert_to_vconsole(&xc, &vc) >= 0);
+ assert_se(streq(vc.keymap, "ru"));
}
static int intro(void) {