Don't set client_version to the ServerHello version.
[openssl.git] / test / testutil.h
1 /* test/testutil.h */
2 /*
3  * Utilities for writing OpenSSL unit tests.
4  *
5  * More information:
6  * http://wiki.openssl.org/index.php/How_To_Write_Unit_Tests_For_OpenSSL
7  *
8  * Author: Mike Bland (mbland@acm.org)
9  * Date:   2014-06-07
10  * ====================================================================
11  * Copyright (c) 2014 The OpenSSL Project.  All rights reserved.
12  *
13  * Redistribution and use in source and binary forms, with or without
14  * modification, are permitted provided that the following conditions
15  * are met:
16  *
17  * 1. Redistributions of source code must retain the above copyright
18  *    notice, this list of conditions and the following disclaimer.
19  *
20  * 2. Redistributions in binary form must reproduce the above copyright
21  *    notice, this list of conditions and the following disclaimer in
22  *    the documentation and/or other materials provided with the
23  *    distribution.
24  *
25  * 3. All advertising materials mentioning features or use of this
26  *    software must display the following acknowledgment:
27  *    "This product includes software developed by the OpenSSL Project
28  *    for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
29  *
30  * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
31  *    endorse or promote products derived from this software without
32  *    prior written permission. For written permission, please contact
33  *    licensing@OpenSSL.org.
34  *
35  * 5. Products derived from this software may not be called "OpenSSL"
36  *    nor may "OpenSSL" appear in their names without prior written
37  *    permission of the OpenSSL Project.
38  *
39  * 6. Redistributions of any form whatsoever must retain the following
40  *    acknowledgment:
41  *    "This product includes software developed by the OpenSSL Project
42  *    for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
43  *
44  * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
45  * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
46  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
47  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
48  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
49  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
50  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
51  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
52  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
53  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
54  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
55  * OF THE POSSIBILITY OF SUCH DAMAGE.
56  * ====================================================================
57  */
58
59 #ifndef HEADER_TESTUTIL_H
60 #define HEADER_TESTUTIL_H
61
62 /* SETUP_TEST_FIXTURE and EXECUTE_TEST macros for test case functions.
63  *
64  * SETUP_TEST_FIXTURE will call set_up() to create a new TEST_FIXTURE_TYPE
65  * object called "fixture". It will also allocate the "result" variable used
66  * by EXECUTE_TEST. set_up() should take a const char* specifying the test
67  * case name and return a TEST_FIXTURE_TYPE by value.
68  *
69  * EXECUTE_TEST will pass fixture to execute_func() by value, call
70  * tear_down(), and return the result of execute_func(). execute_func() should
71  * take a TEST_FIXTURE_TYPE by value and return zero on success or one on
72  * failure.
73  *
74  * Unit tests can define their own SETUP_TEST_FIXTURE and EXECUTE_TEST
75  * variations like so:
76  *
77  * #define SETUP_FOOBAR_TEST_FIXTURE()\
78  *   SETUP_TEST_FIXTURE(FOOBAR_TEST_FIXTURE, set_up_foobar)
79  *
80  * #define EXECUTE_FOOBAR_TEST()\
81  *   EXECUTE_TEST(execute_foobar, tear_down_foobar)
82  *
83  * Then test case functions can take the form:
84  *
85  * static int test_foobar_feature()
86  *      {
87  *      SETUP_FOOBAR_TEST_FIXTURE();
88  *      [...set individual members of fixture...]
89  *      EXECUTE_FOOBAR_TEST();
90  *      }
91  */
92 #define SETUP_TEST_FIXTURE(TEST_FIXTURE_TYPE, set_up)\
93         TEST_FIXTURE_TYPE fixture = set_up(TEST_CASE_NAME);\
94         int result = 0
95
96 #define EXECUTE_TEST(execute_func, tear_down)\
97         if (execute_func(fixture) != 0) result = 1;\
98         tear_down(fixture);\
99         return result
100
101 /* TEST_CASE_NAME is defined as the name of the test case function where
102  * possible; otherwise we get by with the file name and line number.
103  */
104 #if __STDC_VERSION__ < 199901L
105 #if defined(_MSC_VER)
106 #define TEST_CASE_NAME __FUNCTION__
107 #else
108 #define testutil_stringify_helper(s) #s
109 #define testutil_stringify(s) testutil_stringify_helper(s)
110 #define TEST_CASE_NAME __FILE__ ":" testutil_stringify(__LINE__)
111 #endif /* _MSC_VER */
112 #else
113 #define TEST_CASE_NAME __func__
114 #endif /* __STDC_VERSION__ */
115
116 /* In main(), call ADD_TEST to register each test case function, then call
117  * run_tests() to execute all tests and report the results. The result
118  * returned from run_tests() should be used as the return value for main().
119  */
120 #define ADD_TEST(test_function) add_test(#test_function, test_function)
121 void add_test(const char* test_case_name, int (*test_fn)());
122 int run_tests(const char* test_prog_name);
123
124 #endif /* HEADER_TESTUTIL_H */