/* * Copyright (c) 2015 SPUDlib authors. See LICENSE file. */ #include #include #include #include #include #include #include "cn-cbor/cn-cbor.h" #define CTEST_MAIN #include "ctest.h" int main(int argc, const char *argv[]) { return ctest_main(argc, argv); } #ifdef USE_CBOR_CONTEXT #define CONTEXT_NULL , NULL #define CONTEXT_NULL_COMMA NULL, #else #define CONTEXT_NULL #define CONTEXT_NULL_COMMA #endif typedef struct _buffer { size_t sz; unsigned char *ptr; } buffer; static bool parse_hex(char *inp, buffer *b) { int len = strlen(inp); size_t i; if (len%2 != 0) { b->sz = -1; b->ptr = NULL; return false; } b->sz = len / 2; b->ptr = malloc(b->sz); for (i=0; isz; i++) { sscanf(inp+(2*i), "%02hhx", &b->ptr[i]); } return true; } CTEST(cbor, error) { ASSERT_STR(cn_cbor_error_str[CN_CBOR_NO_ERROR], "CN_CBOR_NO_ERROR"); ASSERT_STR(cn_cbor_error_str[CN_CBOR_ERR_OUT_OF_DATA], "CN_CBOR_ERR_OUT_OF_DATA"); ASSERT_STR(cn_cbor_error_str[CN_CBOR_ERR_NOT_ALL_DATA_CONSUMED], "CN_CBOR_ERR_NOT_ALL_DATA_CONSUMED"); ASSERT_STR(cn_cbor_error_str[CN_CBOR_ERR_ODD_SIZE_INDEF_MAP], "CN_CBOR_ERR_ODD_SIZE_INDEF_MAP"); ASSERT_STR(cn_cbor_error_str[CN_CBOR_ERR_BREAK_OUTSIDE_INDEF], "CN_CBOR_ERR_BREAK_OUTSIDE_INDEF"); ASSERT_STR(cn_cbor_error_str[CN_CBOR_ERR_MT_UNDEF_FOR_INDEF], "CN_CBOR_ERR_MT_UNDEF_FOR_INDEF"); ASSERT_STR(cn_cbor_error_str[CN_CBOR_ERR_RESERVED_AI], "CN_CBOR_ERR_RESERVED_AI"); ASSERT_STR(cn_cbor_error_str[CN_CBOR_ERR_WRONG_NESTING_IN_INDEF_STRING], "CN_CBOR_ERR_WRONG_NESTING_IN_INDEF_STRING"); ASSERT_STR(cn_cbor_error_str[CN_CBOR_ERR_INVALID_PARAMETER], "CN_CBOR_ERR_INVALID_PARAMETER"); ASSERT_STR(cn_cbor_error_str[CN_CBOR_ERR_OUT_OF_MEMORY], "CN_CBOR_ERR_OUT_OF_MEMORY"); ASSERT_STR(cn_cbor_error_str[CN_CBOR_ERR_FLOAT_NOT_SUPPORTED], "CN_CBOR_ERR_FLOAT_NOT_SUPPORTED"); } CTEST(cbor, parse) { cn_cbor_errback err; char *tests[] = { "00", // 0 "01", // 1 "17", // 23 "1818", // 24 "190100", // 256 "1a00010000", // 65536 "1b0000000100000000", // 4294967296 "20", // -1 "37", // -24 "3818", // -25 "390100", // -257 "3a00010000", // -65537 "3b0000000100000000", // -4294967297 "4161", // h"a" "6161", // "a" "80", // [] "8100", // [0] "820102", // [1,2] "818100", // [[0]] "a1616100", // {"a":0} "d8184100", // tag "f4", // false "f5", // true "f6", // null "f7", // undefined "f8ff", // simple(255) #ifndef CBOR_NO_FLOAT "f93c00", // 1.0 "f9bc00", // -1.0 "f903ff", // 6.097555160522461e-05 "f90400", // 6.103515625e-05 "f907ff", // 0.00012201070785522461 "f90800", // 0.0001220703125 "fa47800000", // 65536.0 "fb3ff199999999999a", // 1.1 "f97e00", // NaN #endif /* CBOR_NO_FLOAT */ "5f42010243030405ff", // (_ h'0102', h'030405') "7f61616161ff", // (_ "a", "a") "9fff", // [_ ] "9f9f9fffffff", // [_ [_ [_ ]]] "9f009f00ff00ff", // [_ 0, [_ 0], 0] "bf61610161629f0203ffff", // {_ "a": 1, "b": [_ 2, 3]} }; cn_cbor *cb; buffer b; size_t i; unsigned char encoded[1024]; ssize_t enc_sz; for (i=0; ilength == 2); cn_cbor_mapput_int(cb_map, -7, cb_data CONTEXT_NULL, &err); ASSERT_TRUE(err.err == CN_CBOR_NO_ERROR); ASSERT_TRUE(cb_map->length == 4); cn_cbor_mapput_string(cb_map, "foo", cn_cbor_string_create(data CONTEXT_NULL, &err) CONTEXT_NULL, &err); ASSERT_TRUE(err.err == CN_CBOR_NO_ERROR); ASSERT_TRUE(cb_map->length == 6); cn_cbor_map_put(cb_map, cn_cbor_string_create("bar" CONTEXT_NULL, &err), cn_cbor_string_create("qux" CONTEXT_NULL, &err), &err); ASSERT_TRUE(err.err == CN_CBOR_NO_ERROR); ASSERT_TRUE(cb_map->length == 8); #ifndef CBOR_NO_FLOAT cn_cbor_mapput_int(cb_map, 42, cb_dbl CONTEXT_NULL, &err); ASSERT_TRUE(err.err == CN_CBOR_NO_ERROR); ASSERT_TRUE(cb_map->length == 10); #endif val = cn_cbor_mapget_int(cb_map, 5); ASSERT_NOT_NULL(val); ASSERT_TRUE(val->v.sint == 256); val = cn_cbor_mapget_int(cb_map, -7); ASSERT_NOT_NULL(val); ASSERT_STR(val->v.str, "abc"); #ifndef CBOR_NO_FLOAT val = cn_cbor_mapget_int(cb_map, 42); ASSERT_NOT_NULL(val); ASSERT_TRUE(val->v.dbl > 3.14 && val->v.dbl < 3.15); #endif cn_cbor_free(cb_map CONTEXT_NULL); } CTEST(cbor, map_errors) { cn_cbor_errback err; cn_cbor *ci; ci = cn_cbor_int_create(65536, CONTEXT_NULL_COMMA &err); cn_cbor_mapput_int(ci, -5, NULL, CONTEXT_NULL_COMMA &err); ASSERT_EQUAL(err.err, CN_CBOR_ERR_INVALID_PARAMETER); cn_cbor_mapput_string(ci, "foo", NULL, CONTEXT_NULL_COMMA &err); ASSERT_EQUAL(err.err, CN_CBOR_ERR_INVALID_PARAMETER); cn_cbor_map_put(ci, NULL, NULL, &err); } CTEST(cbor, array) { cn_cbor_errback err; cn_cbor *a = cn_cbor_array_create(CONTEXT_NULL_COMMA &err); ASSERT_NOT_NULL(a); ASSERT_TRUE(err.err == CN_CBOR_NO_ERROR); ASSERT_EQUAL(a->length, 0); cn_cbor_array_append(a, cn_cbor_int_create(256, CONTEXT_NULL_COMMA &err), &err); ASSERT_TRUE(err.err == CN_CBOR_NO_ERROR); ASSERT_EQUAL(a->length, 1); cn_cbor_array_append(a, cn_cbor_string_create("five", CONTEXT_NULL_COMMA &err), &err); ASSERT_TRUE(err.err == CN_CBOR_NO_ERROR); ASSERT_EQUAL(a->length, 2); } CTEST(cbor, array_errors) { cn_cbor_errback err; cn_cbor *ci = cn_cbor_int_create(12, CONTEXT_NULL_COMMA &err); cn_cbor_array_append(NULL, ci, &err); ASSERT_EQUAL(err.err, CN_CBOR_ERR_INVALID_PARAMETER); cn_cbor_array_append(ci, NULL, &err); ASSERT_EQUAL(err.err, CN_CBOR_ERR_INVALID_PARAMETER); } CTEST(cbor, create_encode) { cn_cbor *map; cn_cbor *cdata; char data[] = "data"; unsigned char encoded[1024]; ssize_t enc_sz; map = cn_cbor_map_create(CONTEXT_NULL_COMMA NULL); ASSERT_NOT_NULL(map); cdata = cn_cbor_data_create((uint8_t*)data, sizeof(data)-1, CONTEXT_NULL_COMMA NULL); ASSERT_NOT_NULL(cdata); ASSERT_TRUE(cn_cbor_mapput_int(map, 0, cdata, CONTEXT_NULL_COMMA NULL)); enc_sz = cn_cbor_encoder_write(encoded, 0, sizeof(encoded), map); ASSERT_EQUAL(7, enc_sz); }