CMakeLists.txt 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. find_package(GTest)
  2. if(GTest_FOUND)
  3. if(NOT TARGET GTest::gtest_main AND TARGET GTest::Main)
  4. # CMake <3.20
  5. add_library(GTest::gtest_main INTERFACE IMPORTED)
  6. target_link_libraries(GTest::gtest_main INTERFACE GTest::Main)
  7. endif()
  8. else()
  9. if(POLICY CMP0135)
  10. cmake_policy(SET CMP0135 NEW)
  11. endif()
  12. include(FetchContent)
  13. set(BUILD_GMOCK OFF)
  14. set(INSTALL_GTEST OFF)
  15. set(gtest_force_shared_crt ON)
  16. FetchContent_Declare(
  17. gtest
  18. URL https://github.com/google/googletest/archive/main.tar.gz
  19. )
  20. FetchContent_MakeAvailable(gtest)
  21. endif()
  22. find_package(CURL REQUIRED)
  23. add_executable(httplib-test test.cc include_httplib.cc $<$<BOOL:${WIN32}>:include_windows_h.cc>)
  24. target_compile_options(httplib-test PRIVATE "$<$<CXX_COMPILER_ID:MSVC>:/utf-8;/bigobj>")
  25. target_link_libraries(httplib-test PRIVATE httplib GTest::gtest_main CURL::libcurl)
  26. gtest_discover_tests(httplib-test)
  27. file(
  28. COPY www www2 www3 ca-bundle.crt image.jpg
  29. DESTINATION ${CMAKE_CURRENT_BINARY_DIR}
  30. )
  31. if(HTTPLIB_IS_USING_OPENSSL)
  32. if (OPENSSL_VERSION VERSION_LESS "3.2.0")
  33. set(OPENSSL_X509_FLAG "-x509")
  34. else()
  35. set(OPENSSL_X509_FLAG "-x509v1")
  36. endif()
  37. find_program(OPENSSL_COMMAND
  38. NAMES openssl
  39. PATHS ${OPENSSL_INCLUDE_DIR}/../bin
  40. REQUIRED
  41. )
  42. execute_process(
  43. COMMAND ${OPENSSL_COMMAND} genrsa 2048
  44. OUTPUT_FILE key.pem
  45. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  46. COMMAND_ERROR_IS_FATAL ANY
  47. )
  48. execute_process(
  49. COMMAND ${OPENSSL_COMMAND} req -new -batch -config ${CMAKE_CURRENT_LIST_DIR}/test.conf -key key.pem
  50. COMMAND ${OPENSSL_COMMAND} x509 -days 3650 -req -signkey key.pem
  51. OUTPUT_FILE cert.pem
  52. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  53. COMMAND_ERROR_IS_FATAL ANY
  54. )
  55. execute_process(
  56. COMMAND ${OPENSSL_COMMAND} req ${OPENSSL_X509_FLAG} -new -config ${CMAKE_CURRENT_LIST_DIR}/test.conf -key key.pem -sha256 -days 3650 -nodes -out cert2.pem -extensions SAN
  57. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  58. COMMAND_ERROR_IS_FATAL ANY
  59. )
  60. execute_process(
  61. COMMAND ${OPENSSL_COMMAND} genrsa 2048
  62. OUTPUT_FILE rootCA.key.pem
  63. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  64. COMMAND_ERROR_IS_FATAL ANY
  65. )
  66. execute_process(
  67. COMMAND ${OPENSSL_COMMAND} req ${OPENSSL_X509_FLAG} -new -batch -config ${CMAKE_CURRENT_LIST_DIR}/test.rootCA.conf -key rootCA.key.pem -days 1024
  68. OUTPUT_FILE rootCA.cert.pem
  69. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  70. COMMAND_ERROR_IS_FATAL ANY
  71. )
  72. execute_process(
  73. COMMAND ${OPENSSL_COMMAND} genrsa 2048
  74. OUTPUT_FILE client.key.pem
  75. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  76. COMMAND_ERROR_IS_FATAL ANY
  77. )
  78. execute_process(
  79. COMMAND ${OPENSSL_COMMAND} req -new -batch -config ${CMAKE_CURRENT_LIST_DIR}/test.conf -key client.key.pem
  80. COMMAND ${OPENSSL_COMMAND} x509 -days 370 -req -CA rootCA.cert.pem -CAkey rootCA.key.pem -CAcreateserial
  81. OUTPUT_FILE client.cert.pem
  82. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  83. COMMAND_ERROR_IS_FATAL ANY
  84. )
  85. execute_process(
  86. COMMAND ${OPENSSL_COMMAND} genrsa -passout pass:test123! 2048
  87. OUTPUT_FILE key_encrypted.pem
  88. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  89. COMMAND_ERROR_IS_FATAL ANY
  90. )
  91. execute_process(
  92. COMMAND ${OPENSSL_COMMAND} req -new -batch -config ${CMAKE_CURRENT_LIST_DIR}/test.conf -key key_encrypted.pem
  93. COMMAND ${OPENSSL_COMMAND} x509 -days 3650 -req -signkey key_encrypted.pem
  94. OUTPUT_FILE cert_encrypted.pem
  95. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  96. COMMAND_ERROR_IS_FATAL ANY
  97. )
  98. execute_process(
  99. COMMAND ${OPENSSL_COMMAND} genrsa -aes256 -passout pass:test012! 2048
  100. OUTPUT_FILE client_encrypted.key.pem
  101. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  102. COMMAND_ERROR_IS_FATAL ANY
  103. )
  104. execute_process(
  105. COMMAND ${OPENSSL_COMMAND} req -new -batch -config ${CMAKE_CURRENT_LIST_DIR}/test.conf -key client_encrypted.key.pem -passin pass:test012!
  106. COMMAND ${OPENSSL_COMMAND} x509 -days 370 -req -CA rootCA.cert.pem -CAkey rootCA.key.pem -CAcreateserial
  107. OUTPUT_FILE client_encrypted.cert.pem
  108. WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
  109. COMMAND_ERROR_IS_FATAL ANY
  110. )
  111. endif()
  112. add_subdirectory(fuzzing)