blob: 4e44f882117c1f016c1a30dcbbebe3ff110702fd [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
David Horstmann1732b5d2021-10-19 16:43:53 +010019execute_process(
20 COMMAND
21 ${CMAKE_CURRENT_SOURCE_DIR}/../tests/scripts/generate_psa_tests.py
22 --list-for-cmake
23 --directory ${CMAKE_CURRENT_BINARY_DIR}/suites
24 WORKING_DIRECTORY
25 ${CMAKE_CURRENT_SOURCE_DIR}/..
26 OUTPUT_VARIABLE
27 test_suite_data_files)
28
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +020029if(DEV_MODE)
30 add_custom_command(
31 OUTPUT
David Horstmann7b78ec82021-10-19 14:43:54 +010032 ${test_suite_data_files}
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +020033 WORKING_DIRECTORY
34 ${CMAKE_CURRENT_SOURCE_DIR}/..
35 COMMAND
36 ${MBEDTLS_PYTHON_EXECUTABLE}
37 ${CMAKE_CURRENT_SOURCE_DIR}/../tests/scripts/generate_psa_tests.py
38 --directory ${CMAKE_CURRENT_BINARY_DIR}/suites
39 DEPENDS
40 ${CMAKE_CURRENT_SOURCE_DIR}/../tests/scripts/generate_psa_tests.py
41 ${CMAKE_CURRENT_SOURCE_DIR}/../include/psa/crypto_config.h
42 ${CMAKE_CURRENT_SOURCE_DIR}/../include/psa/crypto_values.h
43 ${CMAKE_CURRENT_SOURCE_DIR}/../include/psa/crypto_extra.h
44 )
45else()
David Horstmann1732b5d2021-10-19 16:43:53 +010046 foreach(file ${test_suite_data_files})
47 link_to_source(${file})
48 endforeach()
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +020049endif()
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020050
Gilles Peskineac372cc2018-11-29 10:15:06 +000051# Test suites caught by SKIP_TEST_SUITES are built but not executed.
52# "foo" as a skip pattern skips "test_suite_foo" and "test_suite_foo.bar"
53# but not "test_suite_foobar".
54string(REGEX REPLACE "[ ,;]" "|" SKIP_TEST_SUITES_REGEX "${SKIP_TEST_SUITES}")
55string(REPLACE "." "\\." SKIP_TEST_SUITES_REGEX "${SKIP_TEST_SUITES_REGEX}")
56set(SKIP_TEST_SUITES_REGEX "^(${SKIP_TEST_SUITES_REGEX})(\$|\\.)")
57
Paul Bakker73043762011-07-13 15:03:10 +000058function(add_test_suite suite_name)
59 if(ARGV1)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +020060 set(data_name ${ARGV1})
Paul Bakker73043762011-07-13 15:03:10 +000061 else()
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +020062 set(data_name ${suite_name})
Paul Bakker46c17942011-07-13 14:54:54 +000063 endif()
64
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020065 if(data_name STREQUAL "psa_crypto_not_supported.generated" OR
66 data_name STREQUAL "psa_crypto_storage_format.current" OR
67 data_name STREQUAL "psa_crypto_storage_format.v0")
68 set(data_file
69 ${CMAKE_CURRENT_BINARY_DIR}/suites/test_suite_${data_name}.data)
70 else()
71 set(data_file
72 ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${data_name}.data)
73 endif()
74
Paul Bakker367dae42009-06-28 21:50:27 +000075 add_custom_command(
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +020076 OUTPUT
77 test_suite_${data_name}.c
78 COMMAND
79 ${MBEDTLS_PYTHON_EXECUTABLE}
80 ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py
81 -f ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020082 -d ${data_file}
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +020083 -t ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function
84 -p ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function
85 -s ${CMAKE_CURRENT_SOURCE_DIR}/suites
86 --helpers-file ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function
87 -o .
88 DEPENDS
89 ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py
90 ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function
Manuel Pégourié-Gonnardce3ba8f2021-05-14 12:03:37 +020091 ${data_file}
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +020092 ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function
93 ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function
94 ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function
95 ${mbedtls_target}
Manuel Pégourié-Gonnard389150d2021-09-09 10:51:16 +020096 BYPRODUCTS
97 test_suite_${data_name}.datax
Paul Bakker4c14a252010-06-18 22:54:05 +000098 )
Paul Bakker19343182013-08-16 13:31:10 +020099
Ronald Cronf5ea29a2020-06-19 10:42:29 +0200100 add_executable(test_suite_${data_name} test_suite_${data_name}.c $<TARGET_OBJECTS:mbedtls_test>)
Paul Bakker73043762011-07-13 15:03:10 +0000101 target_link_libraries(test_suite_${data_name} ${libs})
Gilles Peskine76dd3aa2020-07-02 15:58:37 +0200102 # Include test-specific header files from ./include and private header
103 # files (used by some invasive tests) from ../library. Public header
104 # files are automatically included because the library targets declare
105 # them as PUBLIC.
Ronald Cron85527412020-05-15 17:20:47 +0200106 target_include_directories(test_suite_${data_name}
107 PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include
108 PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/../library)
109
Gilles Peskineac372cc2018-11-29 10:15:06 +0000110 if(${data_name} MATCHES ${SKIP_TEST_SUITES_REGEX})
111 message(STATUS "The test suite ${data_name} will not be executed.")
112 else()
113 add_test(${data_name}-suite test_suite_${data_name} --verbose)
114 endif()
Paul Bakker367dae42009-06-28 21:50:27 +0000115endfunction(add_test_suite)
116
Manuel Pégourié-Gonnard42681f32021-05-14 10:53:43 +0200117# Enable definition of various functions used throughout the testsuite
118# (gethostname, strdup, fileno...) even when compiling with -std=c99. Harmless
119# on non-POSIX platforms.
120add_definitions("-D_POSIX_C_SOURCE=200809L")
121
Manuel Pégourié-Gonnard7e2d68c2015-07-01 13:41:35 +0200122if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
123 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-function")
124endif(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
Paul Bakker367dae42009-06-28 21:50:27 +0000125
Gilles Peskinef29019f2021-02-23 13:44:41 +0100126if(CMAKE_COMPILER_IS_CLANG)
127 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wdocumentation -Wno-documentation-deprecated-sync -Wunreachable-code")
128endif(CMAKE_COMPILER_IS_CLANG)
129
Manuel Pégourié-Gonnard30830532015-07-01 17:06:28 +0200130if(MSVC)
Simon B9b3e3c42016-11-03 01:12:50 +0000131 # If a warning level has been defined, suppress all warnings for test code
132 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /W0")
133 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX-")
Manuel Pégourié-Gonnard30830532015-07-01 17:06:28 +0200134endif(MSVC)
135
Paul Bakker286bf3c2013-04-08 18:09:51 +0200136add_test_suite(aes aes.cbc)
137add_test_suite(aes aes.cfb)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200138add_test_suite(aes aes.ecb)
Gilles Peskinec8fff7b2018-11-29 10:55:21 +0000139add_test_suite(aes aes.ofb)
Paul Bakker286bf3c2013-04-08 18:09:51 +0200140add_test_suite(aes aes.rest)
Aorimn5f778012016-06-09 23:22:58 +0200141add_test_suite(aes aes.xts)
Manuel Pégourié-Gonnard442f03b2018-02-20 13:56:54 +0100142add_test_suite(aria)
Gilles Peskine27d806f2019-03-01 18:02:53 +0100143add_test_suite(asn1parse)
Manuel Pégourié-Gonnard36178ff2014-05-29 14:26:03 +0200144add_test_suite(asn1write)
Paul Bakker9d781402011-05-09 16:17:09 +0000145add_test_suite(base64)
146add_test_suite(camellia)
Manuel Pégourié-Gonnarda6916fa2014-05-02 15:17:29 +0200147add_test_suite(ccm)
Daniel King34b822c2016-05-15 17:28:08 -0300148add_test_suite(chacha20)
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +0200149add_test_suite(chachapoly)
Paul Bakker46c17942011-07-13 14:54:54 +0000150add_test_suite(cipher cipher.aes)
151add_test_suite(cipher cipher.camellia)
Manuel Pégourié-Gonnard542eac52014-05-15 16:03:07 +0200152add_test_suite(cipher cipher.ccm)
Daniel Kingbd920622016-05-15 19:56:20 -0300153add_test_suite(cipher cipher.chacha20)
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +0200154add_test_suite(cipher cipher.chachapoly)
Paul Bakker46c17942011-07-13 14:54:54 +0000155add_test_suite(cipher cipher.des)
Manuel Pégourié-Gonnard07f8fa52013-08-30 18:34:08 +0200156add_test_suite(cipher cipher.gcm)
Andrzej Kurekc470b6b2019-01-31 08:20:20 -0500157add_test_suite(cipher cipher.misc)
Jaeden Amero521dbc62019-04-17 12:12:24 +0100158add_test_suite(cipher cipher.nist_kw)
Paul Bakkerfab5c822012-02-06 16:45:10 +0000159add_test_suite(cipher cipher.null)
Manuel Pégourié-Gonnardd5fdcaf2013-07-24 18:05:00 +0200160add_test_suite(cipher cipher.padding)
Simon Butcher53da6ae2016-10-10 22:03:39 +0100161add_test_suite(cmac)
Paul Bakker0e04d0e2011-11-27 14:46:59 +0000162add_test_suite(ctr_drbg)
Jack Lloyd274024f2019-04-04 07:59:33 -0700163add_test_suite(debug)
Paul Bakker9d781402011-05-09 16:17:09 +0000164add_test_suite(des)
165add_test_suite(dhm)
Manuel Pégourié-Gonnard61ce13b2013-01-26 16:20:32 +0100166add_test_suite(ecdh)
Manuel Pégourié-Gonnardd1c71502013-01-26 19:09:07 +0100167add_test_suite(ecdsa)
Manuel Pégourié-Gonnard4d8685b2015-08-05 15:44:42 +0200168add_test_suite(ecjpake)
169add_test_suite(ecp)
Manuel Pégourié-Gonnard2c25eb02014-05-30 10:38:18 +0200170add_test_suite(entropy)
Paul Bakker9d781402011-05-09 16:17:09 +0000171add_test_suite(error)
Manuel Pégourié-Gonnard94dd5b42013-10-24 11:57:47 +0200172add_test_suite(gcm gcm.aes128_de)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200173add_test_suite(gcm gcm.aes128_en)
Manuel Pégourié-Gonnard94dd5b42013-10-24 11:57:47 +0200174add_test_suite(gcm gcm.aes192_de)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200175add_test_suite(gcm gcm.aes192_en)
Manuel Pégourié-Gonnard94dd5b42013-10-24 11:57:47 +0200176add_test_suite(gcm gcm.aes256_de)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200177add_test_suite(gcm gcm.aes256_en)
Manuel Pégourié-Gonnard13e0d442013-10-24 12:59:00 +0200178add_test_suite(gcm gcm.camellia)
Andrzej Kurekc470b6b2019-01-31 08:20:20 -0500179add_test_suite(gcm gcm.misc)
Thomas Fossati656864b2016-07-17 08:51:22 +0100180add_test_suite(hkdf)
Manuel Pégourié-Gonnard48bc3e82014-01-30 21:11:16 +0100181add_test_suite(hmac_drbg hmac_drbg.misc)
Manuel Pégourié-Gonnard6801f392014-01-30 17:22:14 +0100182add_test_suite(hmac_drbg hmac_drbg.no_reseed)
Manuel Pégourié-Gonnard24600b72014-01-31 09:54:14 +0100183add_test_suite(hmac_drbg hmac_drbg.nopr)
Manuel Pégourié-Gonnard62273b82014-01-31 10:16:57 +0100184add_test_suite(hmac_drbg hmac_drbg.pr)
Paul Bakker17373852011-01-06 14:20:01 +0000185add_test_suite(md)
Paul Bakker9d781402011-05-09 16:17:09 +0000186add_test_suite(mdx)
Manuel Pégourié-Gonnard765bb312014-11-27 11:55:27 +0100187add_test_suite(memory_buffer_alloc)
Paul Bakker9d781402011-05-09 16:17:09 +0000188add_test_suite(mpi)
Hanno Becker09d880a2021-01-12 07:43:30 +0000189add_test_suite(mps)
Gilles Peskine1c0e48a2021-02-24 18:37:46 +0100190add_test_suite(net)
Ron Eldor8dd03cd2018-07-15 09:37:28 +0300191add_test_suite(nist_kw)
Jaeden Ameroc70a3c72019-03-28 16:02:25 +0000192add_test_suite(oid)
Paul Bakker16300582014-04-11 13:28:43 +0200193add_test_suite(pem)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200194add_test_suite(pk)
Janos Follath8a49a012016-02-12 13:18:20 +0000195add_test_suite(pkcs1_v15)
Paul Bakker9dcc3222011-03-08 14:16:06 +0000196add_test_suite(pkcs1_v21)
Paul Bakkerb0c19a42013-06-24 19:26:38 +0200197add_test_suite(pkcs5)
Paul Bakker1a7550a2013-09-15 13:01:22 +0200198add_test_suite(pkparse)
Paul Bakkerc7bb02b2013-09-15 14:54:56 +0200199add_test_suite(pkwrite)
Daniel Kingadc32c02016-05-16 18:25:45 -0300200add_test_suite(poly1305)
Moran Pekerb4d0ddd2018-04-04 12:47:52 +0300201add_test_suite(psa_crypto)
Ronald Cronf7b666c2021-01-28 18:20:21 +0100202add_test_suite(psa_crypto_attributes)
Netanel Gonen9468bb22018-11-19 11:53:55 +0200203add_test_suite(psa_crypto_entropy)
itayzafrir02d62952018-10-24 12:45:18 +0300204add_test_suite(psa_crypto_hash)
Gilles Peskineb309eec2018-11-20 20:56:14 +0100205add_test_suite(psa_crypto_init)
Gilles Peskine6dee5c92018-10-22 19:11:00 +0200206add_test_suite(psa_crypto_metadata)
Gilles Peskine79f21662021-02-16 14:42:22 +0100207add_test_suite(psa_crypto_not_supported psa_crypto_not_supported.generated)
208add_test_suite(psa_crypto_not_supported psa_crypto_not_supported.misc)
Darryl Greend49a4992018-06-18 17:27:26 +0100209add_test_suite(psa_crypto_persistent_key)
Gilles Peskine2c2243d2019-06-24 13:47:24 +0200210add_test_suite(psa_crypto_se_driver_hal)
Unknownc9ad5912019-07-10 06:45:31 -0400211add_test_suite(psa_crypto_se_driver_hal_mocks)
Gilles Peskine5ec7b072018-11-30 18:53:28 +0100212add_test_suite(psa_crypto_slot_management)
Gilles Peskine00d37d02021-03-01 17:45:11 +0100213add_test_suite(psa_crypto_storage_format psa_crypto_storage_format.misc)
Gilles Peskine0225d3a2021-04-27 20:25:27 +0200214add_test_suite(psa_crypto_storage_format psa_crypto_storage_format.current)
215add_test_suite(psa_crypto_storage_format psa_crypto_storage_format.v0)
Gilles Peskinebc1f2722018-11-16 22:24:38 +0100216add_test_suite(psa_its)
Gilles Peskine077599a2021-02-03 18:55:39 +0100217add_test_suite(random)
Manuel Pégourié-Gonnard6f830252020-04-03 11:56:06 +0200218add_test_suite(rsa)
Paul Bakker9d781402011-05-09 16:17:09 +0000219add_test_suite(shax)
Jack Lloyd274024f2019-04-04 07:59:33 -0700220add_test_suite(ssl)
Paul Bakker50157ff2016-07-19 14:57:00 +0100221add_test_suite(timing)
Jack Lloyd274024f2019-04-04 07:59:33 -0700222add_test_suite(version)
223add_test_suite(x509parse)
224add_test_suite(x509write)
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100225
Gilles Peskine84052572018-03-21 12:12:47 +0100226# Make scripts and data files needed for testing available in an
227# out-of-source build.
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100228if (NOT ${CMAKE_CURRENT_BINARY_DIR} STREQUAL ${CMAKE_CURRENT_SOURCE_DIR})
Andrzej Kurek4a71cfa2019-05-06 05:06:06 -0400229 if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/seedfile")
230 link_to_source(seedfile)
231 endif()
Gilles Peskine84052572018-03-21 12:12:47 +0100232 link_to_source(compat.sh)
David Brownc7444182020-10-16 13:19:49 -0600233 link_to_source(context-info.sh)
Gilles Peskine84052572018-03-21 12:12:47 +0100234 link_to_source(data_files)
235 link_to_source(scripts)
236 link_to_source(ssl-opt.sh)
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100237endif()