blob: dfac338fb4672806e0052c3d604496a45878a337 [file] [log] [blame]
Laurence Lundblade2ded3d92018-10-09 21:36:11 +08001/*==============================================================================
Laurence Lundbladed92a6162018-11-01 11:38:35 +07002 Copyright (c) 2016-2018, The Linux Foundation.
Laurence Lundbladef0ea5f32019-01-11 20:10:26 -08003 Copyright (c) 2018-2019, Laurence Lundblade.
Laurence Lundbladed92a6162018-11-01 11:38:35 +07004 All rights reserved.
Laurence Lundblade3aee3a32018-12-17 16:17:45 -08005
Laurence Lundblade0dbc9172018-11-01 14:17:21 +07006Redistribution and use in source and binary forms, with or without
7modification, are permitted provided that the following conditions are
8met:
9 * Redistributions of source code must retain the above copyright
10 notice, this list of conditions and the following disclaimer.
11 * Redistributions in binary form must reproduce the above
12 copyright notice, this list of conditions and the following
13 disclaimer in the documentation and/or other materials provided
14 with the distribution.
15 * Neither the name of The Linux Foundation nor the names of its
16 contributors, nor the name "Laurence Lundblade" may be used to
17 endorse or promote products derived from this software without
18 specific prior written permission.
Laurence Lundblade3aee3a32018-12-17 16:17:45 -080019
Laurence Lundblade0dbc9172018-11-01 14:17:21 +070020THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
21WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
22MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
23ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
24BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
27BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
28WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
29OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
30IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Laurence Lundbladed92a6162018-11-01 11:38:35 +070031 ==============================================================================*/
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080032
33#ifndef __QCBOR__qcbort_decode_tests__
34#define __QCBOR__qcbort_decode_tests__
35
36#include "qcbor.h"
37
38
Laurence Lundblade3aee3a32018-12-17 16:17:45 -080039/*
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080040 Notes:
Laurence Lundblade3aee3a32018-12-17 16:17:45 -080041
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080042 - All the functions in qcbor.h are called once in the aggregation of all the tests below.
Laurence Lundblade3aee3a32018-12-17 16:17:45 -080043
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080044 - All the types that are supported are given as input and parsed by these tests
Laurence Lundblade3aee3a32018-12-17 16:17:45 -080045
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080046 - There is some hostile input such as invalid lengths and CBOR too complex
47 and types this parser doesn't handle
Laurence Lundblade3aee3a32018-12-17 16:17:45 -080048
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080049 */
50
51
52
53
54/*
55 Parse a well-known set of integers including those around the boundaries and
56 make sure the expected values come out
57 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +080058int IntegerValuesParseTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080059
60
61
62
63
64/*
65 Decode a simple CBOR encoded array and make sure it returns all the correct values.
66 This is a decode test.
67 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +080068int SimpleArrayTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080069
Laurence Lundblade9916b1b2019-09-07 22:33:25 -070070/*
71 Tests with empty maps and arrays
72 */
73int EmptyMapsAndArraysTest(void);
74
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080075
76/*
77 Make sure a maximally deep array can be parsed and that the
78 reported nesting level is correct. This uses test vector
79 of CBOR encoded data with a depth of 10. This a parse test.
80 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +080081int ParseDeepArrayTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080082
83
84/*
85 See that the correct error is reported when parsing
86 an array of depth 11, one too large.
87 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +080088int ParseTooDeepArrayTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080089
90
91/*
92 Try to parse some legit CBOR types that this parsers
93 doesn't support.
94 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +080095int UnsupportedCBORDecodeTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080096
97
Laurence Lundblade3aee3a32018-12-17 16:17:45 -080098/*
Laurence Lundblade2ded3d92018-10-09 21:36:11 +080099 This takes the encoded CBOR integers used in the above test and parses
100 it over and over with one more byte less each time. It should fail
101 every time on incorrect CBOR input. This is a hostile input decode test.
102 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800103int ShortBufferParseTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800104
105
Laurence Lundblade3aee3a32018-12-17 16:17:45 -0800106/*
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800107 Same as ShortBufferParseTest, but with a different encoded CBOR input.
108 It is another hostile input test
109 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800110int ShortBufferParseTest2(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800111
112
113/*
114 Parses the somewhat complicated CBOR MAP and makes sure all the correct
115 values parse out. About 15 values are tested. This is a decode test.
116 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800117int ParseMapTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800118
119
120
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800121int FloatValuesTest1(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800122
123
124
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800125int SimpleValuesTest1(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800126
127
Laurence Lundbladeccfb8cd2018-12-07 21:11:30 +0900128/*
Laurence Lundblade3aee3a32018-12-17 16:17:45 -0800129
Laurence Lundbladeccfb8cd2018-12-07 21:11:30 +0900130 */
131int ParseMapAsArrayTest(void);
132
133
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800134
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800135int ParseSimpleTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800136
137
Laurence Lundbladebb1062e2019-08-12 23:28:54 -0700138/*
139 This tests all the not-well-formed CBOR from the CBOR RFC.
140 (This is the CBORbis RFC which is not yet published at the
141 time this test was added).
142 */
143int NotWellFormedTests(void);
144
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800145
146/*
147 Tests a number of failure cases on bad CBOR to get the right error code
148 */
Laurence Lundblade3a6042e2019-06-28 19:58:04 -0700149int DecodeFailureTests(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800150
151
152/*
Laurence Lundbladea2e29072018-12-30 09:20:06 -0800153 Parses all possible inputs that are two bytes long. Main point
154 is that the test doesn't crash as it doesn't evaluate the
155 input for correctness in any way.
Laurence Lundbladedf1c1cf2019-01-17 11:55:05 -0800156
Laurence Lundbladea2e29072018-12-30 09:20:06 -0800157 (Parsing all possible 3 byte strings takes too long on all but
Laurence Lundbladedf1c1cf2019-01-17 11:55:05 -0800158 very fast machines).
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800159 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800160int ComprehensiveInputTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800161
162
163/*
Laurence Lundbladea2e29072018-12-30 09:20:06 -0800164 Parses all possible inputs that are four bytes long. Main point
165 is that the test doesn't crash as it doesn't evaluate the
166 input for correctness in any way. This runs very slow, so it
167 is only practical as a once-in-a-while regression test on
168 fast machines.
169 */
170int BigComprehensiveInputTest(void);
171
172
173/*
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800174 Thest the date types -- epoch and strings
175 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800176int DateParseTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800177
178
179/*
180 Test optional tags like the CBOR magic number.
181 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800182int OptTagParseTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800183
184
185/*
186 Parse some big numbers, positive and negative
187 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800188int BignumParseTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800189
190
Laurence Lundbladeea567ac2018-12-09 14:03:21 -0800191int StringDecoderModeFailTest(void);
192
193
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800194/*
195 Parse some nested maps
196 */
Laurence Lundblade9e3651c2018-10-10 11:49:55 +0800197int NestedMapTest(void);
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800198
Laurence Lundbladefab1b522018-10-19 13:40:52 +0530199
200/*
201 Parse maps with indefinite lengths
202 */
Laurence Lundblade742df4a2018-10-13 20:07:17 +0800203int NestedMapTestIndefLen(void);
204
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800205
Laurence Lundbladefab1b522018-10-19 13:40:52 +0530206/*
207 Parse some maps and arrays with indefinite lengths.
208 Includes some error cases.
209 */
Laurence Lundbladea44d5062018-10-17 18:45:12 +0530210int IndefiniteLengthArrayMapTest(void);
Laurence Lundblade4d1ecba2018-10-12 21:22:30 +0800211
Laurence Lundbladefab1b522018-10-19 13:40:52 +0530212
213/*
214 Parse indefinite length strings. Uses
215 MemPool. Includes error cases.
216 */
Laurence Lundbladea44d5062018-10-17 18:45:12 +0530217int IndefiniteLengthStringTest(void);
Laurence Lundblade4d1ecba2018-10-12 21:22:30 +0800218
Laurence Lundbladefab1b522018-10-19 13:40:52 +0530219
220/*
221 Test deep nesting of indefinite length
222 maps and arrays including too deep.
223 */
Laurence Lundbladea44d5062018-10-17 18:45:12 +0530224int IndefiniteLengthNestTest(void);
225
Laurence Lundbladefab1b522018-10-19 13:40:52 +0530226
227/*
228 Test parsing strings were all strings, not
229 just indefinite length strings, are
230 allocated. Includes error test cases.
231 */
Laurence Lundbladea44d5062018-10-17 18:45:12 +0530232int AllocAllStringsTest(void);
233
Laurence Lundblade0155b622018-10-12 20:04:37 +0800234
Laurence Lundbladefab1b522018-10-19 13:40:52 +0530235/*
236 Direct test of MemPool string allocator
237 */
238int MemPoolTest(void);
Laurence Lundblade0155b622018-10-12 20:04:37 +0800239
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800240
Laurence Lundblade1d7eb632019-02-17 17:23:38 -0800241/*
242 Test the setting up of an external string allocator.
243 */
244int SetUpAllocatorTest(void);
245
246
247
248
Laurence Lundblade2ded3d92018-10-09 21:36:11 +0800249#endif /* defined(__QCBOR__qcbort_decode_tests__) */