2018-12-22 01:17:44 +08:00
|
|
|
# arguments checking
|
|
|
|
if( NOT TEST_PROGRAM )
|
|
|
|
message( FATAL_ERROR "Require TEST_PROGRAM to be defined" )
|
|
|
|
endif( NOT TEST_PROGRAM )
|
|
|
|
if( NOT TEST_ARGS )
|
|
|
|
message( FATAL_ERROR "Require TEST_ARGS to be defined" )
|
|
|
|
endif( NOT TEST_ARGS )
|
|
|
|
if( NOT TEST_OUTPUT )
|
|
|
|
message( FATAL_ERROR "Require TEST_OUTPUT to be defined" )
|
|
|
|
endif( NOT TEST_OUTPUT )
|
|
|
|
if( NOT TEST_REFERENCE )
|
|
|
|
message( FATAL_ERROR "Require TEST_REFERENCE to be defined" )
|
|
|
|
endif( NOT TEST_REFERENCE )
|
|
|
|
|
|
|
|
set(ENV{BOX86_LOG} 0)
|
2020-10-05 17:53:46 +08:00
|
|
|
set(ENV{BOX86_NOBANNER} 1)
|
2020-08-06 18:22:01 +08:00
|
|
|
if( EXISTS ${CMAKE_SOURCE_DIR}/x86lib )
|
|
|
|
# we are inside box86 folder
|
|
|
|
set(ENV{LD_LIBRARY_PATH} ${CMAKE_SOURCE_DIR}/x86lib)
|
|
|
|
else()
|
|
|
|
# we are inside build folder
|
|
|
|
set(ENV{LD_LIBRARY_PATH} ${CMAKE_SOURCE_DIR}/../x86lib)
|
|
|
|
endif( EXISTS ${CMAKE_SOURCE_DIR}/x86lib )
|
|
|
|
|
2018-12-22 01:17:44 +08:00
|
|
|
# run the test program, capture the stdout/stderr and the result var
|
|
|
|
execute_process(
|
2018-12-22 23:15:26 +08:00
|
|
|
COMMAND ${TEST_PROGRAM} ${TEST_ARGS} ${TEST_ARGS2}
|
2018-12-22 01:17:44 +08:00
|
|
|
OUTPUT_FILE ${TEST_OUTPUT}
|
|
|
|
ERROR_VARIABLE TEST_ERROR
|
|
|
|
RESULT_VARIABLE TEST_RESULT
|
|
|
|
)
|
|
|
|
|
|
|
|
# if the return value is !=0 bail out
|
|
|
|
if( TEST_RESULT )
|
2021-05-24 03:35:05 +08:00
|
|
|
get_filename_component(TESTNAME "${TEST_ARGS}" NAME)
|
|
|
|
file(RENAME "${TEST_OUTPUT}" "${CMAKE_BINARY_DIR}/${TESTNAME}.out")
|
|
|
|
file(WRITE "${CMAKE_BINARY_DIR}/${TESTNAME}.err" ${TEST_ERROR})
|
2018-12-22 01:17:44 +08:00
|
|
|
message( FATAL_ERROR "Failed: Test program ${TEST_PROGRAM} exited != 0.\n${TEST_ERROR}" )
|
|
|
|
endif( TEST_RESULT )
|
|
|
|
|
|
|
|
# now compare the output with the reference
|
|
|
|
execute_process(
|
2021-05-24 03:35:05 +08:00
|
|
|
COMMAND "${CMAKE_COMMAND}" -E compare_files "${TEST_OUTPUT}" "${TEST_REFERENCE}"
|
2018-12-22 01:17:44 +08:00
|
|
|
RESULT_VARIABLE TEST_RESULT
|
|
|
|
)
|
|
|
|
|
|
|
|
# again, if return value is !=0 scream and shout
|
|
|
|
if( TEST_RESULT )
|
2021-05-24 03:35:05 +08:00
|
|
|
get_filename_component(TESTNAME "${TEST_ARGS}" NAME)
|
|
|
|
file(RENAME "${TEST_OUTPUT}" "${CMAKE_BINARY_DIR}/${TESTNAME}.out")
|
|
|
|
file(WRITE "${CMAKE_BINARY_DIR}/${TESTNAME}.err" ${TEST_ERROR})
|
2018-12-22 01:17:44 +08:00
|
|
|
message( FATAL_ERROR "Failed: The output of ${TEST_PROGRAM} did not match ${TEST_REFERENCE}")
|
|
|
|
endif( TEST_RESULT )
|
|
|
|
|
2022-01-07 15:59:21 +08:00
|
|
|
# remove the temporary files if they exist
|
|
|
|
if( EXISTS ${TEST_OUTPUT} )
|
|
|
|
file(REMOVE "${TEST_OUTPUT}")
|
|
|
|
endif()
|
|
|
|
|
2018-12-22 01:17:44 +08:00
|
|
|
# everything went fine...
|
|
|
|
message( "Passed: The output of ${TEST_PROGRAM} matches ${TEST_REFERENCE}" )
|