blob: 8c6bc76b743e2ae7070573d8285f8dcfb054c95d [file] [log] [blame]
Paul Bakkerb06819b2011-01-18 16:18:38 +00001set(libs
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +02002 mbedtls
Paul Bakkerb06819b2011-01-18 16:18:38 +00003)
4
5if(USE_PKCS11_HELPER_LIBRARY)
6 set(libs ${libs} pkcs11-helper)
7endif(USE_PKCS11_HELPER_LIBRARY)
8
Paul Bakker92eeea42012-07-03 15:10:33 +00009if(ENABLE_ZLIB_SUPPORT)
10 set(libs ${libs} ${ZLIB_LIBRARIES})
11endif(ENABLE_ZLIB_SUPPORT)
12
Nicholas Wilson733676b2015-11-14 13:09:01 +000013find_package(Perl)
14if(NOT PERL_FOUND)
15 message(FATAL_ERROR "Cannot build test suites without Perl")
16endif()
17
Nicholas Wilson2682edf2017-12-05 12:08:15 +000018# Enable definition of various functions used throughout the testsuite
Nicholas Wilson61fa4362018-06-25 12:10:00 +010019# (gethostname, strdup, fileno...) even when compiling with -std=c99. Harmless
Nicholas Wilson2682edf2017-12-05 12:08:15 +000020# on non-POSIX platforms.
21add_definitions("-D_POSIX_C_SOURCE=200809L")
22
Gilles Peskineac372cc2018-11-29 10:15:06 +000023# Test suites caught by SKIP_TEST_SUITES are built but not executed.
24# "foo" as a skip pattern skips "test_suite_foo" and "test_suite_foo.bar"
25# but not "test_suite_foobar".
26string(REGEX REPLACE "[ ,;]" "|" SKIP_TEST_SUITES_REGEX "${SKIP_TEST_SUITES}")
27string(REPLACE "." "\\." SKIP_TEST_SUITES_REGEX "${SKIP_TEST_SUITES_REGEX}")
28set(SKIP_TEST_SUITES_REGEX "^(${SKIP_TEST_SUITES_REGEX})(\$|\\.)")
29
Paul Bakker73043762011-07-13 15:03:10 +000030function(add_test_suite suite_name)
31 if(ARGV1)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +020032 set(data_name ${ARGV1})
Paul Bakker73043762011-07-13 15:03:10 +000033 else()
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +020034 set(data_name ${suite_name})
Paul Bakker46c17942011-07-13 14:54:54 +000035 endif()
36
Paul Bakker367dae42009-06-28 21:50:27 +000037 add_custom_command(
Paul Bakker73043762011-07-13 15:03:10 +000038 OUTPUT test_suite_${data_name}.c
Azim Khan63ab5012018-06-29 15:00:11 +010039 COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py -f ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function -d ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${data_name}.data -t ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function -p ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function -s ${CMAKE_CURRENT_SOURCE_DIR}/suites --helpers-file ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function -o .
Mohammad Azim Khan78befd92018-03-06 11:49:41 +000040 DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/scripts/generate_test_code.py mbedtls ${CMAKE_CURRENT_SOURCE_DIR}/suites/helpers.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/main_test.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/host_test.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${suite_name}.function ${CMAKE_CURRENT_SOURCE_DIR}/suites/test_suite_${data_name}.data
Paul Bakker4c14a252010-06-18 22:54:05 +000041 )
Paul Bakker19343182013-08-16 13:31:10 +020042
Jaeden Amerob478bb62019-03-07 16:44:54 +000043 set(exe_name test_suite_${data_name})
44 # Add a prefix to differentiate these tests from those of the parent
45 # module, when this project is built as a submodule.
46 if(USE_CRYPTO_SUBMODULE)
47 set(exe_name crypto.${exe_name})
48 endif()
49
Paul Bakker4c14a252010-06-18 22:54:05 +000050 include_directories(${CMAKE_CURRENT_SOURCE_DIR})
Jaeden Amerob478bb62019-03-07 16:44:54 +000051 add_executable(${exe_name} test_suite_${data_name}.c)
52 target_link_libraries(${exe_name} ${libs})
53 target_include_directories(${exe_name}
Jaeden Amero120d5712019-03-07 15:32:49 +000054 PUBLIC ${CMAKE_SOURCE_DIR}/include/
Jaeden Amero0a504c02019-03-15 15:44:14 +000055 PUBLIC ${CMAKE_SOURCE_DIR}/crypto/include/
56 PRIVATE ${CMAKE_SOURCE_DIR}/crypto/library/)
Jaeden Amero120d5712019-03-07 15:32:49 +000057
Gilles Peskineac372cc2018-11-29 10:15:06 +000058 if(${data_name} MATCHES ${SKIP_TEST_SUITES_REGEX})
59 message(STATUS "The test suite ${data_name} will not be executed.")
60 else()
Jaeden Amerob478bb62019-03-07 16:44:54 +000061 add_test(${data_name}-suite ${exe_name} --verbose)
Gilles Peskineac372cc2018-11-29 10:15:06 +000062 endif()
Paul Bakker367dae42009-06-28 21:50:27 +000063endfunction(add_test_suite)
64
Manuel Pégourié-Gonnard7e2d68c2015-07-01 13:41:35 +020065if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
66 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-unused-function")
67endif(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_CLANG)
Paul Bakker367dae42009-06-28 21:50:27 +000068
Manuel Pégourié-Gonnard30830532015-07-01 17:06:28 +020069if(MSVC)
Simon B9b3e3c42016-11-03 01:12:50 +000070 # If a warning level has been defined, suppress all warnings for test code
71 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /W0")
72 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX-")
Manuel Pégourié-Gonnard30830532015-07-01 17:06:28 +020073endif(MSVC)
74
Paul Bakker286bf3c2013-04-08 18:09:51 +020075add_test_suite(aes aes.ecb)
76add_test_suite(aes aes.cbc)
77add_test_suite(aes aes.cfb)
Gilles Peskinec8fff7b2018-11-29 10:55:21 +000078add_test_suite(aes aes.ofb)
Paul Bakker286bf3c2013-04-08 18:09:51 +020079add_test_suite(aes aes.rest)
Aorimn5f778012016-06-09 23:22:58 +020080add_test_suite(aes aes.xts)
Paul Bakker367dae42009-06-28 21:50:27 +000081add_test_suite(arc4)
Manuel Pégourié-Gonnard442f03b2018-02-20 13:56:54 +010082add_test_suite(aria)
Manuel Pégourié-Gonnard36178ff2014-05-29 14:26:03 +020083add_test_suite(asn1write)
Paul Bakker9d781402011-05-09 16:17:09 +000084add_test_suite(base64)
Paul Bakkera9379c02012-07-04 11:02:11 +000085add_test_suite(blowfish)
Paul Bakker9d781402011-05-09 16:17:09 +000086add_test_suite(camellia)
Manuel Pégourié-Gonnarda6916fa2014-05-02 15:17:29 +020087add_test_suite(ccm)
Daniel King34b822c2016-05-15 17:28:08 -030088add_test_suite(chacha20)
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +020089add_test_suite(chachapoly)
Paul Bakker46c17942011-07-13 14:54:54 +000090add_test_suite(cipher cipher.aes)
Manuel Pégourié-Gonnard37e230c2013-08-28 13:50:42 +020091add_test_suite(cipher cipher.arc4)
Paul Bakker6132d0a2012-07-04 17:10:40 +000092add_test_suite(cipher cipher.blowfish)
Paul Bakker46c17942011-07-13 14:54:54 +000093add_test_suite(cipher cipher.camellia)
Manuel Pégourié-Gonnard542eac52014-05-15 16:03:07 +020094add_test_suite(cipher cipher.ccm)
Daniel Kingbd920622016-05-15 19:56:20 -030095add_test_suite(cipher cipher.chacha20)
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +020096add_test_suite(cipher cipher.chachapoly)
Paul Bakker46c17942011-07-13 14:54:54 +000097add_test_suite(cipher cipher.des)
Manuel Pégourié-Gonnard07f8fa52013-08-30 18:34:08 +020098add_test_suite(cipher cipher.gcm)
Andrzej Kurekc470b6b2019-01-31 08:20:20 -050099add_test_suite(cipher cipher.misc)
Paul Bakkerfab5c822012-02-06 16:45:10 +0000100add_test_suite(cipher cipher.null)
Manuel Pégourié-Gonnardd5fdcaf2013-07-24 18:05:00 +0200101add_test_suite(cipher cipher.padding)
Simon Butcher53da6ae2016-10-10 22:03:39 +0100102add_test_suite(cmac)
Paul Bakker0e04d0e2011-11-27 14:46:59 +0000103add_test_suite(ctr_drbg)
Paul Bakker9d781402011-05-09 16:17:09 +0000104add_test_suite(des)
105add_test_suite(dhm)
Manuel Pégourié-Gonnard61ce13b2013-01-26 16:20:32 +0100106add_test_suite(ecdh)
Manuel Pégourié-Gonnardd1c71502013-01-26 19:09:07 +0100107add_test_suite(ecdsa)
Manuel Pégourié-Gonnard4d8685b2015-08-05 15:44:42 +0200108add_test_suite(ecjpake)
109add_test_suite(ecp)
Manuel Pégourié-Gonnard2c25eb02014-05-30 10:38:18 +0200110add_test_suite(entropy)
Paul Bakker9d781402011-05-09 16:17:09 +0000111add_test_suite(error)
Manuel Pégourié-Gonnard94dd5b42013-10-24 11:57:47 +0200112add_test_suite(gcm gcm.aes128_en)
113add_test_suite(gcm gcm.aes192_en)
114add_test_suite(gcm gcm.aes256_en)
115add_test_suite(gcm gcm.aes128_de)
116add_test_suite(gcm gcm.aes192_de)
117add_test_suite(gcm gcm.aes256_de)
Manuel Pégourié-Gonnard13e0d442013-10-24 12:59:00 +0200118add_test_suite(gcm gcm.camellia)
Andrzej Kurekc470b6b2019-01-31 08:20:20 -0500119add_test_suite(gcm gcm.misc)
Thomas Fossati656864b2016-07-17 08:51:22 +0100120add_test_suite(hkdf)
Manuel Pégourié-Gonnard48bc3e82014-01-30 21:11:16 +0100121add_test_suite(hmac_drbg hmac_drbg.misc)
Manuel Pégourié-Gonnard6801f392014-01-30 17:22:14 +0100122add_test_suite(hmac_drbg hmac_drbg.no_reseed)
Manuel Pégourié-Gonnard24600b72014-01-31 09:54:14 +0100123add_test_suite(hmac_drbg hmac_drbg.nopr)
Manuel Pégourié-Gonnard62273b82014-01-31 10:16:57 +0100124add_test_suite(hmac_drbg hmac_drbg.pr)
Paul Bakker17373852011-01-06 14:20:01 +0000125add_test_suite(md)
Paul Bakker9d781402011-05-09 16:17:09 +0000126add_test_suite(mdx)
Manuel Pégourié-Gonnard765bb312014-11-27 11:55:27 +0100127add_test_suite(memory_buffer_alloc)
Paul Bakker9d781402011-05-09 16:17:09 +0000128add_test_suite(mpi)
Ron Eldor8dd03cd2018-07-15 09:37:28 +0300129add_test_suite(nist_kw)
Jaeden Ameroc70a3c72019-03-28 16:02:25 +0000130add_test_suite(oid)
Paul Bakker16300582014-04-11 13:28:43 +0200131add_test_suite(pem)
Janos Follath8a49a012016-02-12 13:18:20 +0000132add_test_suite(pkcs1_v15)
Paul Bakker9dcc3222011-03-08 14:16:06 +0000133add_test_suite(pkcs1_v21)
Paul Bakkerb0c19a42013-06-24 19:26:38 +0200134add_test_suite(pkcs5)
Manuel Pégourié-Gonnardb0a467f2013-09-21 12:31:05 +0200135add_test_suite(pk)
Paul Bakker1a7550a2013-09-15 13:01:22 +0200136add_test_suite(pkparse)
Paul Bakkerc7bb02b2013-09-15 14:54:56 +0200137add_test_suite(pkwrite)
Daniel Kingadc32c02016-05-16 18:25:45 -0300138add_test_suite(poly1305)
Moran Pekerb4d0ddd2018-04-04 12:47:52 +0300139add_test_suite(psa_crypto)
Netanel Gonen9468bb22018-11-19 11:53:55 +0200140add_test_suite(psa_crypto_entropy)
itayzafrir02d62952018-10-24 12:45:18 +0300141add_test_suite(psa_crypto_hash)
Gilles Peskineb309eec2018-11-20 20:56:14 +0100142add_test_suite(psa_crypto_init)
Gilles Peskine6dee5c92018-10-22 19:11:00 +0200143add_test_suite(psa_crypto_metadata)
Darryl Greend49a4992018-06-18 17:27:26 +0100144add_test_suite(psa_crypto_persistent_key)
Gilles Peskine5ec7b072018-11-30 18:53:28 +0100145add_test_suite(psa_crypto_slot_management)
Gilles Peskinebc1f2722018-11-16 22:24:38 +0100146add_test_suite(psa_its)
Paul Bakker9d781402011-05-09 16:17:09 +0000147add_test_suite(shax)
Paul Bakker50157ff2016-07-19 14:57:00 +0100148add_test_suite(timing)
Paul Bakker9d781402011-05-09 16:17:09 +0000149add_test_suite(rsa)
Paul Bakker9d781402011-05-09 16:17:09 +0000150add_test_suite(xtea)
Jaeden Amero1264c2a2019-03-07 16:01:11 +0000151if (NOT USE_CRYPTO_SUBMODULE)
152 add_test_suite(version)
153endif()
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100154
Gilles Peskine84052572018-03-21 12:12:47 +0100155# Make scripts and data files needed for testing available in an
156# out-of-source build.
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100157if (NOT ${CMAKE_CURRENT_BINARY_DIR} STREQUAL ${CMAKE_CURRENT_SOURCE_DIR})
Andrzej Kurek0c74e302019-05-06 06:18:24 -0400158 if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/seedfile")
159 link_to_source(seedfile)
160 endif()
Gilles Peskine84052572018-03-21 12:12:47 +0100161 link_to_source(data_files)
162 link_to_source(scripts)
Gilles Peskine6a785732019-01-02 17:29:04 +0100163 link_to_source(suites)
Paul Bakkercd6d69a2014-02-06 15:43:21 +0100164endif()