libamxd  6.4.1
Data Model Manager
test_amxd_action_object_validate.c
Go to the documentation of this file.
1 /****************************************************************************
2 **
3 ** SPDX-License-Identifier: BSD-2-Clause-Patent
4 **
5 ** SPDX-FileCopyrightText: Copyright (c) 2023 SoftAtHome
6 **
7 ** Redistribution and use in source and binary forms, with or without modification,
8 ** are permitted provided that the following conditions are met:
9 **
10 ** 1. Redistributions of source code must retain the above copyright notice,
11 ** this list of conditions and the following disclaimer.
12 **
13 ** 2. Redistributions in binary form must reproduce the above copyright notice,
14 ** this list of conditions and the following disclaimer in the documentation
15 ** and/or other materials provided with the distribution.
16 **
17 ** Subject to the terms and conditions of this license, each copyright holder
18 ** and contributor hereby grants to those receiving rights under this license
19 ** a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable
20 ** (except for failure to satisfy the conditions of this license) patent license
21 ** to make, have made, use, offer to sell, sell, import, and otherwise transfer
22 ** this software, where such license applies only to those patent claims, already
23 ** acquired or hereafter acquired, licensable by such copyright holder or contributor
24 ** that are necessarily infringed by:
25 **
26 ** (a) their Contribution(s) (the licensed copyrights of copyright holders and
27 ** non-copyrightable additions of contributors, in source or binary form) alone;
28 ** or
29 **
30 ** (b) combination of their Contribution(s) with the work of authorship to which
31 ** such Contribution(s) was added by such copyright holder or contributor, if,
32 ** at the time the Contribution is added, such addition causes such combination
33 ** to be necessarily infringed. The patent license shall not apply to any other
34 ** combinations which include the Contribution.
35 **
36 ** Except as expressly stated above, no rights or licenses from any copyright
37 ** holder or contributor is granted under this license, whether expressly, by
38 ** implication, estoppel or otherwise.
39 **
40 ** DISCLAIMER
41 **
42 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
43 ** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
44 ** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
45 ** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
46 ** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
47 ** DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
48 ** SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
49 ** CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
50 ** OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
51 ** USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
52 **
53 ****************************************************************************/
54 
55 #include <stdlib.h>
56 #include <stdarg.h>
57 #include <stddef.h>
58 #include <setjmp.h>
59 #include <fcntl.h>
60 #include <unistd.h>
61 #include <signal.h>
62 #include <cmocka.h>
63 
64 #include <amxc/amxc.h>
65 #include <amxp/amxp_signal.h>
66 #include <amxp/amxp_slot.h>
67 
68 #include <amxd/amxd_common.h>
69 #include <amxd/amxd_dm.h>
70 #include <amxd/amxd_object.h>
71 #include <amxd/amxd_parameter.h>
72 #include <amxd/amxd_function.h>
73 #include <amxd/amxd_action.h>
74 
76 
77 #include <amxc/amxc_macros.h>
78 static amxd_dm_t dm;
79 
81  UNUSED amxd_param_t* const p,
82  amxd_action_t reason,
83  UNUSED const amxc_var_t* const args,
84  UNUSED amxc_var_t* const retval,
85  UNUSED void* priv) {
87  uint32_t ivalue = 0;
88  bool bvalue = false;
89  assert_ptr_not_equal(object, NULL);
90  assert_int_equal(reason, action_object_validate);
91 
92  ivalue = amxd_object_get_value(uint32_t, object, "param", NULL);
93  bvalue = amxd_object_get_value(bool, object, "inst_param", NULL);
94 
97  } else if(bvalue && (ivalue > 10)) {
99  } else {
101  }
102 
103  return status;
104 }
105 
107  amxd_object_t* object = NULL;
108  amxd_object_t* template = NULL;
109  amxd_param_t* param = NULL;
110 
111  assert_int_equal(amxd_dm_init(&dm), 0);
112 
113  assert_int_equal(amxd_object_new(&template, amxd_object_template, "parent"), 0);
114  assert_int_equal(amxd_dm_add_root_object(&dm, template), 0);
115  assert_int_equal(amxd_object_new(&object, amxd_object_singleton, "child"), 0);
116  assert_int_equal(amxd_object_add_object(template, object), 0);
117 
118  assert_int_equal(amxd_param_new(&param, "templ_param", AMXC_VAR_ID_CSTRING), 0);
120  assert_int_equal(amxd_object_add_param(template, param), 0);
121  assert_int_equal(amxd_param_new(&param, "inst_param", AMXC_VAR_ID_BOOL), 0);
122  assert_int_equal(amxd_object_add_param(template, param), 0);
123  assert_int_equal(amxd_param_new(&param, "param", AMXC_VAR_ID_UINT32), 0);
126  assert_int_equal(amxd_object_add_param(template, param), 0);
127 
128  assert_int_equal(amxd_param_new(&param, "child_param", AMXC_VAR_ID_CSTRING), 0);
130  assert_int_equal(amxd_object_add_param(object, param), 0);
131  assert_int_equal(amxd_param_new(&param, "child_param2", AMXC_VAR_ID_BOOL), 0);
132  assert_int_equal(amxd_object_add_param(object, param), 0);
133  assert_int_equal(amxd_param_new(&param, "child_param3", AMXC_VAR_ID_UINT64), 0);
134  assert_int_equal(amxd_object_add_param(object, param), 0);
135 
136  return template;
137 }
138 
139 void test_amxd_object_validate(UNUSED void** state) {
140  amxd_object_t* template = NULL;
141  amxd_object_t* instance = NULL;
142 
143  template = test_build_dm();
144 
145  assert_int_equal(amxd_object_new_instance(&instance, template, NULL, 1, NULL), 0);
146  assert_ptr_not_equal(instance, NULL);
147 
148  assert_int_equal(amxd_action_object_validate(instance, NULL, action_object_validate, NULL, NULL, NULL), 0);
149  assert_int_equal(amxd_action_object_validate(template, NULL, action_object_validate, NULL, NULL, NULL), 0);
150 
151  assert_int_not_equal(amxd_action_object_validate(NULL, NULL, action_object_validate, NULL, NULL, NULL), 0);
152  assert_int_not_equal(amxd_action_object_validate(template, NULL, action_object_read, NULL, NULL, NULL), 0);
153 
154  assert_int_equal(amxd_object_validate(NULL, 0), 0);
155  assert_int_equal(amxd_object_validate(template, 0), 0);
156  assert_int_equal(amxd_object_validate(template, INT32_MAX), 0);
157  assert_int_equal(amxd_object_validate(instance, 0), 0);
158 
159  amxd_dm_clean(&dm);
160 }
161 
162 void test_amxd_object_validate_with_cb(UNUSED void** state) {
163  amxd_object_t* template = NULL;
164  amxd_object_t* instance = NULL;
165 
166  template = test_build_dm();
168  assert_int_equal(amxd_object_new_instance(&instance, template, NULL, 1, NULL), 0);
169  assert_ptr_not_equal(instance, NULL);
170 
171  assert_int_equal(amxd_object_validate(instance, 0), 0);
172  assert_int_equal(amxd_object_validate(template, 0), 0);
173  assert_int_equal(amxd_object_validate(template, INT32_MAX), 0);
174 
177 
178  amxd_object_set_value(bool, instance, "inst_param", true);
179  amxd_object_set_value(uint32_t, instance, "param", 500);
180 
181  assert_int_not_equal(amxd_object_validate(instance, 0), 0);
182  assert_int_equal(amxd_object_validate(template, 0), 0);
183  assert_int_not_equal(amxd_object_validate(template, INT32_MAX), 0);
184 
185  amxd_object_set_value(bool, instance, "inst_param", false);
186 
187  assert_int_equal(amxd_object_validate(instance, 0), 0);
188  assert_int_equal(amxd_object_validate(template, 0), 0);
189  assert_int_equal(amxd_object_validate(template, INT32_MAX), 0);
190 
191  amxd_dm_clean(&dm);
192 }
Ambiorix Data Model Default actions header file.
Ambiorix Data Model API header file.
Ambiorix Data Model RPC methods API header file.
Ambiorix Data Model API header file.
amxd_status_t amxd_object_validate(amxd_object_t *const object, int32_t depth)
amxd_status_t amxd_object_add_action_cb(amxd_object_t *const object, const amxd_action_t reason, amxd_action_fn_t fn, void *priv)
amxd_status_t amxd_object_remove_action_cb(amxd_object_t *const object, const amxd_action_t reason, amxd_action_fn_t fn)
amxd_status_t amxd_param_new(amxd_param_t **param, const char *name, const uint32_t type)
amxd_status_t amxd_param_set_attr(amxd_param_t *param, const amxd_pattr_id_t attr, const bool enable)
@ amxd_pattr_template
Definition: amxd_types.h:355
@ amxd_pattr_private
Definition: amxd_types.h:357
@ amxd_pattr_instance
Definition: amxd_types.h:356
@ action_object_read
Definition: amxd_types.h:117
@ action_object_validate
Definition: amxd_types.h:119
enum _amxd_action amxd_action_t
enum _amxd_status amxd_status_t
@ amxd_status_ok
Definition: amxd_types.h:78
@ amxd_status_unknown_error
Definition: amxd_types.h:79
@ amxd_status_invalid_value
Definition: amxd_types.h:88
@ amxd_object_template
Definition: amxd_types.h:183
@ amxd_object_singleton
Definition: amxd_types.h:181
amxd_status_t amxd_dm_add_root_object(amxd_dm_t *const dm, amxd_object_t *const object)
Adds an object to the root of the data model.
Definition: amxd_dm.c:418
amxd_status_t amxd_dm_init(amxd_dm_t *dm)
Initializes a data model structure.
Definition: amxd_dm.c:334
void amxd_dm_clean(amxd_dm_t *dm)
Cleans a data model structure.
Definition: amxd_dm.c:365
amxd_status_t amxd_action_object_validate(amxd_object_t *const object, amxd_param_t *const param, amxd_action_t reason, const amxc_var_t *const args, amxc_var_t *const retval, void *priv)
Default object validate action implementation.
amxd_status_t amxd_object_add_object(amxd_object_t *const parent, amxd_object_t *const child)
Adds an object in the data model tree.
Definition: amxd_object.c:207
#define amxd_object_get_value(type, object, name, status)
Helper macro for getting a value.
#define amxd_object_set_value(type, object, name, value)
Helper macro for setting a value.
amxd_status_t amxd_object_add_param(amxd_object_t *const object, amxd_param_t *const param)
Adds a parameter definition to an object.
amxd_status_t amxd_object_new_instance(amxd_object_t **object, amxd_object_t *templ, const char *name, uint32_t index, amxc_var_t *values)
Data model object constructor function.
amxd_status_t amxd_object_new(amxd_object_t **object, const amxd_object_type_t type, const char *name)
Data model object constructor function.
Definition: amxd_object.c:185
static amxd_object_type_t amxd_object_get_type(const amxd_object_t *const object)
Returns the object type.
Definition: amxd_object.h:586
static amxd_dm_t dm
static amxd_status_t amxd_test_validate(amxd_object_t *const object, UNUSED amxd_param_t *const p, amxd_action_t reason, UNUSED const amxc_var_t *const args, UNUSED amxc_var_t *const retval, UNUSED void *priv)
void test_amxd_object_validate_with_cb(UNUSED void **state)
void test_amxd_object_validate(UNUSED void **state)
static amxd_object_t * test_build_dm(void)
static amxd_status_t status