diff options
author | Sébastien Helleu <flashcode@flashtux.org> | 2024-03-04 18:42:41 +0100 |
---|---|---|
committer | Sébastien Helleu <flashcode@flashtux.org> | 2024-03-05 19:52:21 +0100 |
commit | 361d55d9d7d8f072802d6b4dc4ebbc9f483e958e (patch) | |
tree | 8a3a3328945463291c4f095432bc6cc32b01c263 /tests/unit/core | |
parent | 8f0b3ab9c752a729819f285d5944d58007b8718d (diff) | |
download | weechat-361d55d9d7d8f072802d6b4dc4ebbc9f483e958e.zip |
api: add functions config_{boolean|integer|string|color|enum}_inherited in scripting API
Diffstat (limited to 'tests/unit/core')
-rw-r--r-- | tests/unit/core/test-core-config-file.cpp | 146 |
1 files changed, 146 insertions, 0 deletions
diff --git a/tests/unit/core/test-core-config-file.cpp b/tests/unit/core/test-core-config-file.cpp index d55aeebb3..44ac72e3a 100644 --- a/tests/unit/core/test-core-config-file.cpp +++ b/tests/unit/core/test-core-config-file.cpp @@ -41,11 +41,17 @@ extern const char *config_file_option_escape (const char *name); } struct t_config_option *ptr_option_bool = NULL; +struct t_config_option *ptr_option_bool_child = NULL; struct t_config_option *ptr_option_int = NULL; +struct t_config_option *ptr_option_int_child = NULL; struct t_config_option *ptr_option_int_str = NULL; +struct t_config_option *ptr_option_int_str_child = NULL; struct t_config_option *ptr_option_str = NULL; +struct t_config_option *ptr_option_str_child = NULL; struct t_config_option *ptr_option_col = NULL; +struct t_config_option *ptr_option_col_child = NULL; struct t_config_option *ptr_option_enum = NULL; +struct t_config_option *ptr_option_enum_child = NULL; TEST_GROUP(CoreConfigFile) { @@ -74,12 +80,26 @@ TEST_GROUP(CoreConfigFileWithNewOptions) NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL); + ptr_option_bool_child = config_file_new_option ( + weechat_config_file, weechat_config_section_look, + "test_boolean_child << weechat.look.test_boolean", + "boolean", "", NULL, 0, 0, NULL, NULL, 1, + NULL, NULL, NULL, + NULL, NULL, NULL, + NULL, NULL, NULL); ptr_option_int = config_file_new_option ( weechat_config_file, weechat_config_section_look, "test_integer", "integer", "", NULL, 0, 123456, "100", NULL, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL); + ptr_option_int_child = config_file_new_option ( + weechat_config_file, weechat_config_section_look, + "test_integer_child << weechat.look.test_integer", + "integer", "", NULL, 0, 123456, NULL, NULL, 1, + NULL, NULL, NULL, + NULL, NULL, NULL, + NULL, NULL, NULL); /* auto-created as enum with WeeChat >= 4.1.0 */ ptr_option_int_str = config_file_new_option ( weechat_config_file, weechat_config_section_look, @@ -87,40 +107,80 @@ TEST_GROUP(CoreConfigFileWithNewOptions) NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL); + ptr_option_int_str_child = config_file_new_option ( + weechat_config_file, weechat_config_section_look, + "test_integer_values_child << weechat.look.test_integer_values", + "integer", "", "v1|v2|v3", 0, 0, NULL, NULL, 1, + NULL, NULL, NULL, + NULL, NULL, NULL, + NULL, NULL, NULL); ptr_option_str = config_file_new_option ( weechat_config_file, weechat_config_section_look, "test_string", "string", "", NULL, 0, 0, "value", NULL, 0, &option_str_check_cb, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL); + ptr_option_str_child = config_file_new_option ( + weechat_config_file, weechat_config_section_look, + "test_string_child << weechat.look.test_string", + "string", "", NULL, 0, 0, NULL, NULL, 1, + &option_str_check_cb, NULL, NULL, + NULL, NULL, NULL, + NULL, NULL, NULL); ptr_option_col = config_file_new_option ( weechat_config_file, weechat_config_section_color, "test_color", "color", "", NULL, 0, 0, "blue", NULL, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL); + ptr_option_col_child = config_file_new_option ( + weechat_config_file, weechat_config_section_color, + "test_color_child << weechat.color.test_color", + "color", "", NULL, 0, 0, NULL, NULL, 1, + NULL, NULL, NULL, + NULL, NULL, NULL, + NULL, NULL, NULL); ptr_option_enum = config_file_new_option ( weechat_config_file, weechat_config_section_look, "test_enum", "enum", "", "v1|v2|v3", 0, 0, "v2", NULL, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL); + ptr_option_enum_child = config_file_new_option ( + weechat_config_file, weechat_config_section_look, + "test_enum_child << weechat.look.test_enum", + "enum", "", "v1|v2|v3", 0, 0, NULL, NULL, 1, + NULL, NULL, NULL, + NULL, NULL, NULL, + NULL, NULL, NULL); } void teardown () { config_file_option_free (ptr_option_bool, 0); ptr_option_bool = NULL; + config_file_option_free (ptr_option_bool_child, 0); + ptr_option_bool_child = NULL; config_file_option_free (ptr_option_int, 0); ptr_option_int = NULL; + config_file_option_free (ptr_option_int_child, 0); + ptr_option_int_child = NULL; config_file_option_free (ptr_option_int_str, 0); ptr_option_int_str = NULL; + config_file_option_free (ptr_option_int_str_child, 0); + ptr_option_int_str_child = NULL; config_file_option_free (ptr_option_str, 0); ptr_option_str = NULL; + config_file_option_free (ptr_option_str_child, 0); + ptr_option_str_child = NULL; config_file_option_free (ptr_option_col, 0); ptr_option_col = NULL; + config_file_option_free (ptr_option_col_child, 0); + ptr_option_col_child = NULL; config_file_option_free (ptr_option_enum, 0); ptr_option_enum = NULL; + config_file_option_free (ptr_option_enum_child, 0); + ptr_option_enum_child = NULL; } }; @@ -1148,6 +1208,22 @@ TEST(CoreConfigFileWithNewOptions, OptionBoolean) /* * Tests functions: + * config_file_option_boolean_inherited + */ + +TEST(CoreConfigFileWithNewOptions, OptionBooleanInherited) +{ + LONGS_EQUAL(0, config_file_option_boolean_inherited (NULL)); + + LONGS_EQUAL(0, config_file_option_boolean_inherited (ptr_option_bool_child)); + config_file_option_set (ptr_option_bool, "on", 1); + LONGS_EQUAL(1, config_file_option_boolean_inherited (ptr_option_bool_child)); + config_file_option_reset (ptr_option_bool, 1); + LONGS_EQUAL(0, config_file_option_boolean_inherited (ptr_option_bool_child)); +} + +/* + * Tests functions: * config_file_option_integer * config_file_option_integer_default */ @@ -1185,6 +1261,22 @@ TEST(CoreConfigFileWithNewOptions, OptionInteger) /* * Tests functions: + * config_file_option_integer_inherited + */ + +TEST(CoreConfigFileWithNewOptions, OptionIntegerInherited) +{ + LONGS_EQUAL(0, config_file_option_integer_inherited (NULL)); + + LONGS_EQUAL(100, config_file_option_integer_inherited (ptr_option_int_child)); + config_file_option_set (ptr_option_int, "123", 1); + LONGS_EQUAL(123, config_file_option_integer_inherited (ptr_option_int_child)); + config_file_option_reset (ptr_option_int, 1); + LONGS_EQUAL(100, config_file_option_integer_inherited (ptr_option_int_child)); +} + +/* + * Tests functions: * config_file_option_string * config_file_option_string_default */ @@ -1228,6 +1320,28 @@ TEST(CoreConfigFileWithNewOptions, OptionString) /* * Tests functions: + * config_file_option_string_inherited + */ + +TEST(CoreConfigFileWithNewOptions, OptionStringInherited) +{ + POINTERS_EQUAL(NULL, config_file_option_string_inherited (NULL)); + + STRCMP_EQUAL("v2", config_file_option_string_inherited (ptr_option_int_str_child)); + config_file_option_set (ptr_option_int_str, "v3", 1); + STRCMP_EQUAL("v3", config_file_option_string_inherited (ptr_option_int_str_child)); + config_file_option_reset (ptr_option_int_str, 1); + STRCMP_EQUAL("v2", config_file_option_string_inherited (ptr_option_int_str_child)); + + STRCMP_EQUAL("value", config_file_option_string_inherited (ptr_option_str_child)); + config_file_option_set (ptr_option_str, "test", 1); + STRCMP_EQUAL("test", config_file_option_string_inherited (ptr_option_str_child)); + config_file_option_reset (ptr_option_str, 1); + STRCMP_EQUAL("value", config_file_option_string_inherited (ptr_option_str_child)); +} + +/* + * Tests functions: * config_file_option_color * config_file_option_color_default */ @@ -1261,6 +1375,22 @@ TEST(CoreConfigFileWithNewOptions, OptionColor) /* * Tests functions: + * config_file_option_color_inherited + */ + +TEST(CoreConfigFileWithNewOptions, OptionColorInherited) +{ + POINTERS_EQUAL(NULL, config_file_option_color_inherited (NULL)); + + STRCMP_EQUAL("blue", config_file_option_color_inherited (ptr_option_col_child)); + config_file_option_set (ptr_option_col, "red", 1); + STRCMP_EQUAL("red", config_file_option_color_inherited (ptr_option_col_child)); + config_file_option_reset (ptr_option_col, 1); + STRCMP_EQUAL("blue", config_file_option_color_inherited (ptr_option_col_child)); +} + +/* + * Tests functions: * config_file_option_enum * config_file_option_enum_default */ @@ -1300,6 +1430,22 @@ TEST(CoreConfigFileWithNewOptions, OptionEnum) /* * Tests functions: + * config_file_option_enum_inherited + */ + +TEST(CoreConfigFileWithNewOptions, OptionEnumInherited) +{ + LONGS_EQUAL(0, config_file_option_enum_inherited (NULL)); + + LONGS_EQUAL(1, config_file_option_enum_inherited (ptr_option_enum_child)); + config_file_option_set (ptr_option_enum, "v3", 1); + LONGS_EQUAL(2, config_file_option_enum_inherited (ptr_option_enum_child)); + config_file_option_reset (ptr_option_enum, 1); + LONGS_EQUAL(1, config_file_option_enum_inherited (ptr_option_enum_child)); +} + +/* + * Tests functions: * config_file_option_escape */ |