#include #include #include #include #include #include #include #include #include static DMOBJ *TR181_ROOT_TREE = tEntryRoot; static DM_MAP_VENDOR *TR181_VENDOR_EXTENSION[2] = { tVendorExtension, tVendorExtensionOverwrite }; static DM_MAP_VENDOR_EXCLUDE *TR181_VENDOR_EXTENSION_EXCLUDE = tVendorExtensionExclude; static int setup(void **state) { struct dmctx *ctx = calloc(1, sizeof(struct dmctx)); if (!ctx) return -1; bbf_ctx_init(ctx, TR181_ROOT_TREE, TR181_VENDOR_EXTENSION, TR181_VENDOR_EXTENSION_EXCLUDE); *state = ctx; return 0; } static int teardown_commit(void **state) { struct dmctx *ctx = (struct dmctx *) *state; bbf_entry_restart_services(NULL, true); bbf_ctx_clean(ctx); free(ctx); return 0; } static int group_init(void **state) { bbf_global_init(TR181_ROOT_TREE, TR181_VENDOR_EXTENSION, TR181_VENDOR_EXTENSION_EXCLUDE, "/etc/bbfdm/plugins"); return 0; } static int group_teardown(void **state) { bbf_global_clean(TR181_ROOT_TREE); return 0; } static void validate_parameter(struct dmctx *ctx, const char *name, const char *value, const char *type) { struct dm_parameter *n; list_for_each_entry(n, &ctx->list_parameter, list) { // check the returned path assert_string_equal(n->name, name); // check the returned value assert_string_equal(n->data, value); // check the returned type assert_string_equal(n->type, type); } bbf_ctx_clean_sub(ctx); bbf_ctx_init_sub(ctx, TR181_ROOT_TREE, TR181_VENDOR_EXTENSION, TR181_VENDOR_EXTENSION_EXCLUDE); } static void test_api_bbfdm_get_set_standard_parameter(void **state) { struct dmctx *ctx = (struct dmctx *) *state; int fault = 0; // get value ==> expected "0" error ctx->in_param = "Device.WiFi.Radio.1.Channel"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.WiFi.Radio.1.Channel", "36", "xsd:unsignedInt"); // Set Wrong Value ==> expected "9007" error ctx->in_param = "Device.WiFi.Radio.1.Channel"; ctx->in_value = "64t"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error ctx->in_param = "Device.WiFi.Radio.1.Channel"; ctx->in_value = "100"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.WiFi.Radio.1.Channel"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter after setting to 64: name, type, value validate_parameter(ctx, "Device.WiFi.Radio.1.Channel", "100", "xsd:unsignedInt"); } static void test_api_bbfdm_get_set_json_parameter(void **state) { struct dmctx *ctx = (struct dmctx *) *state; int fault = 0; // get value ==> expected "0" error ctx->in_param = "Device.WiFi.X_IOPSYS_EU_Radio.1.Noise"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.WiFi.X_IOPSYS_EU_Radio.1.Noise", "-87", "xsd:int"); // get value ==> expected "0" error ctx->in_param = "Device.WiFi.X_IOPSYS_EU_Radio.2.Noise"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.WiFi.X_IOPSYS_EU_Radio.2.Noise", "-85", "xsd:int"); // get value ==> expected "0" error ctx->in_param = "Device.WiFi.X_IOPSYS_EU_Radio.2.Band"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.WiFi.X_IOPSYS_EU_Radio.2.Band", "2.4GHz", "xsd:string"); // get value ==> expected "0" error ctx->in_param = "Device.WiFi.X_IOPSYS_EU_Radio.1.Stats.BytesSent"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.WiFi.X_IOPSYS_EU_Radio.1.Stats.BytesSent", "14418177", "xsd:unsignedInt"); // get value ==> expected "0" error ctx->in_param = "Device.WiFi.X_IOPSYS_EU_Radio.2.Stats.BytesSent"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.WiFi.X_IOPSYS_EU_Radio.2.Stats.BytesSent", "14417451", "xsd:unsignedInt"); } static void test_api_bbfdm_get_set_json_v1_parameter(void **state) { struct dmctx *ctx = (struct dmctx *) *state; char *value = NULL; int fault = 0; // get value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.Password"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UCI_TEST_V1.Password", "", "xsd:string"); // set value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.Password"; ctx->in_value = "iopsys_test"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.Password"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UCI_TEST_V1.Password", "", "xsd:string"); // validate uci config fault = dmuci_get_option_value_string("users", "user", "password_required", &value); assert_int_equal(fault, 0); assert_string_equal(value, "iopsys_test"); // get value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSDNumberOfEntries"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UCI_TEST_V1.OWSDNumberOfEntries", "3", "xsd:unsignedInt"); // set value ==> expected "9008" error ctx->in_param = "Device.UCI_TEST_V1.OWSDNumberOfEntries"; ctx->in_value = "5"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, FAULT_9008); // get value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.2.IPv6"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UCI_TEST_V1.OWSD.2.IPv6", "off", "xsd:string"); // set value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.2.IPv6"; ctx->in_value = "on"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.2.IPv6"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UCI_TEST_V1.OWSD.2.IPv6", "on", "xsd:string"); // get value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.1.Port"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UCI_TEST_V1.OWSD.1.Port", "80", "xsd:unsignedInt"); // set value ==> expected "9007" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.1.Port"; ctx->in_value = "65536"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.1.Port"; ctx->in_value = "8081"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.1.Port"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UCI_TEST_V1.OWSD.1.Port", "8081", "xsd:unsignedInt"); // get value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.3.Password"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UCI_TEST_V1.OWSD.3.Password", "", "xsd:string"); // set value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.3.Password"; ctx->in_value = "owsd_pwd"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.3.Password"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UCI_TEST_V1.OWSD.3.Password", "", "xsd:string"); // validate uci config fault = dmuci_get_option_value_string("owsd", "@owsd_listen[2]", "password", &value); assert_int_equal(fault, 0); assert_string_equal(value, "owsd_pwd"); // get value ==> expected "0" error ctx->in_param = "Device.UBUS_TEST_V1.Uptime"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UBUS_TEST_V1.Uptime", "5859", "xsd:string"); // set value ==> expected "0" error ctx->in_param = "Device.UBUS_TEST_V1.Uptime"; ctx->in_value = "lan"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.UBUS_TEST_V1.InterfaceNumberOfEntries"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UBUS_TEST_V1.InterfaceNumberOfEntries", "10", "xsd:unsignedInt"); // set value ==> expected "9008" error ctx->in_param = "Device.UBUS_TEST_V1.InterfaceNumberOfEntries"; ctx->in_value = "5"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, FAULT_9008); // get value ==> expected "0" error ctx->in_param = "Device.UBUS_TEST_V1.Interface.3.MacAddress"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UBUS_TEST_V1.Interface.3.MacAddress", "60:8d:26:c4:96:f7", "xsd:string"); // set value ==> expected "9008" error ctx->in_param = "Device.UBUS_TEST_V1.Interface.3.MacAddress"; ctx->in_value = "49:d4:40:71:7e:55"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, FAULT_9008); // get value ==> expected "0" error ctx->in_param = "Device.UBUS_TEST_V1.Interface.4.Ifname"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UBUS_TEST_V1.Interface.4.Ifname", "eth4", "xsd:string"); // set value ==> expected "9008" error ctx->in_param = "Device.UBUS_TEST_V1.Interface.4.Ifname"; ctx->in_value = "lan5"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, FAULT_9008); // get value ==> expected "0" error ctx->in_param = "Device.UBUS_TEST_V1.Interface.2.Media"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.UBUS_TEST_V1.Interface.2.Media", "IEEE 802_3AB_GIGABIT_ETHERNET", "xsd:string"); // set value ==> expected "9008" error ctx->in_param = "Device.UBUS_TEST_V1.Interface.2.Media"; ctx->in_value = "IEEE 802_11AX_5_GHZ"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, FAULT_9008); // get value ==> expected "0" error ctx->in_param = "Device.X_IOPSYS_EU_URLFilter.Profile.1.Name"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_URLFilter.Profile.1.Name", "homeoffice", "xsd:string"); // set value ==> expected "0" error ctx->in_param = "Device.X_IOPSYS_EU_URLFilter.Profile.1.Name"; ctx->in_value = "home+office test"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.X_IOPSYS_EU_URLFilter.Profile.1.Name"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_URLFilter.Profile.1.Name", "home+office test", "xsd:string"); // set value ==> expected "0" error ctx->in_param = "Device.X_IOPSYS_EU_URLFilter.Profile.1.Name"; ctx->in_value = "office_test"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.X_IOPSYS_EU_URLFilter.Profile.1.Name"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_URLFilter.Profile.1.Name", "office_test", "xsd:string"); } static void test_api_bbfdm_get_set_library_parameter(void **state) { struct dmctx *ctx = (struct dmctx *) *state; int fault = 0; // get value ==> expected "0" error ctx->in_param = "Device.WiFi.SSID.1.Enable"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.WiFi.SSID.1.Enable", "1", "xsd:boolean"); // Set Wrong Value ==> expected "9007" error ctx->in_param = "Device.WiFi.SSID.1.Enable"; ctx->in_value = "truee"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error ctx->in_param = "Device.WiFi.SSID.1.Enable"; ctx->in_value = "0"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.WiFi.SSID.1.Enable"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter after setting to 0: name, type, value validate_parameter(ctx, "Device.WiFi.SSID.1.Enable", "0", "xsd:boolean"); } static void test_api_bbfdm_get_set_standard_parameter_alias(void **state) { struct dmctx *ctx = (struct dmctx *) *state; int fault = 0; ctx->instance_mode = INSTANCE_MODE_ALIAS; // get value ==> expected "0" error ctx->in_param = "Device.WiFi.Radio.[cpe-1].Channel"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter : name, type, value validate_parameter(ctx, "Device.WiFi.Radio.[cpe-1].Channel", "100", "xsd:unsignedInt"); // Set Wrong Value ==> expected "9007" error ctx->in_param = "Device.WiFi.Radio.[cpe-1].Channel"; ctx->in_value = "64t"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error ctx->in_param = "Device.WiFi.Radio.[cpe-1].Channel"; ctx->in_value = "52"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.WiFi.Radio.[cpe-1].Channel"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter after setting to 64: name, type, value validate_parameter(ctx, "Device.WiFi.Radio.[cpe-1].Channel", "52", "xsd:unsignedInt"); // set value ==> expected "0" error ctx->in_param = "Device.WiFi.Radio.[cpe-1].Alias"; ctx->in_value = "iopsys_test"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.WiFi.Radio.[iopsys_test].Alias"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter after setting to 64: name, type, value validate_parameter(ctx, "Device.WiFi.Radio.[iopsys_test].Alias", "iopsys_test", "xsd:string"); // set value ==> expected "0" error ctx->in_param = "Device.WiFi.Radio.[iopsys_test].Channel"; ctx->in_value = "116"; fault = bbf_entry_method(ctx, BBF_SET_VALUE); assert_int_equal(fault, 0); // get value ==> expected "0" error ctx->in_param = "Device.WiFi.Radio.[iopsys_test].Channel"; fault = bbf_entry_method(ctx, BBF_GET_VALUE); assert_int_equal(fault, 0); // validate parameter after setting to 64: name, type, value validate_parameter(ctx, "Device.WiFi.Radio.[iopsys_test].Channel", "116", "xsd:unsignedInt"); } #if 0 static void test_api_bbfdm_input_value_validation_json_parameter(void **state) { struct dmctx *ctx = (struct dmctx *) *state; int fault = 0; /* * Validate Boolean parameters */ // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Enable", "64t", NULL); assert_int_equal(fault, FAULT_9007); // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Enable", "truee", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Enable", "true", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Enable", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Enable", "1", "xsd:boolean"); /* * Validate unsignedInt parameters */ // Mapping without range: Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_Retries", "64t", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_Retries", "15600", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_Retries", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Nbr_Retries", "15600", "xsd:unsignedInt"); // Mapping with range: Set Wrong Value out of range ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Port", "1050", NULL); assert_int_equal(fault, FAULT_9007); // Mapping with range: set value in the first range [0-1000] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Port", "1000", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Port", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Port", "1000", "xsd:unsignedInt"); // Mapping with range: set value in the second range [15000-65535] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Port", "20546", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Port", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Port", "20546", "xsd:unsignedInt"); /* * Validate int parameters */ // Mapping with range (only min): Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Min_value", "-300", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Min_value", "-273", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Min_value", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Min_value", "-273", "xsd:int"); // Mapping with range (only max): Set Wrong Value out of range ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Max_value", "280", NULL); assert_int_equal(fault, FAULT_9007); // Mapping with range: set value in the first range [0-1000] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Max_value", "274", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Max_value", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Max_value", "274", "xsd:int"); // Mapping with range: Set Wrong Value out of range ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Value", "-3", NULL); assert_int_equal(fault, FAULT_9007); // Mapping with range: set value in the first range [-10:-5] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Value", "-7", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Value", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.value", "-7", "xsd:int"); // Mapping with range: set value in the second range [-1:10] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Value", "1", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Value", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Value", "1", "xsd:int"); /* * Validate unsignedLong parameters */ // Mapping without range: Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_bytes", "64t", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_bytes", "15600", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_bytes", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Nbr_bytes", "15600", "xsd:unsignedLong"); // Mapping with range: Set Wrong Value out of range ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_packets", "499", NULL); assert_int_equal(fault, FAULT_9007); // Mapping with range: set value in the first range [0-100] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_packets", "99", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_packets", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Nbr_packets", "99", "xsd:unsignedLong"); // Mapping with range: set value in the second range [500-3010] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_packets", "1024", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Nbr_packets", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Nbr_packets", "1024", "xsd:unsignedLong"); /* * Validate long parameters */ // Mapping without range: Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.MaxTxPower", "-300t", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.MaxTxPower", "-273", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.MaxTxPower", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.MaxTxPower", "-273", "xsd:long"); // Mapping with range: Set Wrong Value out of range ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerLimit", "-91", NULL); assert_int_equal(fault, FAULT_9007); // Mapping with range: set value in the first range [-90:36] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerLimit", "274", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerLimit", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerLimit", "274", "xsd:long"); // Mapping with range: Set Wrong Value out of range ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerLimit", "37", NULL); assert_int_equal(fault, FAULT_9007); // Mapping with range: set value in the first range [70:360] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerLimit", "70", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerLimit", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerLimit", "70", "xsd:long"); /* * Validate dateTime parameters */ // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.AssociationTime", "2030-01-01T11:22:33.2Z", NULL); assert_int_equal(fault, FAULT_9007); // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.AssociationTime", "2022-01-01T12:20:22.2222Z", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.AssociationTime", "2022-01-01T12:20:22Z", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.AssociationTime", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.AssociationTime", "2022-01-01T12:20:22Z", "xsd:dateTime"); /* * Validate hexBinary parameters */ // Mapping without range: Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.ButtonColor", "64t", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.ButtonColor", "64ab78cef12", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.ButtonColor", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.ButtonColor", "64ab78cef12", "xsd:hexBinary"); // Mapping with range: Set Wrong Value out of range ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TextColor", "am123", NULL); assert_int_equal(fault, FAULT_9007); // Mapping with range: set value in the first range [3-3] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TextColor", "123abc", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TextColor", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.TextColor", "123abc", "xsd:hexBinary"); // Mapping with range: set value in the second range [5-5] ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TextColor", "12345abcde", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TextColor", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.TextColor", "12345abcde", "xsd:hexBinary"); // Mapping without range: Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.BackgroundColor", "12345abce", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.BackgroundColor", "45a1bd", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.BackgroundColor", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.BackgroundColor", "45a1bd", "xsd:hexBinary"); /* * Validate string parameters */ // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Interface", "64", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Interface", "wan", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Interface", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Interface", "wan", "xsd:string"); // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.IPAddr", "192.168.1.789", NULL); assert_int_equal(fault, FAULT_9007); // Set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.IPAddr", "192.168.117.45", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.IPAddr", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.IPAddr", "192.168.117.45", "xsd:string"); // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Protocol", "OMA-D", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Protocol", "OMA-DM", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Protocol", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Protocol", "OMA-DM", "xsd:string"); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Description", "bbf validate test", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.Description", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.Description", "bbf validate test", "xsd:string"); /* * Validate list string parameters */ // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.FailureReasons", "te,be,re,yu", NULL); assert_int_equal(fault, FAULT_9007); // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.FailureReasons", "ExcessiveDelay,InsufficientBuffers", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.FailureReasons", "LowRate,Other", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.FailureReasons", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.FailureReasons", "LowRate,Other", "xsd:string"); // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.SupportedOperatingChannelBandwidths", "200MHz,10MHz", NULL); assert_int_equal(fault, FAULT_9007); // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.SupportedOperatingChannelBandwidths", "ExcessiveDelay,InsufficientBuffers", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.SupportedOperatingChannelBandwidths", "40MHz,80+80MHz", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.SupportedOperatingChannelBandwidths", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.SupportedOperatingChannelBandwidths", "40MHz,80+80MHz", "xsd:string"); /* * Validate list int parameters */ // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerSupported", "-5,-3,99,120", NULL); assert_int_equal(fault, FAULT_9007); // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerSupported", "-1,9,990", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerSupported", "-1,9,100", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerSupported", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.TransmitPowerSupported", "-1,9,100", "xsd:string"); /* * Validate list unsignedInt parameters */ // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.PriorityRegeneration", "8,1,2,3", NULL); assert_int_equal(fault, FAULT_9007); // Set Wrong Value ==> expected "9007" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.PriorityRegeneration", "1,2,3,4,5,6,7,8", NULL); assert_int_equal(fault, FAULT_9007); // set value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_SET_VALUE, "Device.X_IOPSYS_EU_TEST.1.PriorityRegeneration", "0,1,2,3,4,5,6,7", NULL); assert_int_equal(fault, 0); // get value ==> expected "0" error fault = bbf_entry_method(ctx, BBF_GET_VALUE, "Device.X_IOPSYS_EU_TEST.1.PriorityRegeneration", NULL, NULL); assert_int_equal(fault, 0); // validate parameter after setting to true: name, type, value validate_parameter(ctx, "Device.X_IOPSYS_EU_TEST.1.PriorityRegeneration", "0,1,2,3,4,5,6,7", "xsd:string"); } #endif static void test_api_bbfdm_add_del_standard_object(void **state) { struct dmctx *ctx = (struct dmctx *) *state; int fault = 0; // Get name object ==> expected "0" error ctx->in_param = "Device.Users.User."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, 0); // add object ==> expected "0" error ctx->in_param = "Device.Users.User."; fault = bbf_entry_method(ctx, BBF_ADD_OBJECT); assert_int_equal(fault, 0); // check the new instance assert_non_null(ctx->addobj_instance); assert_string_equal(ctx->addobj_instance, "2"); // delete object ==> expected "0" error ctx->in_param = "Device.Users.User.2."; fault = bbf_entry_method(ctx, BBF_DEL_OBJECT); assert_int_equal(fault, 0); // Get name object after deleting instance 2 ==> expected "9005" error ctx->in_param = "Device.Users.User.2."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, FAULT_9005); // delete all object ==> expected "0" error ctx->in_param = "Device.Users.User."; fault = bbf_entry_method(ctx, BBF_DEL_OBJECT); assert_int_equal(fault, 0); // Get name object after deleting all instances ==> expected "9005" error ctx->in_param = "Device.Users.User.1."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, FAULT_9005); } static void test_api_bbfdm_add_del_json_object(void **state) { struct dmctx *ctx = (struct dmctx *) *state; int fault = 0; // Get name object ==> expected "0" error ctx->in_param = "Device.X_IOPSYS_EU_Dropbear."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, 0); // add object ==> expected "0" error ctx->in_param = "Device.X_IOPSYS_EU_Dropbear."; fault = bbf_entry_method(ctx, BBF_ADD_OBJECT); assert_int_equal(fault, 0); // check the new instance assert_non_null(ctx->addobj_instance); assert_string_equal(ctx->addobj_instance, "2"); // delete object ==> expected "0" error ctx->in_param = "Device.X_IOPSYS_EU_Dropbear.2."; fault = bbf_entry_method(ctx, BBF_DEL_OBJECT); assert_int_equal(fault, 0); // Get name object after deleting instance 2 ==> expected "9005" error ctx->in_param = "Device.X_IOPSYS_EU_Dropbear.2."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, FAULT_9005); // delete all object ==> expected "0" error ctx->in_param = "Device.X_IOPSYS_EU_Dropbear."; fault = bbf_entry_method(ctx, BBF_DEL_OBJECT); assert_int_equal(fault, 0); // Get name object after deleting all instances ==> expected "9005" error ctx->in_param = "Device.X_IOPSYS_EU_Dropbear.1."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, FAULT_9005); } static void test_api_bbfdm_add_del_json_v1_object(void **state) { struct dmctx *ctx = (struct dmctx *) *state; int fault = 0; // Get name object ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, 0); // add object ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD."; fault = bbf_entry_method(ctx, BBF_ADD_OBJECT); assert_int_equal(fault, 0); // check the new instance assert_non_null(ctx->addobj_instance); assert_string_equal(ctx->addobj_instance, "4"); // delete object ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.2."; fault = bbf_entry_method(ctx, BBF_DEL_OBJECT); assert_int_equal(fault, 0); // Get name object after deleting instance 2 ==> expected "9005" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.2."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, FAULT_9005); // delete all object ==> expected "0" error ctx->in_param = "Device.UCI_TEST_V1.OWSD."; fault = bbf_entry_method(ctx, BBF_DEL_OBJECT); assert_int_equal(fault, 0); // Get name object after deleting all instances ==> expected "9005" error ctx->in_param = "Device.UCI_TEST_V1.OWSD.1."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, FAULT_9005); // add object ==> expected "9005" error ctx->in_param = "Device.UBUS_TEST_V1.Interface."; fault = bbf_entry_method(ctx, BBF_ADD_OBJECT); assert_int_equal(fault, FAULT_9005); // delete all object ==> expected "9005" error ctx->in_param = "Device.UBUS_TEST_V1.Interface."; fault = bbf_entry_method(ctx, BBF_DEL_OBJECT); assert_int_equal(fault, FAULT_9005); } static void test_api_bbfdm_add_del_library_object(void **state) { struct dmctx *ctx = (struct dmctx *) *state; int fault = 0; // Get name object ==> expected "0" error ctx->in_param = "Device.WiFi.AccessPoint."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, 0); // Get name object ==> expected "0" error ctx->in_param = "Device.WiFi.SSID."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, 0); // add object ==> expected "0" error ctx->in_param = "Device.WiFi.SSID."; fault = bbf_entry_method(ctx, BBF_ADD_OBJECT); assert_int_equal(fault, 0); // check the new instance assert_non_null(ctx->addobj_instance); assert_string_equal(ctx->addobj_instance, "4"); // delete object ==> expected "0" error ctx->in_param = "Device.WiFi.SSID.2."; fault = bbf_entry_method(ctx, BBF_DEL_OBJECT); assert_int_equal(fault, 0); // Get name object after deleting instance 2 ==> expected "9005" error ctx->in_param = "Device.WiFi.SSID.2."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, FAULT_9005); // delete all object ==> expected "0" error ctx->in_param = "Device.WiFi.SSID."; fault = bbf_entry_method(ctx, BBF_DEL_OBJECT); assert_int_equal(fault, 0); // Get name object after deleting all instances ==> expected "9005" error ctx->in_param = "Device.WiFi.SSID.1."; ctx->nextlevel = true; fault = bbf_entry_method(ctx, BBF_GET_NAME); assert_int_equal(fault, FAULT_9005); } static void test_api_bbfdm_valid_standard_operate(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0; ctx->in_param = "Device.IP.Diagnostics.IPPing()"; ctx->in_value = "{\"Host\":\"iopsys.eu\",\"NumberOfRepetitions\":\"1\",\"Timeout\":\"5000\",\"DataBlockSize\":\"64\"}"; fault = bbf_entry_method(ctx, BBF_OPERATE); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { if (DM_STRCMP(n->name, "Status") == 0) { assert_string_equal(n->data, "Complete"); assert_string_equal(n->type, "xsd:string"); } else if (DM_STRCMP(n->name, "IPAddressUsed") == 0) { assert_string_equal(n->data, ""); assert_string_equal(n->type, "xsd:string"); } else if (DM_STRCMP(n->name, "SuccessCount") == 0) { assert_string_equal(n->data, "1"); assert_string_equal(n->type, "xsd:unsignedInt"); } else if (DM_STRCMP(n->name, "FailureCount") == 0) { assert_string_equal(n->data, "0"); assert_string_equal(n->type, "xsd:unsignedInt"); } else { assert_string_not_equal(n->data, "0"); assert_string_equal(n->type, "xsd:unsignedInt"); } } } static void test_api_bbfdm_valid_standard_list_operate(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0, i = 0; ctx->in_param = "Device."; ctx->dm_type = BBFDM_USP; ctx->nextlevel = false; ctx->iscommand = true; ctx->isevent = false; ctx->isinfo = false; fault = bbf_entry_method(ctx, BBF_SCHEMA); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { if (DM_STRCMP(n->name, "Device.FactoryReset()") == 0) { assert_string_equal(n->type, "xsd:command"); assert_string_equal(n->additional_data, "sync"); assert_null(n->data); } if (DM_STRCMP(n->name, "Device.DeviceInfo.VendorLogFile.{i}.Upload()") == 0) { assert_string_equal(n->type, "xsd:command"); assert_string_equal(n->additional_data, "async"); operation_args *args = (operation_args *)n->data; assert_non_null(args); const char **command_in = args->in; const char **command_out = args->out; assert_non_null(command_in); assert_null(command_out); for (i = 0; command_in[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(command_in[i], "URL"); break; case 1: assert_string_equal(command_in[i], "Username"); break; case 2: assert_string_equal(command_in[i], "Password"); break; } } assert_int_equal(i, 3); } if (DM_STRCMP(n->name, "Device.WiFi.NeighboringWiFiDiagnostic()") == 0) { assert_string_equal(n->type, "xsd:command"); assert_string_equal(n->additional_data, "async"); operation_args *args = (operation_args *)n->data; assert_non_null(args); const char **command_in = args->in; const char **command_out = args->out; assert_null(command_in); assert_non_null(command_out); for (i = 0; command_out[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(command_out[i], "Status"); break; case 1: assert_string_equal(command_out[i], "Result.{i}.Radio"); break; case 2: assert_string_equal(command_out[i], "Result.{i}.SSID"); break; } } assert_int_equal(i, 18); } } } static void test_api_bbfdm_valid_library_operate(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0; ctx->in_param = "Device.X_IOPSYS_EU_PingTEST.Run()"; ctx->in_value = "{\"Host\":\"iopsys.eu\"}"; fault = bbf_entry_method(ctx, BBF_OPERATE); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { assert_string_not_equal(n->data, "0"); assert_string_equal(n->type, "xsd:unsignedInt"); }} static void test_api_bbfdm_valid_library_list_operate(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0, i = 0; ctx->in_param = "Device."; ctx->dm_type = BBFDM_USP; ctx->nextlevel = false; ctx->iscommand = true; ctx->isevent = false; ctx->isinfo = false; fault = bbf_entry_method(ctx, BBF_SCHEMA); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { if (DM_STRCMP(n->name, "Device.X_IOPSYS_EU_Reboot()") == 0) { assert_string_equal(n->type, "xsd:command"); assert_string_equal(n->additional_data, "sync"); assert_null(n->data); } if (DM_STRCMP(n->name, "Device.X_IOPSYS_EU_PingTEST.Run()") == 0) { assert_string_equal(n->type, "xsd:command"); assert_string_equal(n->additional_data, "async"); operation_args *args = (operation_args *)n->data; assert_non_null(args); const char **command_in = args->in; const char **command_out = args->out; assert_non_null(command_in); assert_non_null(command_out); for (i = 0; command_in[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(command_in[i], "Host"); break; } } assert_int_equal(i, 1); for (i = 0; command_out[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(command_out[i], "AverageResponseTime"); break; case 1: assert_string_equal(command_out[i], "MinimumResponseTime"); break; case 2: assert_string_equal(command_out[i], "MaximumResponseTime"); break; } } assert_int_equal(i, 3); } } } static void test_api_bbfdm_valid_json_operate(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0; ctx->in_param = "Device.X_IOPSYS_EU_TEST.1.Status()"; fault = bbf_entry_method(ctx, BBF_OPERATE); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { assert_string_equal(n->name, "Result"); assert_string_equal(n->data, "Success"); assert_string_equal(n->type, "xsd:string"); } } static void test_api_bbfdm_valid_json_list_operate(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0, i = 0; ctx->in_param = "Device."; ctx->dm_type = BBFDM_USP; ctx->nextlevel = false; ctx->iscommand = true; ctx->isevent = false; ctx->isinfo = false; fault = bbf_entry_method(ctx, BBF_SCHEMA); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { if (DM_STRCMP(n->name, "Device.X_IOPSYS_EU_TEST.{i}.Status()") == 0) { assert_string_equal(n->type, "xsd:command"); assert_string_equal(n->additional_data, "async"); operation_args *args = (operation_args *)n->data; assert_non_null(args); const char **command_in = args->in; const char **command_out = args->out; assert_non_null(command_in); assert_non_null(command_out); for (i = 0; command_in[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(command_in[i], "Option"); break; } } assert_int_equal(i, 1); for (i = 0; command_out[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(command_out[i], "Result"); break; } } assert_int_equal(i, 1); } } } static void test_api_bbfdm_valid_json_v1_operate(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0; ctx->in_param = "Device.UBUS_TEST_V1.Interface.3.Status()"; fault = bbf_entry_method(ctx, BBF_OPERATE); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { assert_string_equal(n->name, "Result"); assert_string_equal(n->data, "Success"); assert_string_equal(n->type, "xsd:string"); } } static void test_api_bbfdm_valid_json_v1_list_operate(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0, i = 0; ctx->in_param = "Device."; ctx->dm_type = BBFDM_USP; ctx->nextlevel = false; ctx->iscommand = true; ctx->isevent = false; ctx->isinfo = false; fault = bbf_entry_method(ctx, BBF_SCHEMA); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { if (DM_STRCMP(n->name, "Device.UBUS_TEST_V1.Interface.{i}.Status()") == 0) { assert_string_equal(n->type, "xsd:command"); assert_string_equal(n->additional_data, "async"); operation_args *args = (operation_args *)n->data; assert_non_null(args); const char **command_in = args->in; const char **command_out = args->out; assert_non_null(command_in); assert_non_null(command_out); for (i = 0; command_in[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(command_in[i], "Option"); break; case 1: assert_string_equal(command_out[i], "Value"); break; } } assert_int_equal(i, 2); for (i = 0; command_out[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(command_out[i], "Result"); break; case 1: assert_string_equal(command_out[i], "Value"); break; } } assert_int_equal(i, 2); } } } static void test_api_bbfdm_valid_library_event(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0, idx = 0; ctx->in_param = "Device."; ctx->dm_type = BBFDM_USP; ctx->nextlevel = false; ctx->iscommand = false; ctx->isevent = true; ctx->isinfo = false; fault = bbf_entry_method(ctx, BBF_SCHEMA); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { if (DM_STRCMP(n->name, "Device.X_IOPSYS_EU_WakeUp!") == 0) { assert_string_equal(n->type, "xsd:event"); assert_null(n->data); } if (DM_STRCMP(n->name, "Device.X_IOPSYS_EU_Boot!") == 0) { assert_string_equal(n->type, "xsd:event"); event_args *args = (event_args *)n->data; assert_non_null(args); const char **event_param = args->param; assert_non_null(event_param); for (int i = 0; event_param[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(event_param[i], "CommandKey"); break; case 1: assert_string_equal(event_param[i], "Cause"); break; case 2: assert_string_equal(event_param[i], "FirmwareUpdated"); break; case 3: assert_string_equal(event_param[i], "ParameterMap"); break; } } } idx++; } assert_int_equal(idx, 9); } static void test_api_bbfdm_valid_json_event(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0, idx = 0; ctx->in_param = "Device."; ctx->dm_type = BBFDM_USP; ctx->nextlevel = false; ctx->iscommand = false; ctx->isevent = true; ctx->isinfo = false; fault = bbf_entry_method(ctx, BBF_SCHEMA); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { if (DM_STRCMP(n->name, "Device.X_IOPSYS_EU_TEST.{i}.Periodic!") == 0) { assert_string_equal(n->type, "xsd:event"); assert_null(n->data); } if (DM_STRCMP(n->name, "Device.X_IOPSYS_EU_TEST.{i}.Push!") == 0) { assert_string_equal(n->type, "xsd:event"); event_args *args = (event_args *)n->data; assert_non_null(args); const char **event_param = args->param; assert_non_null(event_param); for (int i = 0; event_param[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(event_param[i], "Data"); break; case 1: assert_string_equal(event_param[i], "Status"); break; } } } idx++; } assert_int_equal(idx, 9); } static void test_api_bbfdm_valid_json_v1_event(void **state) { struct dmctx *ctx = (struct dmctx *) *state; struct dm_parameter *n; int fault = 0, idx = 0; ctx->in_param = "Device."; ctx->dm_type = BBFDM_USP; ctx->nextlevel = false; ctx->iscommand = false; ctx->isevent = true; ctx->isinfo = false; fault = bbf_entry_method(ctx, BBF_SCHEMA); assert_int_equal(fault, 0); list_for_each_entry(n, &ctx->list_parameter, list) { if (DM_STRCMP(n->name, "Device.UBUS_TEST_V1.Interface.{i}.Periodic!") == 0) { assert_string_equal(n->type, "xsd:event"); assert_null(n->data); } if (DM_STRCMP(n->name, "Device.UBUS_TEST_V1.Interface.{i}.Push!") == 0) { assert_string_equal(n->type, "xsd:event"); event_args *args = (event_args *)n->data; assert_non_null(args); const char **event_param = args->param; assert_non_null(event_param); for (int i = 0; event_param[i] != NULL; i++) { switch (i) { case 0: assert_string_equal(event_param[i], "Data"); break; case 1: assert_string_equal(event_param[i], "Status"); break; case 2: assert_string_equal(event_param[i], "Value"); break; } } } idx++; } assert_int_equal(idx, 9); } int main(void) { const struct CMUnitTest tests[] = { // Get/Set Value method test cases cmocka_unit_test_setup_teardown(test_api_bbfdm_get_set_standard_parameter, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_get_set_json_parameter, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_get_set_json_v1_parameter, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_get_set_library_parameter, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_get_set_standard_parameter_alias, setup, teardown_commit), #if 0 cmocka_unit_test_setup_teardown(test_api_bbfdm_input_value_validation_json_parameter, setup, teardown_commit), #endif // Add/Delete Object method test cases cmocka_unit_test_setup_teardown(test_api_bbfdm_add_del_standard_object, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_add_del_json_object, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_add_del_json_v1_object, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_add_del_library_object, setup, teardown_commit), // Operate method test cases cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_standard_operate, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_standard_list_operate, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_library_operate, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_library_list_operate, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_json_operate, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_json_list_operate, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_json_v1_operate, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_json_v1_list_operate, setup, teardown_commit), // Event method test cases cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_library_event, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_json_event, setup, teardown_commit), cmocka_unit_test_setup_teardown(test_api_bbfdm_valid_json_v1_event, setup, teardown_commit), }; return cmocka_run_group_tests(tests, group_init, group_teardown); }