Fix running test programs from within visual studio. 44/3144/1
authorJoakim Soderberg <joakim.soderberg@gmail.com>
Fri, 22 Feb 2013 01:28:17 +0000 (09:28 +0800)
committerKevron Rees <kevron_m_rees@linux.intel.com>
Thu, 7 Mar 2013 21:01:38 +0000 (13:01 -0800)
Copy test-server data to a path so that we can run the test-server from
within visual studio without having to copy stuff around.

CMakeLists.txt
win32port/win32helpers/websock-w32.h

index 3b507b4..71402a2 100644 (file)
@@ -544,10 +544,10 @@ if (NOT WITHOUT_TESTAPPS)
 
                # Data files for running the test server.
                set(TEST_SERVER_DATA
-                       test-server/favicon.ico 
-                       test-server/leaf.jpg
-                       test-server/libwebsockets.org-logo.png
-                       test-server/test.html)
+                       ${PROJECT_SOURCE_DIR}/test-server/favicon.ico 
+                       ${PROJECT_SOURCE_DIR}/test-server/leaf.jpg
+                       ${PROJECT_SOURCE_DIR}/test-server/libwebsockets.org-logo.png
+                       ${PROJECT_SOURCE_DIR}/test-server/test.html)
 
                # Generate self-signed SSL certs for the test-server.
                if (WITH_SSL AND OPENSSL_EXECUTABLE)
@@ -574,6 +574,8 @@ if (NOT WITHOUT_TESTAPPS)
                                        COMMAND "${OPENSSL_EXECUTABLE}" req -new -newkey rsa:1024 -days 10000 -nodes -x509 -keyout "${TEST_SERVER_SSL_KEY}" -out "${TEST_SERVER_SSL_CERT}"
                                        RESULT_VARIABLE OPENSSL_RETURN_CODE)
                                
+                               message("\n")
+
                                if (OPENSSL_RETURN_CODE)
                                        message("!!! Failed to generate SSL certificate:\n${OPENSSL_RETURN_CODE} !!!")
                                endif()
@@ -589,6 +591,15 @@ if (NOT WITHOUT_TESTAPPS)
                                ${TEST_SERVER_SSL_KEY} 
                                ${TEST_SERVER_SSL_CERT})
                endif()
+
+               # Copy the file needed to run the server so that the test apps can
+               # reach them from their default output location
+               foreach (TEST_FILE ${TEST_SERVER_DATA})
+                       add_custom_command(TARGET test-server
+                                               POST_BUILD 
+                                               COMMAND ${CMAKE_COMMAND} -E make_directory "$<TARGET_FILE_DIR:test-server>/../share/libwebsockets-test-server"
+                                               COMMAND ${CMAKE_COMMAND} -E copy ${TEST_FILE} "$<TARGET_FILE_DIR:test-server>/../share/libwebsockets-test-server" VERBATIM)
+               endforeach()
        endif(NOT WITHOUT_SERVER)
 
        if (NOT WITHOUT_CLIENT)
index dfd99ca..72a4f5c 100644 (file)
@@ -55,10 +55,8 @@ extern INT WSAAPI emulated_poll(LPWSAPOLLFD fdarray, ULONG nfds, INT timeout);
 \r
 /* windows can't cope with this idea, needs assets in cwd */\r
 \r
-#ifdef INSTALL_DATADIR\r
-#undef INSTALL_DATADIR\r
-#endif\r
-\r
+#ifndef INSTALL_DATADIR\r
 #define INSTALL_DATADIR "."\r
+#endif\r
 \r
 #endif\r