diff options
| -rw-r--r-- | tests/CMakeLists.txt | 9 | ||||
| -rw-r--r-- | tests/CTestCustom.template | 7 | ||||
| -rw-r--r-- | tests/test_pretty_print.cc | 22 | ||||
| -rwxr-xr-x | tests/virtualfb.sh | 70 | 
4 files changed, 88 insertions, 20 deletions
| diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index d2daf43..854fb44 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -569,6 +569,15 @@ set_target_properties(throwntogethertest PROPERTIES COMPILE_FLAGS "-DENABLE_OPEN  target_link_libraries(throwntogethertest tests-offscreen tests-cgal ${OPENCSG_LIBRARY} ${TESTS-CGAL-LIBRARIES} ${GLEW_LIBRARY} ${COCOA_LIBRARY})  # +# Post-test pretty print +# + +add_executable(test_pretty_print test_pretty_print.cc) +set_target_properties(test_pretty_print PROPERTIES COMPILE_FLAGS +  "-DPYBIN=${PYTHON_EXECUTABLE} -DPYSRC=test_pretty_print.py -DBUILDDIR=--builddir=${CMAKE_CURRENT_BINARY_DIR}" +) + +#  # Tags tests as disabled. This is more convenient than removing them manually  # from the lists of filenames  # diff --git a/tests/CTestCustom.template b/tests/CTestCustom.template index 72e6443..8ab2f5b 100644 --- a/tests/CTestCustom.template +++ b/tests/CTestCustom.template @@ -24,8 +24,7 @@ if( __cmake_system_name__ MATCHES "Linux|BSD")   else()    message("X11 DISPLAY environment variable not found. Calling virtualfb.sh")    execute_process( -   COMMAND __cmake_current_source_dir__/virtualfb.sh start -   OUTPUT_VARIABLE SVFB_OUT) +   COMMAND __cmake_current_source_dir__/virtualfb.sh OUTPUT_VARIABLE SVFB_OUT)    string(REGEX MATCH "DISPLAY=:[0-9.]*" VFB_DISPLAY_STR "${SVFB_OUT}")    string(REGEX MATCH ":[0-9.]*" VFB_DISPLAY "${VFB_DISPLAY_STR}")    string(REGEX MATCH "PID=[0-9.]*" VFB_PID_STR "${SVFB_OUT}") @@ -50,7 +49,7 @@ if( __cmake_system_name__ MATCHES "Linux|BSD")    # in the build directory).    set(ENV{DISPLAY} "${VFB_DISPLAY}") -  set(CTEST_CUSTOM_POST_TEST "kill ${VFB_PID}") +  set(CTEST_CUSTOM_POST_TEST "__cmake_current_source_dir__/virtualfb.sh")   endif()  endif() @@ -59,7 +58,7 @@ endif()  message("running 'opencsgtest --info' to generate sysinfo.txt")  execute_process(COMMAND __wine__ __cmake_current_binary_dir__/opencsgtest --info OUTPUT_FILE sysinfo.txt) -set(CTEST_CUSTOM_POST_TEST ${CTEST_CUSTOM_POST_TEST} "__python__ __cmake_current_source_dir__/test_pretty_print.py --builddir=__cmake_current_binary_dir__") +set(CTEST_CUSTOM_POST_TEST ${CTEST_CUSTOM_POST_TEST} "__cmake_current_binary_dir__/test_pretty_print")  if ( ${debug_openscad_template} )    foreach(post_test ${CTEST_CUSTOM_POST_TEST} ) diff --git a/tests/test_pretty_print.cc b/tests/test_pretty_print.cc new file mode 100644 index 0000000..b400e21 --- /dev/null +++ b/tests/test_pretty_print.cc @@ -0,0 +1,22 @@ +/* Workaround for CTEST_CUSTOM_POST_TEST not allowing arguments + compile with + -DPYBIN=/usr/bin/python  + -DPYSRC=/home/janedoe/openscad/tests/test_pretty_print.py + -DBUILDDIR=--builddir=/home/janedoe/openscad/tests/bin" +*/ + +#include <unistd.h> + +#define PREQUOTE(x) #x +#define QUOTE(x) PREQUOTE(x) +int main( int argc, char * argv[] ) +{ +	char *newargs[4]; +	newargs[0] = const_cast<char *>(QUOTE( PYBIN )); +	newargs[1] = const_cast<char *>(QUOTE( PYSRC )); +	newargs[2] = const_cast<char *>(QUOTE( BUILDDIR )); +	newargs[3] = NULL; +	return execv( newargs[0], newargs ); +} + + diff --git a/tests/virtualfb.sh b/tests/virtualfb.sh index 3c0cf0e..e0d8320 100755 --- a/tests/virtualfb.sh +++ b/tests/virtualfb.sh @@ -1,22 +1,60 @@  #!/bin/sh -if [ "`command -v Xvfb`" ]; then -  VFB_BINARY=Xvfb -fi +# Toggle the Virtual Framebuffer +# If started, stop. If stopped, start. -if [ "`command -v Xvnc`" ]; then -  VFB_BINARY=Xvnc -fi +start() +{ +  if [ "`command -v Xvfb`" ]; then +    VFB_BINARY=Xvfb +  fi + +  if [ "`command -v Xvnc`" ]; then +    VFB_BINARY=Xvnc +  fi + +  if [ ! $VFB_BINARY ]; then +    echo "$0 Failed, cannot find Xvfb or Xvnc" +    exit 1 +  fi + +  VFB_DISPLAY=`echo | awk 'BEGIN{srand();} {printf ":%.0f", rand()*1000+100};'` +  $VFB_BINARY $VFB_DISPLAY -screen 0 800x600x24 &> ./virtualfb.log & +  VFB_PID=$! + +  echo $VFB_DISPLAY > ./virtualfb.DISPLAY +  echo $VFB_PID > ./virtualfb.PID + +  echo "Started virtual fb, PID=$VFB_PID , DISPLAY=$VFB_DISPLAY" +  sleep 1 +} + +stop() +{ +  VFB_PID=`cat ./virtualfb.PID` +  VFB_DISPLAY=`cat ./virtualfb.DISPLAY` + +  echo "Stopping virtual fb, PID=$VFB_PID, DISPLAY=$VFB_DISPLAY" +  kill $VFB_PID +  LOCKFILE=`echo "/tmp/.X"$VFB_DISPLAY"-lock"` +  if [ -e $LOCKFILE ]; then +    rm $LOCKFILE +  fi +  rm ./virtualfb.PID +  rm ./virtualfb.DISPLAY +} + +isrunning() +{ +  isrunning_result= +  if [ -e ./virtualfb.PID ]; then isrunning_result=1 ; fi +  if [ -e ./virtualfb.DISPLAY ]; then isrunning_result=1 ; fi +} -if [ ! $VFB_BINARY ]; then -  echo "$0 Failed, cannot find Xvfb or Xvnc" -  exit 1 +isrunning +if [ $isrunning_result ]; then +  stop +else +  start  fi -DISPLAY=:98 -$VFB_BINARY $DISPLAY -screen 0 800x600x24 &> virtualfblog & -echo PID=$! " " -echo DISPLAY=$DISPLAY -# trap "kill -KILL $xpid ||:" EXIT -export DISPLAY -sleep 3 | 
