]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
expo: Update tests to include textline
authorSimon Glass <sjg@chromium.org>
Mon, 2 Oct 2023 01:13:39 +0000 (19:13 -0600)
committerTom Rini <trini@konsulko.com>
Wed, 11 Oct 2023 19:43:55 +0000 (15:43 -0400)
Provide test coverage for the new expo object type, including building
and reading/writing settings.

Signed-off-by: Simon Glass <sjg@chromium.org>
arch/sandbox/dts/cedit.dtsi
include/test/cedit-test.h
test/boot/cedit.c
test/boot/expo.c
test/boot/files/expo_ids.h
test/boot/files/expo_layout.dts

index a9eb4c2d594abe51055beed75befc5f9a4d5da68..9bd84e62936745e04915a8c57e1dfded1d455482 100644 (file)
 
                                item-id = <ID_AC_OFF ID_AC_ON ID_AC_MEMORY>;
                        };
+
+                       machine-name {
+                               id = <ID_MACHINE_NAME>;
+                               type = "textline";
+                               max-chars = <20>;
+                               title = "Machine name";
+                               edit-id = <ID_MACHINE_NAME_EDIT>;
+                       };
                };
        };
 
index 349df75b16d4edf4cc0e340e4975f0179073488b..475ecc9c2dc2f688c67c0337e8075e6d5b1b4f49 100644 (file)
@@ -24,6 +24,9 @@
 #define ID_AC_ON               11
 #define ID_AC_MEMORY           12
 
-#define ID_DYNAMIC_START       13
+#define ID_MACHINE_NAME                13
+#define ID_MACHINE_NAME_EDIT   14
+
+#define ID_DYNAMIC_START       15
 
 #endif
