blob: fae9f4b59f3b0881ccba4897170dd44b98f5fbf3 [file] [log] [blame]
Laurence Lundblade2ded3d92018-10-09 21:36:11 +08001/*==============================================================================
2Copyright (c) 2016-2018, The Linux Foundation. All rights reserved.
3
4Redistribution and use in source and binary forms, with or without
5modification, are permitted provided that the following conditions are
6met:
7 * Redistributions of source code must retain the above copyright
8 notice, this list of conditions and the following disclaimer.
9 * Redistributions in binary form must reproduce the above
10 copyright notice, this list of conditions and the following
11 disclaimer in the documentation and/or other materials provided
12 with the distribution.
13 * Neither the name of The Linux Foundation nor the names of its
14 contributors may be used to endorse or promote products derived
15 from this software without specific prior written permission.
16
17THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
18WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
19MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
20ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
21BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
24BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
25WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
26OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
27IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28==============================================================================*/
29
30#ifndef __QCBOR__qcbor_encode_tests__
31#define __QCBOR__qcbor_encode_tests__
32
33#include "qcbor.h"
34
35
36/*
37 Notes:
38
39 - All the functions in qcbor.h are called once in the aggregation of all the tests below.
40
41 - All the types that are supported are given as input and parsed by these tests
42
43 - There is some hostile input such as invalid lengths and CBOR too complex
44 and types this parser doesn't handle
45
46 */
47
48
49/*
50 Encode lots of integer values, particularly around the boundary and make sure they
51 Match the expected binary output. Primarily an encoding test.
52 */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +053053int IntegerValuesTest1(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080054
55
56
57/*
58 Create nested arrays to the max depth allowed and make sure it succeeds.
59 This is an encoding test.
60 */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +053061int ArrayNestingTest1(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080062
63
64/*
65 Create nested arrays to one more than the meax depth and make sure it fails.
66 This is an encoding test.
67 */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +053068int ArrayNestingTest2(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080069
70
71/*
72 Encoding test.
73 Create arrays to max depth and close one extra time and look for correct error code
74 */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +053075int ArrayNestingTest3(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080076
77
78/*
79 This tests the QCBOREncode_AddRaw() function by adding two chunks or RAWCBOR to an
80 array and comparing with expected values. This is an encoding test.
81 */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +053082int EncodeRawTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080083
84
85/*
86 This creates a somewhat complicated CBOR MAP and verifies it against expected
87 data. This is an encoding test.
88 */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +053089int MapEncodeTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080090
91
92
93/*
94 Encodes a goodly number of floats and doubles and checks encoding is right
95 */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +053096int FloatValuesTest1(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080097
98
99/*
100 Encodes true, false and the like
101 */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +0530102int SimpleValuesTest1(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800103
104
105/*
106 Encodes most data formats that are supported */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +0530107int EncodeDateTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800108
109
110/*
111 Encodes particular data structure that a particular app will need...
112 */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +0530113int RTICResultsTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800114
115
116/*
117 Calls all public encode methods in qcbor.h once.
118 */
Laurence Lundbladedc6e28e2018-10-11 19:19:27 +0530119int AllAddMethodsTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800120
121/*
122 The binary string wrapping of maps and arrays used by COSE
123 */
Laurence Lundblade684aec22018-10-12 19:33:53 +0800124int bstrwraptest(void);
125
126int bstr_wrap_error_test(void);
127
128int bstr_wrap_nest_test(void);
129
130int cose_sign1_tbs_test(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800131
132
133
134#endif /* defined(__QCBOR__qcbor_encode_tests__) */