From 462b26c1cc041a8fa26deb62cf12f1f351a5b2f6 Mon Sep 17 00:00:00 2001 From: Joshua Haberman Date: Wed, 8 Jul 2009 12:06:47 -0700 Subject: Directory restructuring. --- tests/tests.c | 72 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 tests/tests.c (limited to 'tests/tests.c') diff --git a/tests/tests.c b/tests/tests.c new file mode 100644 index 0000000..7bc5dde --- /dev/null +++ b/tests/tests.c @@ -0,0 +1,72 @@ + +#include +#include +#include +#include "descriptor.c" +#include "upb_enum.c" +#include "upb_parse.c" +#include "upb_context.c" +#include "upb_msg.c" +#include "upb_table.c" + +void test_get_v_uint64_t() +{ + upb_status_t status; + + uint8_t zero[] = {0x00}; + void *zero_buf = zero; + uint64_t zero_val = 0; + status = get_v_uint64_t(&zero_buf, zero + sizeof(zero), &zero_val); + assert(status == UPB_STATUS_OK); + assert(zero_val == 0); + assert(zero_buf == zero + sizeof(zero)); + + uint8_t one[] = {0x01}; + void *one_buf = one; + uint64_t one_val = 0; + status = get_v_uint64_t(&one_buf, one + sizeof(one), &one_val); + assert(status == UPB_STATUS_OK); + assert(one_val == 1); + assert(one_buf == one + sizeof(one)); + + uint8_t twobyte[] = {0xAC, 0x02}; + void *twobyte_buf = twobyte; + uint64_t twobyte_val = 0; + status = get_v_uint64_t(&twobyte_buf, twobyte + sizeof(twobyte), &twobyte_val); + assert(status == UPB_STATUS_OK); + assert(twobyte_val == 300); + assert(twobyte_buf == twobyte + sizeof(twobyte)); + + uint8_t tenbyte[] = {0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89, 0x7F}; + void *tenbyte_buf = tenbyte; + uint64_t tenbyte_val = 0; + status = get_v_uint64_t(&tenbyte_buf, tenbyte + sizeof(tenbyte), &tenbyte_val); + assert(status == UPB_STATUS_OK); + assert(tenbyte_val == 0x89101c305080c101); + assert(tenbyte_buf == tenbyte + sizeof(tenbyte)); + + uint8_t elevenbyte[] = {0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x01}; + void *elevenbyte_buf = elevenbyte; + uint64_t elevenbyte_val = 0; + status = get_v_uint64_t(&elevenbyte_buf, elevenbyte + sizeof(elevenbyte), &elevenbyte_val); + assert(status == UPB_ERROR_UNTERMINATED_VARINT); + status = get_v_uint64_t(&elevenbyte_buf, elevenbyte + sizeof(elevenbyte)-1, &elevenbyte_val); + /* Byte 10 is 0x80, so we know it's unterminated. */ + assert(status == UPB_ERROR_UNTERMINATED_VARINT); + status = get_v_uint64_t(&elevenbyte_buf, elevenbyte + sizeof(elevenbyte)-2, &elevenbyte_val); + assert(status == UPB_STATUS_NEED_MORE_DATA); +} + +void test_upb_context() { + struct upb_context c; + assert(upb_context_init(&c)); + upb_context_free(&c); +} + +int main() +{ + test_get_v_uint64_t(); + test_upb_context(); + printf("All tests passed.\n"); + return 0; +} -- cgit v1.2.3