blob: ef41f2996efb73072403a8e6ab247de9bd8b9c75 [file] [log] [blame]
Paul Bakkerb06819b2011-01-18 16:18:38 +00001set(libs
Raef Coles995c66f2020-10-13 16:30:41 +01002 ${mbedtls_target}
Paul Bakkerb06819b2011-01-18 16:18:38 +00003)
4
Ashley Duncand85a7e92019-04-29 20:35:06 +12005# Set the project root directory if it's not already defined, as may happen if
6# the tests folder is included directly by a parent project, without including
7# the top level CMakeLists.txt.
8if(NOT DEFINED MBEDTLS_DIR)
9 set(MBEDTLS_DIR ${CMAKE_SOURCE_DIR})
10endif()
11
okhowang(王沛文)3c1b0902020-03-25 19:55:32 +080012if(NOT MBEDTLS_PYTHON_EXECUTABLE)
13 message(FATAL_ERROR "Cannot build test suites without Python 3")
Nicholas Wilson733676b2015-11-14 13:09:01 +000014endif()
15
Manuel Pégourié-Gonnard313bcfc2021-09-07 12:16:49 +020016# generated .data files will go there
17file(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/suites)
18
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +020019if(DEV_MODE)
David Horstmanne12e7f42021-10-15 19:10:15 +010020 execute_process(
21 COMMAND
22 ${CMAKE_CURRENT_SOURCE_DIR}/../tests/scripts/generate_psa_tests.py
23 --list-for-cmake
24 --directory ${CMAKE_CURRENT_BINARY_DIR}/suites
25 WORKING_DIRECTORY
26 ${CMAKE_CURRENT_SOURCE_DIR}/..
27 OUTPUT_VARIABLE
28 TEST_SUITE_DATA_FILES)
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +020029 add_custom_command(
30 OUTPUT
David Horstmanne12e7f42021-10-15 19:10:15 +010031 ${TEST_SUITE_DATA_FILES}
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +020032 WORKING_DIRECTORY
33 ${CMAKE_CURRENT_SOURCE_DIR}/..
34 COMMAND
35 ${MBEDTLS_PYTHON_EXECUTABLE}
36 ${CMAKE_CURRENT_SOURCE_DIR}/../tests/scripts/generate_psa_tests.py
37 --directory ${CMAKE_CURRENT_BINARY_DIR}/suites
38 DEPENDS
39 ${CMAKE_CURRENT_SOURCE_DIR}/../tests/scripts/generate_psa_tests.py
40 ${CMAKE_CURRENT_SOURCE_DIR}/../include/psa/crypto_config.h
41 ${CMAKE_CURRENT_SOURCE_DIR}/../include/psa/crypto_values.h
42 ${CMAKE_CURRENT_SOURCE_DIR}/../include/psa/crypto_extra.h
43 )
44else()
45 link_to_source(suites/test_suite_psa_crypto_not_supported.generated.data)
46 link_to_source(suites/test_suite_psa_crypto_storage_format.current.data)
47 link_to_source(suites/test_suite_psa_crypto_storage_format.v0.data)
48endif()
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020049
Gilles Peskineac372cc2018-11-29 10:15:06 +000050# Test suites caught by SKIP_TEST_SUITES are built but not executed.
51# "foo" as a skip pattern skips "test_suite_foo" and "test_suite_foo.bar"
52# but not "test_suite_foobar".
53string(REGEX REPLACE "[ ,;]" "|" SKIP_TEST_SUITES_REGEX "${SKIP_TEST_SUITES}")
54string(REPLACE "." "\\." SKIP_TEST_SUITES_REGEX "${SKIP_TEST_SUITES_REGEX}")
55set(SKIP_TEST_SUITES_REGEX "^(${SKIP_TEST_SUITES_REGEX})(\$|\\.)")
56
Paul Bakker73043762011-07-13 15:03:10 +000057function(add_test_suite suite_name)
58 if(ARGV1)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +020059 set(data_name ${ARGV1})
Paul Bakker73043762011-07-13 15:03:10 +000060 else()
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +020061 set(data_name ${suite_name})
Paul Bakker46c17942011-07-13 14:54:54 +000062 endif()
63
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020064 if(data_name STREQUAL "psa_crypto_not_supported.generated" OR
65 data_name STREQUAL "psa_crypto_storage_format.current" OR
66 data_name STREQUAL "psa_crypto_storage_format.v0")
67 set(data_file
68 ${CMAKE_CURRENT_BINARY_DIR}/suites/test_suite_${data_name}.data)
69 else()
70 set(data_file
71 ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${data_name}.data)
72 endif()
73
Paul Bakker367dae42009-06-28 21:50:27 +000074 add_custom_command(
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +020075 OUTPUT
76 test_suite_${data_name}.c
77 COMMAND
78 ${MBEDTLS_PYTHON_EXECUTABLE}
79 ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py
80 -f ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020081 -d ${data_file}
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +020082 -t ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function
83 -p ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function
84 -s ${CMAKE_CURRENT_SOURCE_DIR}/suites
85 --helpers-file ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function
86 -o .
87 DEPENDS
88 ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py
89 ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020090 ${data_file}
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +020091 ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function
92 ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function
93 ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function
94 ${mbedtls_target}
Manuel Pégourié-Gonnard389150d2021-09-09 10:51:16 +020095 BYPRODUCTS
96 test_suite_${data_name}.datax
Paul Bakker4c14a252010-06-18 22:54:05 +000097 )
Paul Bakker19343182013-08-16 13:31:10 +020098
Ronald Cronf5ea29a2020-06-19 10:42:29 +020099 add_executable(test_suite_${data_name} test_suite_${data_name}.c $<TARGET_OBJECTS:mbedtls_test>)
Paul Bakker73043762011-07-13 15:03:10 +0000100 target_link_libraries(test_suite_${data_name} ${libs})
Gilles Peskine76dd3aa2020-07-02 15:58:37 +0200101 # Include test-specific header files from ./include and private header
102 # files (used by some invasive tests) from ../library. Public header
103 # files are automatically included because the library targets declare
104 # them as PUBLIC.
Ronald Cron85527412020-05-15 17:20:47 +0200105 target_include_directories(test_suite_${data_name}
106 PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include
107 PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/../library)
108
Gilles Peskineac372cc2018-11-29 10:15:06 +0000109 if(${data_name} MATCHES ${SKIP_TEST_SUITES_REGEX})
110 message(STATUS "The test suite ${data_name} will not be executed.")
111 else()
112 add_test(${data_name}-suite test_suite_${data_name} --verbose)
113 endif()
Paul Bakker367dae42009-06-28 21:50:27 +0000114endfunction(add_test_suite)
115
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +0200116# Enable definition of various functions used throughout the testsuite
117# (gethostname, strdup, fileno...) even when compiling with -std=c99. Harmless
118# on non-POSIX platforms.
119add_definitions("-D_POSIX_C_SOURCE=200809L")
120
Manuel Pégourié-Gonnard7e2d68c2015-07-01 13:41:35 +0200121if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
122 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-function")
123endif(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
Paul Bakker367dae42009-06-28 21:50:27 +0000124
Gilles Peskinef29019f2021-02-23 13:44:41 +0100125if(CMAKE_COMPILER_IS_CLANG)
126 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wdocumentation -Wno-documentation-deprecated-sync -Wunreachable-code")
127endif(CMAKE_COMPILER_IS_CLANG)
128
Manuel Pégourié-Gonnard30830532015-07-01 17:06:28 +0200129if(MSVC)
Simon B9b3e3c42016-11-03 01:12:50 +0000130 # If a warning level has been defined, suppress all warnings for test code
131 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /W0")
132 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX-")
Manuel Pégourié-Gonnard30830532015-07-01 17:06:28 +0200133endif(MSVC)
134
Paul Bakker286bf3c2013-04-08 18:09:51 +0200135add_test_suite(aes aes.cbc)
136add_test_suite(aes aes.cfb)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200137add_test_suite(aes aes.ecb)
Gilles Peskinec8fff7b2018-11-29 10:55:21 +0000138add_test_suite(aes aes.ofb)
Paul Bakker286bf3c2013-04-08 18:09:51 +0200139add_test_suite(aes aes.rest)
Aorimn5f778012016-06-09 23:22:58 +0200140add_test_suite(aes aes.xts)
Manuel Pégourié-Gonnard442f03b2018-02-20 13:56:54 +0100141add_test_suite(aria)
Gilles Peskine27d806f2019-03-01 18:02:53 +0100142add_test_suite(asn1parse)
Manuel Pégourié-Gonnard36178ff2014-05-29 14:26:03 +0200143add_test_suite(asn1write)
Paul Bakker9d781402011-05-09 16:17:09 +0000144add_test_suite(base64)
145add_test_suite(camellia)
Manuel Pégourié-Gonnarda6916fa2014-05-02 15:17:29 +0200146add_test_suite(ccm)
Daniel King34b822c2016-05-15 17:28:08 -0300147add_test_suite(chacha20)
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +0200148add_test_suite(chachapoly)
Paul Bakker46c17942011-07-13 14:54:54 +0000149add_test_suite(cipher cipher.aes)
150add_test_suite(cipher cipher.camellia)
Manuel Pégourié-Gonnard542eac52014-05-15 16:03:07 +0200151add_test_suite(cipher cipher.ccm)
Daniel Kingbd920622016-05-15 19:56:20 -0300152add_test_suite(cipher cipher.chacha20)
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +0200153add_test_suite(cipher cipher.chachapoly)
Paul Bakker46c17942011-07-13 14:54:54 +0000154add_test_suite(cipher cipher.des)
Manuel Pégourié-Gonnard07f8fa52013-08-30 18:34:08 +0200155add_test_suite(cipher cipher.gcm)
Andrzej Kurekc470b6b2019-01-31 08:20:20 -0500156add_test_suite(cipher cipher.misc)
Jaeden Amero521dbc62019-04-17 12:12:24 +0100157add_test_suite(cipher cipher.nist_kw)
Paul Bakkerfab5c822012-02-06 16:45:10 +0000158add_test_suite(cipher cipher.null)
Manuel Pégourié-Gonnardd5fdcaf2013-07-24 18:05:00 +0200159add_test_suite(cipher cipher.padding)
Simon Butcher53da6ae2016-10-10 22:03:39 +0100160add_test_suite(cmac)
Paul Bakker0e04d0e2011-11-27 14:46:59 +0000161add_test_suite(ctr_drbg)
Jack Lloyd274024f2019-04-04 07:59:33 -0700162add_test_suite(debug)
Paul Bakker9d781402011-05-09 16:17:09 +0000163add_test_suite(des)
164add_test_suite(dhm)
Manuel Pégourié-Gonnard61ce13b2013-01-26 16:20:32 +0100165add_test_suite(ecdh)
Manuel Pégourié-Gonnardd1c71502013-01-26 19:09:07 +0100166add_test_suite(ecdsa)
Manuel Pégourié-Gonnard4d8685b2015-08-05 15:44:42 +0200167add_test_suite(ecjpake)
168add_test_suite(ecp)
Manuel Pégourié-Gonnard2c25eb02014-05-30 10:38:18 +0200169add_test_suite(entropy)
Paul Bakker9d781402011-05-09 16:17:09 +0000170add_test_suite(error)
Manuel Pégourié-Gonnard94dd5b42013-10-24 11:57:47 +0200171add_test_suite(gcm gcm.aes128_de)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200172add_test_suite(gcm gcm.aes128_en)
Manuel Pégourié-Gonnard94dd5b42013-10-24 11:57:47 +0200173add_test_suite(gcm gcm.aes192_de)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200174add_test_suite(gcm gcm.aes192_en)
Manuel Pégourié-Gonnard94dd5b42013-10-24 11:57:47 +0200175add_test_suite(gcm gcm.aes256_de)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200176add_test_suite(gcm gcm.aes256_en)
Manuel Pégourié-Gonnard13e0d442013-10-24 12:59:00 +0200177add_test_suite(gcm gcm.camellia)
Andrzej Kurekc470b6b2019-01-31 08:20:20 -0500178add_test_suite(gcm gcm.misc)
Thomas Fossati656864b2016-07-17 08:51:22 +0100179add_test_suite(hkdf)
Manuel Pégourié-Gonnard48bc3e82014-01-30 21:11:16 +0100180add_test_suite(hmac_drbg hmac_drbg.misc)
Manuel Pégourié-Gonnard6801f392014-01-30 17:22:14 +0100181add_test_suite(hmac_drbg hmac_drbg.no_reseed)
Manuel Pégourié-Gonnard24600b72014-01-31 09:54:14 +0100182add_test_suite(hmac_drbg hmac_drbg.nopr)
Manuel Pégourié-Gonnard62273b82014-01-31 10:16:57 +0100183add_test_suite(hmac_drbg hmac_drbg.pr)
Paul Bakker17373852011-01-06 14:20:01 +0000184add_test_suite(md)
Paul Bakker9d781402011-05-09 16:17:09 +0000185add_test_suite(mdx)
Manuel Pégourié-Gonnard765bb312014-11-27 11:55:27 +0100186add_test_suite(memory_buffer_alloc)
Paul Bakker9d781402011-05-09 16:17:09 +0000187add_test_suite(mpi)
Hanno Becker09d880a2021-01-12 07:43:30 +0000188add_test_suite(mps)
Gilles Peskine1c0e48a2021-02-24 18:37:46 +0100189add_test_suite(net)
Ron Eldor8dd03cd2018-07-15 09:37:28 +0300190add_test_suite(nist_kw)
Jaeden Ameroc70a3c72019-03-28 16:02:25 +0000191add_test_suite(oid)
Paul Bakker16300582014-04-11 13:28:43 +0200192add_test_suite(pem)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200193add_test_suite(pk)
Janos Follath8a49a012016-02-12 13:18:20 +0000194add_test_suite(pkcs1_v15)
Paul Bakker9dcc3222011-03-08 14:16:06 +0000195add_test_suite(pkcs1_v21)
Paul Bakkerb0c19a42013-06-24 19:26:38 +0200196add_test_suite(pkcs5)
Paul Bakker1a7550a2013-09-15 13:01:22 +0200197add_test_suite(pkparse)
Paul Bakkerc7bb02b2013-09-15 14:54:56 +0200198add_test_suite(pkwrite)
Daniel Kingadc32c02016-05-16 18:25:45 -0300199add_test_suite(poly1305)
Moran Pekerb4d0ddd2018-04-04 12:47:52 +0300200add_test_suite(psa_crypto)
Ronald Cronf7b666c2021-01-28 18:20:21 +0100201add_test_suite(psa_crypto_attributes)
Netanel Gonen9468bb22018-11-19 11:53:55 +0200202add_test_suite(psa_crypto_entropy)
itayzafrir02d62952018-10-24 12:45:18 +0300203add_test_suite(psa_crypto_hash)
Gilles Peskineb309eec2018-11-20 20:56:14 +0100204add_test_suite(psa_crypto_init)
Gilles Peskine6dee5c92018-10-22 19:11:00 +0200205add_test_suite(psa_crypto_metadata)
Gilles Peskine79f21662021-02-16 14:42:22 +0100206add_test_suite(psa_crypto_not_supported psa_crypto_not_supported.generated)
207add_test_suite(psa_crypto_not_supported psa_crypto_not_supported.misc)
Darryl Greend49a4992018-06-18 17:27:26 +0100208add_test_suite(psa_crypto_persistent_key)
Gilles Peskine2c2243d2019-06-24 13:47:24 +0200209add_test_suite(psa_crypto_se_driver_hal)
Unknownc9ad5912019-07-10 06:45:31 -0400210add_test_suite(psa_crypto_se_driver_hal_mocks)
Gilles Peskine5ec7b072018-11-30 18:53:28 +0100211add_test_suite(psa_crypto_slot_management)
Gilles Peskine00d37d02021-03-01 17:45:11 +0100212add_test_suite(psa_crypto_storage_format psa_crypto_storage_format.misc)
Gilles Peskine0225d3a2021-04-27 20:25:27 +0200213add_test_suite(psa_crypto_storage_format psa_crypto_storage_format.current)
214add_test_suite(psa_crypto_storage_format psa_crypto_storage_format.v0)
Gilles Peskinebc1f2722018-11-16 22:24:38 +0100215add_test_suite(psa_its)
Gilles Peskine077599a2021-02-03 18:55:39 +0100216add_test_suite(random)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200217add_test_suite(rsa)
Paul Bakker9d781402011-05-09 16:17:09 +0000218add_test_suite(shax)
Jack Lloyd274024f2019-04-04 07:59:33 -0700219add_test_suite(ssl)
Paul Bakker50157ff2016-07-19 14:57:00 +0100220add_test_suite(timing)
Jack Lloyd274024f2019-04-04 07:59:33 -0700221add_test_suite(version)
222add_test_suite(x509parse)
223add_test_suite(x509write)
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100224
Gilles Peskine84052572018-03-21 12:12:47 +0100225# Make scripts and data files needed for testing available in an
226# out-of-source build.
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100227if (NOT ${CMAKE_CURRENT_BINARY_DIR} STREQUAL ${CMAKE_CURRENT_SOURCE_DIR})
Andrzej Kurek4a71cfa2019-05-06 05:06:06 -0400228 if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/seedfile")
229 link_to_source(seedfile)
230 endif()
Gilles Peskine84052572018-03-21 12:12:47 +0100231 link_to_source(compat.sh)
David Brownc7444182020-10-16 13:19:49 -0600232 link_to_source(context-info.sh)
Gilles Peskine84052572018-03-21 12:12:47 +0100233 link_to_source(data_files)
234 link_to_source(scripts)
235 link_to_source(ssl-opt.sh)
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100236endif()