index ab2b8a1f9ffaaf9229dc8331fb914e2daec47f5c..aa4171904864529e3358faf7cc61d624d94146de 100644 (file)
@@ -58,6 +58,7 @@ BOOTSTD_TEST(cedit_base, 0);
 /* Check the cedit write_fdt and read_fdt commands */
 static int cedit_fdt(struct unit_test_state *uts)
 {
+       struct scene_obj_textline *tline;
        struct video_priv *vid_priv;
        extern struct expo *cur_exp;
        struct scene_obj_menu *menu;
@@ -66,6 +67,7 @@ static int cedit_fdt(struct unit_test_state *uts)
        struct scene *scn;
        oftree tree;
        ofnode node;
+       char *str;
        void *fdt;
        int i;
 
@@ -79,6 +81,12 @@ static int cedit_fdt(struct unit_test_state *uts)
        ut_assertnonnull(menu);
        menu->cur_item_id = ID_CPU_SPEED_2;
 
+       /* get a textline to fiddle with too */
+       tline = scene_obj_find(scn, ID_MACHINE_NAME, SCENEOBJT_TEXTLINE);
+       ut_assertnonnull(tline);
+       str = abuf_data(&tline->buf);
+       strcpy(str, "my-machine");
+
        ut_assertok(run_command("cedit write_fdt hostfs - settings.dtb", 0));
        ut_assertok(run_commandf("load hostfs - %lx settings.dtb", addr));
        ut_assert_nextlinen("1024 bytes read");
@@ -86,26 +94,29 @@ static int cedit_fdt(struct unit_test_state *uts)
        fdt = map_sysmem(addr, 1024);
        tree = oftree_from_fdt(fdt);
        node = ofnode_find_subnode(oftree_root(tree), CEDIT_NODE_NAME);
+       ut_assert(ofnode_valid(node));
 
        ut_asserteq(ID_CPU_SPEED_2,
                    ofnode_read_u32_default(node, "cpu-speed", 0));
        ut_asserteq_str("2.5 GHz", ofnode_read_string(node, "cpu-speed-str"));
-       ut_assert(ofnode_valid(node));
+       ut_asserteq_str("my-machine", ofnode_read_string(node, "machine-name"));
 
-       /* There should only be 4 properties */
+       /* There should only be 5 properties */
        for (i = 0, ofnode_first_property(node, &prop); ofprop_valid(&prop);
             i++, ofnode_next_property(&prop))
                ;
-       ut_asserteq(4, i);
+       ut_asserteq(5, i);
 
        ut_assert_console_end();
 
        /* reset the expo */
        menu->cur_item_id = ID_CPU_SPEED_1;
+       *str = '\0';
 
        /* load in the settings and make sure they update */
        ut_assertok(run_command("cedit read_fdt hostfs - settings.dtb", 0));
        ut_asserteq(ID_CPU_SPEED_2, menu->cur_item_id);
+       ut_asserteq_str("my-machine", ofnode_read_string(node, "machine-name"));
 
        ut_assertnonnull(menu);
        ut_assert_console_end();
@@ -117,10 +128,12 @@ BOOTSTD_TEST(cedit_fdt, 0);
 /* Check the cedit write_env and read_env commands */
 static int cedit_env(struct unit_test_state *uts)
 {
+       struct scene_obj_textline *tline;
        struct video_priv *vid_priv;
        extern struct expo *cur_exp;
        struct scene_obj_menu *menu;
        struct scene *scn;
+       char *str;
 
        console_record_reset_enable();
        ut_assertok(run_command("cedit load hostfs - cedit.dtb", 0));
@@ -132,25 +145,36 @@ static int cedit_env(struct unit_test_state *uts)
        ut_assertnonnull(menu);
        menu->cur_item_id = ID_CPU_SPEED_2;
 
+       /* get a textline to fiddle with too */
+       tline = scene_obj_find(scn, ID_MACHINE_NAME, SCENEOBJT_TEXTLINE);
+       ut_assertnonnull(tline);
+       str = abuf_data(&tline->buf);
+       strcpy(str, "my-machine");
+
        ut_assertok(run_command("cedit write_env -v", 0));
        ut_assert_nextlinen("c.cpu-speed=7");
        ut_assert_nextlinen("c.cpu-speed-str=2.5 GHz");
        ut_assert_nextlinen("c.power-loss=10");
        ut_assert_nextlinen("c.power-loss-str=Always Off");
+       ut_assert_nextlinen("c.machine-name=my-machine");
        ut_assert_console_end();
 
        ut_asserteq(7, env_get_ulong("c.cpu-speed", 10, 0));
        ut_asserteq_str("2.5 GHz", env_get("c.cpu-speed-str"));
+       ut_asserteq_str("my-machine", env_get("c.machine-name"));
 
        /* reset the expo */
        menu->cur_item_id = ID_CPU_SPEED_1;
+       *str = '\0';
 
        ut_assertok(run_command("cedit read_env -v", 0));
        ut_assert_nextlinen("c.cpu-speed=7");
        ut_assert_nextlinen("c.power-loss=10");
+       ut_assert_nextlinen("c.machine-name=my-machine");
        ut_assert_console_end();
 
        ut_asserteq(ID_CPU_SPEED_2, menu->cur_item_id);
+       ut_asserteq_str("my-machine", env_get("c.machine-name"));
 
        return 0;
 }
index 90027409c817f55d26ffdbd0b6f99fcadc2e6936..714fdfa415d10c0dc8f95eff061be2ad5455da17 100644 (file)
@@ -654,7 +654,7 @@ static int expo_test_build(struct unit_test_state *uts)
 
        ut_asserteq_str("name", exp->name);
        ut_asserteq(0, exp->scene_id);
-       ut_asserteq(ID_DYNAMIC_START + 20, exp->next_id);
+       ut_asserteq(ID_DYNAMIC_START + 24, exp->next_id);
        ut_asserteq(false, exp->popup);
 
        /* check the scene */
index 027d44bf38c5b97b13b3cdf6da43ce84e289200e..a86e0d06f6b5bede67da522886adfaf079de40c2 100644 (file)
@@ -21,5 +21,8 @@ enum {
        ID_AC_ON,
        ID_AC_MEMORY,
 
+       ID_MACHINE_NAME,
+       ID_MACHINE_NAME_EDIT,
+
        ID_DYNAMIC_START,
 };
index cb2a674d9d56a444a40b9c5a74fe133d6fd705cd..bed552288f4cd49fd4186e5ac9839fe3ffd401bd 100644 (file)
                                start-bit = <0x422>;
                                bit-length = <2>;
                        };
+
+                       machine-name {
+                               id = <ID_MACHINE_NAME>;
+                               type = "textline";
+                               max-chars = <20>;
+                               title = "Machine name";
+                               edit-id = <ID_MACHINE_NAME_EDIT>;
+                       };
                };
        };