blob: 038465c554b8974eb42b7e50a4a46a33a46f113d [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 */
53int IntegerValuesTest1();
54
55
56
57/*
58 Create nested arrays to the max depth allowed and make sure it succeeds.
59 This is an encoding test.
60 */
61int ArrayNestingTest1();
62
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 */
68int ArrayNestingTest2();
69
70
71/*
72 Encoding test.
73 Create arrays to max depth and close one extra time and look for correct error code
74 */
75int ArrayNestingTest3();
76
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 */
82int EncodeRawTest();
83
84
85/*
86 This creates a somewhat complicated CBOR MAP and verifies it against expected
87 data. This is an encoding test.
88 */
89int MapEncodeTest();
90
91
92
93/*
94 Encodes a goodly number of floats and doubles and checks encoding is right
95 */
96int FloatValuesTest1();
97
98
99/*
100 Encodes true, false and the like
101 */
102int SimpleValuesTest1();
103
104
105/*
106 Encodes most data formats that are supported */
107int EncodeDateTest();
108
109
110/*
111 Encodes particular data structure that a particular app will need...
112 */
113int RTICResultsTest();
114
115
116/*
117 Calls all public encode methods in qcbor.h once.
118 */
119int AllAddMethodsTest();
120
121/*
122 The binary string wrapping of maps and arrays used by COSE
123 */
124int BStrWrapTests();
125
126
127
128#endif /* defined(__QCBOR__qcbor_encode_tests__) */