blob: 6d54d7c57671a4480b1ae8d2a4159697d4c6cea0 [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)
20 add_custom_command(
21 OUTPUT
22 ${CMAKE_CURRENT_BINARY_DIR}/suites/test_suite_psa_crypto_not_supported.generated.data
23 ${CMAKE_CURRENT_BINARY_DIR}/suites/test_suite_psa_crypto_storage_format.current.data
24 ${CMAKE_CURRENT_BINARY_DIR}/suites/test_suite_psa_crypto_storage_format.v0.data
25 WORKING_DIRECTORY
26 ${CMAKE_CURRENT_SOURCE_DIR}/..
27 COMMAND
28 ${MBEDTLS_PYTHON_EXECUTABLE}
29 ${CMAKE_CURRENT_SOURCE_DIR}/../tests/scripts/generate_psa_tests.py
30 --directory ${CMAKE_CURRENT_BINARY_DIR}/suites
31 DEPENDS
32 ${CMAKE_CURRENT_SOURCE_DIR}/../tests/scripts/generate_psa_tests.py
33 ${CMAKE_CURRENT_SOURCE_DIR}/../include/psa/crypto_config.h
34 ${CMAKE_CURRENT_SOURCE_DIR}/../include/psa/crypto_values.h
35 ${CMAKE_CURRENT_SOURCE_DIR}/../include/psa/crypto_extra.h
36 )
37else()
38 link_to_source(suites/test_suite_psa_crypto_not_supported.generated.data)
39 link_to_source(suites/test_suite_psa_crypto_storage_format.current.data)
40 link_to_source(suites/test_suite_psa_crypto_storage_format.v0.data)
41endif()
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020042
Gilles Peskineac372cc2018-11-29 10:15:06 +000043# Test suites caught by SKIP_TEST_SUITES are built but not executed.
44# "foo" as a skip pattern skips "test_suite_foo" and "test_suite_foo.bar"
45# but not "test_suite_foobar".
46string(REGEX REPLACE "[ ,;]" "|" SKIP_TEST_SUITES_REGEX "${SKIP_TEST_SUITES}")
47string(REPLACE "." "\\." SKIP_TEST_SUITES_REGEX "${SKIP_TEST_SUITES_REGEX}")
48set(SKIP_TEST_SUITES_REGEX "^(${SKIP_TEST_SUITES_REGEX})(\$|\\.)")
49
Paul Bakker73043762011-07-13 15:03:10 +000050function(add_test_suite suite_name)
51 if(ARGV1)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +020052 set(data_name ${ARGV1})
Paul Bakker73043762011-07-13 15:03:10 +000053 else()
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +020054 set(data_name ${suite_name})
Paul Bakker46c17942011-07-13 14:54:54 +000055 endif()
56
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020057 if(data_name STREQUAL "psa_crypto_not_supported.generated" OR
58 data_name STREQUAL "psa_crypto_storage_format.current" OR
59 data_name STREQUAL "psa_crypto_storage_format.v0")
60 set(data_file
61 ${CMAKE_CURRENT_BINARY_DIR}/suites/test_suite_${data_name}.data)
62 else()
63 set(data_file
64 ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${data_name}.data)
65 endif()
66
Paul Bakker367dae42009-06-28 21:50:27 +000067 add_custom_command(
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +020068 OUTPUT
69 test_suite_${data_name}.c
70 COMMAND
71 ${MBEDTLS_PYTHON_EXECUTABLE}
72 ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py
73 -f ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020074 -d ${data_file}
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +020075 -t ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function
76 -p ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function
77 -s ${CMAKE_CURRENT_SOURCE_DIR}/suites
78 --helpers-file ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function
79 -o .
80 DEPENDS
81 ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py
82 ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020083 ${data_file}
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +020084 ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function
85 ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function
86 ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function
87 ${mbedtls_target}
Manuel Pégourié-Gonnard389150d2021-09-09 10:51:16 +020088 BYPRODUCTS
89 test_suite_${data_name}.datax
Paul Bakker4c14a252010-06-18 22:54:05 +000090 )
Paul Bakker19343182013-08-16 13:31:10 +020091
Ronald Cronf5ea29a2020-06-19 10:42:29 +020092 add_executable(test_suite_${data_name} test_suite_${data_name}.c $<TARGET_OBJECTS:mbedtls_test>)
Paul Bakker73043762011-07-13 15:03:10 +000093 target_link_libraries(test_suite_${data_name} ${libs})
Gilles Peskine76dd3aa2020-07-02 15:58:37 +020094 # Include test-specific header files from ./include and private header
95 # files (used by some invasive tests) from ../library. Public header
96 # files are automatically included because the library targets declare
97 # them as PUBLIC.
Ronald Cron85527412020-05-15 17:20:47 +020098 target_include_directories(test_suite_${data_name}
99 PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include
100 PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/../library)
101
Gilles Peskineac372cc2018-11-29 10:15:06 +0000102 if(${data_name} MATCHES ${SKIP_TEST_SUITES_REGEX})
103 message(STATUS "The test suite ${data_name} will not be executed.")
104 else()
105 add_test(${data_name}-suite test_suite_${data_name} --verbose)
106 endif()
Paul Bakker367dae42009-06-28 21:50:27 +0000107endfunction(add_test_suite)
108
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +0200109# Enable definition of various functions used throughout the testsuite
110# (gethostname, strdup, fileno...) even when compiling with -std=c99. Harmless
111# on non-POSIX platforms.
112add_definitions("-D_POSIX_C_SOURCE=200809L")
113
Manuel Pégourié-Gonnard7e2d68c2015-07-01 13:41:35 +0200114if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
115 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-function")
116endif(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
Paul Bakker367dae42009-06-28 21:50:27 +0000117
Gilles Peskinef29019f2021-02-23 13:44:41 +0100118if(CMAKE_COMPILER_IS_CLANG)
119 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wdocumentation -Wno-documentation-deprecated-sync -Wunreachable-code")
120endif(CMAKE_COMPILER_IS_CLANG)
121
Manuel Pégourié-Gonnard30830532015-07-01 17:06:28 +0200122if(MSVC)
Simon B9b3e3c42016-11-03 01:12:50 +0000123 # If a warning level has been defined, suppress all warnings for test code
124 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /W0")
125 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX-")
Manuel Pégourié-Gonnard30830532015-07-01 17:06:28 +0200126endif(MSVC)
127
Paul Bakker286bf3c2013-04-08 18:09:51 +0200128add_test_suite(aes aes.cbc)
129add_test_suite(aes aes.cfb)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200130add_test_suite(aes aes.ecb)
Gilles Peskinec8fff7b2018-11-29 10:55:21 +0000131add_test_suite(aes aes.ofb)
Paul Bakker286bf3c2013-04-08 18:09:51 +0200132add_test_suite(aes aes.rest)
Aorimn5f778012016-06-09 23:22:58 +0200133add_test_suite(aes aes.xts)
Manuel Pégourié-Gonnard442f03b2018-02-20 13:56:54 +0100134add_test_suite(aria)
Gilles Peskine27d806f2019-03-01 18:02:53 +0100135add_test_suite(asn1parse)
Manuel Pégourié-Gonnard36178ff2014-05-29 14:26:03 +0200136add_test_suite(asn1write)
Paul Bakker9d781402011-05-09 16:17:09 +0000137add_test_suite(base64)
138add_test_suite(camellia)
Manuel Pégourié-Gonnarda6916fa2014-05-02 15:17:29 +0200139add_test_suite(ccm)
Daniel King34b822c2016-05-15 17:28:08 -0300140add_test_suite(chacha20)
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +0200141add_test_suite(chachapoly)
Paul Bakker46c17942011-07-13 14:54:54 +0000142add_test_suite(cipher cipher.aes)
143add_test_suite(cipher cipher.camellia)
Manuel Pégourié-Gonnard542eac52014-05-15 16:03:07 +0200144add_test_suite(cipher cipher.ccm)
Daniel Kingbd920622016-05-15 19:56:20 -0300145add_test_suite(cipher cipher.chacha20)
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +0200146add_test_suite(cipher cipher.chachapoly)
Paul Bakker46c17942011-07-13 14:54:54 +0000147add_test_suite(cipher cipher.des)
Manuel Pégourié-Gonnard07f8fa52013-08-30 18:34:08 +0200148add_test_suite(cipher cipher.gcm)
Andrzej Kurekc470b6b2019-01-31 08:20:20 -0500149add_test_suite(cipher cipher.misc)
Jaeden Amero521dbc62019-04-17 12:12:24 +0100150add_test_suite(cipher cipher.nist_kw)
Paul Bakkerfab5c822012-02-06 16:45:10 +0000151add_test_suite(cipher cipher.null)
Manuel Pégourié-Gonnardd5fdcaf2013-07-24 18:05:00 +0200152add_test_suite(cipher cipher.padding)
Simon Butcher53da6ae2016-10-10 22:03:39 +0100153add_test_suite(cmac)
Paul Bakker0e04d0e2011-11-27 14:46:59 +0000154add_test_suite(ctr_drbg)
Jack Lloyd274024f2019-04-04 07:59:33 -0700155add_test_suite(debug)
Paul Bakker9d781402011-05-09 16:17:09 +0000156add_test_suite(des)
157add_test_suite(dhm)
Manuel Pégourié-Gonnard61ce13b2013-01-26 16:20:32 +0100158add_test_suite(ecdh)
Manuel Pégourié-Gonnardd1c71502013-01-26 19:09:07 +0100159add_test_suite(ecdsa)
Manuel Pégourié-Gonnard4d8685b2015-08-05 15:44:42 +0200160add_test_suite(ecjpake)
161add_test_suite(ecp)
Manuel Pégourié-Gonnard2c25eb02014-05-30 10:38:18 +0200162add_test_suite(entropy)
Paul Bakker9d781402011-05-09 16:17:09 +0000163add_test_suite(error)
Manuel Pégourié-Gonnard94dd5b42013-10-24 11:57:47 +0200164add_test_suite(gcm gcm.aes128_de)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200165add_test_suite(gcm gcm.aes128_en)
Manuel Pégourié-Gonnard94dd5b42013-10-24 11:57:47 +0200166add_test_suite(gcm gcm.aes192_de)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200167add_test_suite(gcm gcm.aes192_en)
Manuel Pégourié-Gonnard94dd5b42013-10-24 11:57:47 +0200168add_test_suite(gcm gcm.aes256_de)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200169add_test_suite(gcm gcm.aes256_en)
Manuel Pégourié-Gonnard13e0d442013-10-24 12:59:00 +0200170add_test_suite(gcm gcm.camellia)
Andrzej Kurekc470b6b2019-01-31 08:20:20 -0500171add_test_suite(gcm gcm.misc)
Thomas Fossati656864b2016-07-17 08:51:22 +0100172add_test_suite(hkdf)
Manuel Pégourié-Gonnard48bc3e82014-01-30 21:11:16 +0100173add_test_suite(hmac_drbg hmac_drbg.misc)
Manuel Pégourié-Gonnard6801f392014-01-30 17:22:14 +0100174add_test_suite(hmac_drbg hmac_drbg.no_reseed)
Manuel Pégourié-Gonnard24600b72014-01-31 09:54:14 +0100175add_test_suite(hmac_drbg hmac_drbg.nopr)
Manuel Pégourié-Gonnard62273b82014-01-31 10:16:57 +0100176add_test_suite(hmac_drbg hmac_drbg.pr)
Paul Bakker17373852011-01-06 14:20:01 +0000177add_test_suite(md)
Paul Bakker9d781402011-05-09 16:17:09 +0000178add_test_suite(mdx)
Manuel Pégourié-Gonnard765bb312014-11-27 11:55:27 +0100179add_test_suite(memory_buffer_alloc)
Paul Bakker9d781402011-05-09 16:17:09 +0000180add_test_suite(mpi)
Hanno Becker09d880a2021-01-12 07:43:30 +0000181add_test_suite(mps)
Gilles Peskine1c0e48a2021-02-24 18:37:46 +0100182add_test_suite(net)
Ron Eldor8dd03cd2018-07-15 09:37:28 +0300183add_test_suite(nist_kw)
Jaeden Ameroc70a3c72019-03-28 16:02:25 +0000184add_test_suite(oid)
Paul Bakker16300582014-04-11 13:28:43 +0200185add_test_suite(pem)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200186add_test_suite(pk)
Janos Follath8a49a012016-02-12 13:18:20 +0000187add_test_suite(pkcs1_v15)
Paul Bakker9dcc3222011-03-08 14:16:06 +0000188add_test_suite(pkcs1_v21)
Paul Bakkerb0c19a42013-06-24 19:26:38 +0200189add_test_suite(pkcs5)
Paul Bakker1a7550a2013-09-15 13:01:22 +0200190add_test_suite(pkparse)
Paul Bakkerc7bb02b2013-09-15 14:54:56 +0200191add_test_suite(pkwrite)
Daniel Kingadc32c02016-05-16 18:25:45 -0300192add_test_suite(poly1305)
Moran Pekerb4d0ddd2018-04-04 12:47:52 +0300193add_test_suite(psa_crypto)
Ronald Cronf7b666c2021-01-28 18:20:21 +0100194add_test_suite(psa_crypto_attributes)
Netanel Gonen9468bb22018-11-19 11:53:55 +0200195add_test_suite(psa_crypto_entropy)
itayzafrir02d62952018-10-24 12:45:18 +0300196add_test_suite(psa_crypto_hash)
Gilles Peskineb309eec2018-11-20 20:56:14 +0100197add_test_suite(psa_crypto_init)
Gilles Peskine6dee5c92018-10-22 19:11:00 +0200198add_test_suite(psa_crypto_metadata)
Gilles Peskine79f21662021-02-16 14:42:22 +0100199add_test_suite(psa_crypto_not_supported psa_crypto_not_supported.generated)
200add_test_suite(psa_crypto_not_supported psa_crypto_not_supported.misc)
Darryl Greend49a4992018-06-18 17:27:26 +0100201add_test_suite(psa_crypto_persistent_key)
Gilles Peskine2c2243d2019-06-24 13:47:24 +0200202add_test_suite(psa_crypto_se_driver_hal)
Unknownc9ad5912019-07-10 06:45:31 -0400203add_test_suite(psa_crypto_se_driver_hal_mocks)
Gilles Peskine5ec7b072018-11-30 18:53:28 +0100204add_test_suite(psa_crypto_slot_management)
Gilles Peskine00d37d02021-03-01 17:45:11 +0100205add_test_suite(psa_crypto_storage_format psa_crypto_storage_format.misc)
Gilles Peskine0225d3a2021-04-27 20:25:27 +0200206add_test_suite(psa_crypto_storage_format psa_crypto_storage_format.current)
207add_test_suite(psa_crypto_storage_format psa_crypto_storage_format.v0)
Gilles Peskinebc1f2722018-11-16 22:24:38 +0100208add_test_suite(psa_its)
Gilles Peskine077599a2021-02-03 18:55:39 +0100209add_test_suite(random)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200210add_test_suite(rsa)
Paul Bakker9d781402011-05-09 16:17:09 +0000211add_test_suite(shax)
Jack Lloyd274024f2019-04-04 07:59:33 -0700212add_test_suite(ssl)
Paul Bakker50157ff2016-07-19 14:57:00 +0100213add_test_suite(timing)
Jack Lloyd274024f2019-04-04 07:59:33 -0700214add_test_suite(version)
215add_test_suite(x509parse)
216add_test_suite(x509write)
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100217
Gilles Peskine84052572018-03-21 12:12:47 +0100218# Make scripts and data files needed for testing available in an
219# out-of-source build.
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100220if (NOT ${CMAKE_CURRENT_BINARY_DIR} STREQUAL ${CMAKE_CURRENT_SOURCE_DIR})
Andrzej Kurek4a71cfa2019-05-06 05:06:06 -0400221 if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/seedfile")
222 link_to_source(seedfile)
223 endif()
Gilles Peskine84052572018-03-21 12:12:47 +0100224 link_to_source(compat.sh)
David Brownc7444182020-10-16 13:19:49 -0600225 link_to_source(context-info.sh)
Gilles Peskine84052572018-03-21 12:12:47 +0100226 link_to_source(data_files)
227 link_to_source(scripts)
228 link_to_source(ssl-opt.sh)
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100229endif()