/* * Copyright (c) 2014-2020 Pavel Kalvoda * * libcbor is free software; you can redistribute it and/or modify * it under the terms of the MIT license. See LICENSE for details. */ #include "assertions.h" #include "cbor.h" #include "test_allocator.h" cbor_item_t *tag; struct cbor_load_result res; unsigned char embedded_tag_data[] = {0xC0, 0x00}; static void test_refcounting(void **_CBOR_UNUSED(_state)) { tag = cbor_load(embedded_tag_data, 2, &res); assert_true(cbor_refcount(tag) == 1); cbor_item_t *item = cbor_tag_item(tag); assert_true(cbor_refcount(item) == 2); cbor_decref(&tag); assert_null(tag); assert_true(cbor_refcount(item) == 1); cbor_decref(&item); assert_null(item); } /* Tag 0 + uint 0 */ static void test_embedded_tag(void **_CBOR_UNUSED(_state)) { tag = cbor_load(embedded_tag_data, 2, &res); assert_true(cbor_typeof(tag) == CBOR_TYPE_TAG); assert_true(cbor_tag_value(tag) == 0); assert_uint8(cbor_move(cbor_tag_item(tag)), 0); cbor_decref(&tag); assert_null(tag); } unsigned char int8_tag_data[] = {0xD8, 0xFF, 0x01}; /* Tag 255 + uint 1 */ static void test_int8_tag(void **_CBOR_UNUSED(_state)) { tag = cbor_load(int8_tag_data, 3, &res); assert_true(cbor_typeof(tag) == CBOR_TYPE_TAG); assert_true(cbor_tag_value(tag) == 255); assert_uint8(cbor_move(cbor_tag_item(tag)), 1); cbor_decref(&tag); assert_null(tag); } unsigned char int16_tag_data[] = {0xD9, 0xFF, 0x00, 0x02}; /* Tag 255 << 8 + uint 2 */ static void test_int16_tag(void **_CBOR_UNUSED(_state)) { tag = cbor_load(int16_tag_data, 4, &res); assert_true(cbor_typeof(tag) == CBOR_TYPE_TAG); assert_true(cbor_tag_value(tag) == 255 << 8); assert_uint8(cbor_move(cbor_tag_item(tag)), 2); cbor_decref(&tag); assert_null(tag); } unsigned char int32_tag_data[] = {0xDA, 0xFF, 0x00, 0x00, 0x00, 0x03}; /* uint 3 */ static void test_int32_tag(void **_CBOR_UNUSED(_state)) { tag = cbor_load(int32_tag_data, 6, &res); assert_true(cbor_typeof(tag) == CBOR_TYPE_TAG); assert_true(cbor_tag_value(tag) == 4278190080ULL); assert_uint8(cbor_move(cbor_tag_item(tag)), 3); cbor_decref(&tag); assert_null(tag); } unsigned char int64_tag_data[] = {0xDB, 0xFF, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x04}; /* uint 4 */ static void test_int64_tag(void **_CBOR_UNUSED(_state)) { tag = cbor_load(int64_tag_data, 10, &res); assert_true(cbor_typeof(tag) == CBOR_TYPE_TAG); assert_true(cbor_tag_value(tag) == 18374686479671623680ULL); assert_uint8(cbor_move(cbor_tag_item(tag)), 4); cbor_decref(&tag); assert_null(tag); } unsigned char nested_tag_data[] = {0xC0, 0xC1, 0x18, 0x2A}; /* Tag 0, tag 1 + uint 0 */ static void test_nested_tag(void **_CBOR_UNUSED(_state)) { tag = cbor_load(nested_tag_data, 4, &res); assert_true(cbor_typeof(tag) == CBOR_TYPE_TAG); assert_true(cbor_tag_value(tag) == 0); cbor_item_t *nested_tag = cbor_tag_item(tag); assert_true(cbor_typeof(nested_tag) == CBOR_TYPE_TAG); assert_true(cbor_tag_value(nested_tag) == 1); assert_uint8(cbor_move(cbor_tag_item(nested_tag)), 42); cbor_decref(&tag); assert_null(tag); cbor_decref(&nested_tag); assert_null(nested_tag); } static void test_build_tag(void **_CBOR_UNUSED(_state)) { tag = cbor_build_tag(1, cbor_move(cbor_build_uint8(42))); assert_true(cbor_typeof(tag) == CBOR_TYPE_TAG); assert_size_equal(cbor_tag_value(tag), 1); assert_uint8(cbor_move(cbor_tag_item(tag)), 42); cbor_decref(&tag); } static void test_build_tag_failure(void **_CBOR_UNUSED(_state)) { cbor_item_t *tagged_item = cbor_build_uint8(42); WITH_FAILING_MALLOC({ assert_null(cbor_build_tag(1, tagged_item)); }); assert_size_equal(cbor_refcount(tagged_item), 1); cbor_decref(&tagged_item); } static void test_tag_creation(void **_CBOR_UNUSED(_state)) { WITH_FAILING_MALLOC({ assert_null(cbor_new_tag(42)); }); } int main(void) { const struct CMUnitTest tests[] = { cmocka_unit_test(test_refcounting), cmocka_unit_test(test_embedded_tag), cmocka_unit_test(test_int8_tag), cmocka_unit_test(test_int16_tag), cmocka_unit_test(test_int32_tag), cmocka_unit_test(test_int64_tag), cmocka_unit_test(test_nested_tag), cmocka_unit_test(test_build_tag), cmocka_unit_test(test_build_tag_failure), cmocka_unit_test(test_tag_creation), }; return cmocka_run_group_tests(tests, NULL, NULL); }