| # If we are being built as part of lws, confirm current build config supports |
| # reqconfig, else skip building ourselves. |
| # |
| # If we are being built externally, confirm installed lws was configured to |
| # support reqconfig, else error out with a helpful message about the problem. |
| # |
| |
| include(CheckIncludeFile) |
| |
| MACRO(require_lws_config reqconfig _val result) |
| |
| if (DEFINED ${reqconfig}) |
| if (${reqconfig}) |
| set (rq 1) |
| else() |
| set (rq 0) |
| endif() |
| else() |
| set(rq 0) |
| endif() |
| |
| if (${_val} EQUAL ${rq}) |
| set(SAME 1) |
| else() |
| set(SAME 0) |
| endif() |
| |
| string(COMPARE EQUAL "${result}" requirements _cmp) |
| |
| # we go in the first clause if in-tree |
| if (LWS_WITH_MINIMAL_EXAMPLES AND NOT ${SAME}) |
| if (${_val}) |
| message("${SAMP}: skipping as lws being built without ${reqconfig}") |
| else() |
| message("${SAMP}: skipping as lws built with ${reqconfig}") |
| endif() |
| set(${result} 0) |
| else() |
| if (LWS_WITH_MINIMAL_EXAMPLES) |
| set(MET ${SAME}) |
| else() |
| CHECK_C_SOURCE_COMPILES("#include <libwebsockets.h>\nint main(void) {\n#if defined(${reqconfig})\n return 0;\n#else\n fail;\n#endif\n return 0;\n}\n" HAS_${reqconfig}) |
| if (NOT DEFINED HAS_${reqconfig} OR NOT HAS_${reqconfig}) |
| set(HAS_${reqconfig} 0) |
| else() |
| set(HAS_${reqconfig} 1) |
| endif() |
| if ((HAS_${reqconfig} AND ${_val}) OR (NOT HAS_${reqconfig} AND NOT ${_val})) |
| set(MET 1) |
| else() |
| set(MET 0) |
| endif() |
| endif() |
| if (NOT MET AND _cmp) |
| if (${_val}) |
| message(FATAL_ERROR "This project requires lws must have been configured with ${reqconfig}") |
| else() |
| message(FATAL_ERROR "Lws configuration of ${reqconfig} is incompatible with this project") |
| endif() |
| endif() |
| |
| endif() |
| ENDMACRO() |
| |
| MACRO(require_pthreads result) |
| CHECK_INCLUDE_FILE(pthread.h LWS_HAVE_PTHREAD_H) |
| if (NOT LWS_HAVE_PTHREAD_H) |
| if (LWS_WITH_MINIMAL_EXAMPLES) |
| set(${result} 0) |
| message("${SAMP}: skipping as no pthreads") |
| else() |
| message(FATAL_ERROR "threading support requires pthreads") |
| endif() |
| else() |
| if (WIN32) |
| set(PTHREAD_LIB ${LWS_EXT_PTHREAD_LIBRARIES}) |
| else() |
| set(PTHREAD_LIB pthread) |
| endif() |
| endif() |
| ENDMACRO() |
| |
| MACRO(sai_resource SR_NAME SR_AMOUNT SR_LEASE SR_SCOPE) |
| if (DEFINED ENV{SAI_OVN}) |
| |
| site_name(HOST_NAME) |
| |
| # |
| # Creates a "test" called res_${SR_SCOPE} that waits to be |
| # given a lease on ${SR_AMOUNT} of a resource ${SR_NAME}, for at |
| # most $SR_LEASE seconds, until the test dependent on it can |
| # proceed. |
| # |
| # We need to keep this sai-resource instance up for the |
| # duration of the actual test it is authorizing, when it |
| # is killed, the resource is then immediately released. |
| # |
| # The resource cookie has to be globally unique within the |
| # distributed builder sessions, so it includes the builder |
| # hostname and builder instance information |
| # |
| |
| add_test(NAME st_res_${SR_SCOPE} COMMAND |
| ${CMAKE_SOURCE_DIR}/scripts/ctest-background.sh |
| res_${SR_SCOPE} |
| sai-resource ${SR_NAME} ${SR_AMOUNT} ${SR_LEASE} |
| ${HOST_NAME}-res_${SR_SCOPE}-$ENV{SAI_PROJECT}-$ENV{SAI_OVN}) |
| |
| # allow it to wait for up to 100s for the resource lease |
| |
| set_tests_properties(st_res_${SR_SCOPE} PROPERTIES |
| WORKING_DIRECTORY . |
| FIXTURES_SETUP res_sspcmin |
| TIMEOUT 100) |
| |
| add_test(NAME ki_res_${SR_SCOPE} COMMAND |
| ${CMAKE_SOURCE_DIR}/scripts/ctest-background-kill.sh |
| res_${SR_SCOPE} sai-resource ) |
| |
| set_tests_properties(ki_res_${SR_SCOPE} PROPERTIES |
| FIXTURES_CLEANUP res_${SR_SCOPE}) |
| |
| endif() |
| ENDMACRO() |
| |