yin parser CHANGE add support for identity element
diff --git a/tests/src/test_parser_yin.c b/tests/src/test_parser_yin.c
index ce30903..a0c9853 100644
--- a/tests/src/test_parser_yin.c
+++ b/tests/src/test_parser_yin.c
@@ -38,6 +38,7 @@
void lysp_revision_free(struct ly_ctx *ctx, struct lysp_revision *rev);
void lysp_include_free(struct ly_ctx *ctx, struct lysp_include *include);
void lysp_feature_free(struct ly_ctx *ctx, struct lysp_feature *feat);
+void lysp_ident_free(struct ly_ctx *ctx, struct lysp_ident *ident);
struct state {
struct ly_ctx *ctx;
@@ -2470,6 +2471,57 @@
st->finished_correctly = true;
}
+static void
+test_identity_elem(void **state)
+{
+ struct state *st = *state;
+ const char *data;
+ struct lysp_ident *identities = NULL;
+
+ /* max subelems */
+ st->yin_ctx->mod_version = LYS_VERSION_1_1;
+ data = ELEMENT_WRAPPER_START
+ "<identity name=\"ident-name\">"
+ "<if-feature name=\"iff\"/>"
+ "<base name=\"base-name\"/>"
+ "<status value=\"deprecated\"/>"
+ "<description><text>desc</text></description>"
+ "<reference><text>ref</text></reference>"
+ "</identity>"
+ ELEMENT_WRAPPER_END;
+ assert_int_equal(test_element_helper(st, &data, &identities, NULL, NULL, true), LY_SUCCESS);
+ assert_string_equal(identities->name, "ident-name");
+ assert_string_equal(*identities->bases, "base-name");
+ assert_string_equal(*identities->iffeatures, "iff");
+ assert_string_equal(identities->dsc, "desc");
+ assert_string_equal(identities->ref, "ref");
+ assert_true(identities->flags & LYS_STATUS_DEPRC);
+ assert_null(identities->exts);
+ FREE_ARRAY(st->ctx, identities, lysp_ident_free);
+ identities = NULL;
+
+ /* min subelems */
+ data = ELEMENT_WRAPPER_START "<identity name=\"ident-name\" />" ELEMENT_WRAPPER_END;
+ assert_int_equal(test_element_helper(st, &data, &identities, NULL, NULL, true), LY_SUCCESS);
+ assert_string_equal(identities->name, "ident-name");
+ FREE_ARRAY(st->ctx, identities, lysp_ident_free);
+ identities = NULL;
+
+ /* invalid */
+ st->yin_ctx->mod_version = LYS_VERSION_1_0;
+ data = ELEMENT_WRAPPER_START
+ "<identity name=\"ident-name\">"
+ "<if-feature name=\"iff\"/>"
+ "</identity>"
+ ELEMENT_WRAPPER_END;
+ assert_int_equal(test_element_helper(st, &data, &identities, NULL, NULL, false), LY_EVALID);
+ logbuf_assert("Invalid sub-elemnt \"if-feature\" of \"identity\" element - this sub-element is allowed only in modules with version 1.1 or newer. Line number 1.");
+ FREE_ARRAY(st->ctx, identities, lysp_ident_free);
+ identities = NULL;
+
+ st->finished_correctly = true;
+}
+
int
main(void)
{
@@ -2529,6 +2581,7 @@
cmocka_unit_test_setup_teardown(test_revision_elem, setup_element_test, teardown_element_test),
cmocka_unit_test_setup_teardown(test_include_elem, setup_element_test, teardown_element_test),
cmocka_unit_test_setup_teardown(test_feature_elem, setup_element_test, teardown_element_test),
+ cmocka_unit_test_setup_teardown(test_identity_elem, setup_element_test, teardown_element_test),
};