mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-25 10:09:36 +02:00 
			
		
		
		
	Merge pull request #1099 from Kampbell/AppVeyorWithCMake
AppVeyor with Cmake
This commit is contained in:
		
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -149,3 +149,4 @@ openssl/packages/ | |||||||
| !openssl/win64/lib/debug/*.pdb | !openssl/win64/lib/debug/*.pdb | ||||||
| !openssl/win64/lib/release/*.lib | !openssl/win64/lib/release/*.lib | ||||||
|  |  | ||||||
|  | /Debug | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								.travis.yml
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								.travis.yml
									
									
									
									
									
								
							| @@ -3,6 +3,11 @@ language: cpp | |||||||
| cache: | cache: | ||||||
|  - apt |  - apt | ||||||
|  |  | ||||||
|  | branches: | ||||||
|  |   except: | ||||||
|  |     - /*?pp?eyor*/ | ||||||
|  |  | ||||||
|  |  | ||||||
| before_install: | before_install: | ||||||
|   # we need a recent version of CMake |   # we need a recent version of CMake | ||||||
|   # - sudo add-apt-repository -y ppa:andykimpe/cmake3 |   # - sudo add-apt-repository -y ppa:andykimpe/cmake3 | ||||||
| @@ -40,9 +45,10 @@ matrix: | |||||||
|       compiler: clang |       compiler: clang | ||||||
|       os: osx |       os: osx | ||||||
|       script: |       script: | ||||||
|         - ./configure --everything --omit=Data/ODBC,Data/MySQL,Data/SQLite |         - ./configure --everything --omit=Data/ODBC,Data/MySQL,Data/SQLite && make -j2 | ||||||
|         - cat config.* |         - cat config.* | ||||||
|         - make install -j2 |         - sudo make install | ||||||
|  |         - ls -l /usr/local/lib/*Poco* | ||||||
|         - find . -name "*testrunner*" |         - find . -name "*testrunner*" | ||||||
|         - ./travis/runtests.sh |         - ./travis/runtests.sh | ||||||
|  |  | ||||||
| @@ -50,6 +56,7 @@ matrix: | |||||||
|       compiler: gcc |       compiler: gcc | ||||||
|       script: |       script: | ||||||
|         - ./configure --everything && make -s -j2 |         - ./configure --everything && make -s -j2 | ||||||
|  |         - sudo make install | ||||||
|         - ./travis/runtests.sh |         - ./travis/runtests.sh | ||||||
|      |      | ||||||
|     - env:    TEST_NAME="Linux gcc (make) unbundled" |     - env:    TEST_NAME="Linux gcc (make) unbundled" | ||||||
| @@ -57,12 +64,14 @@ matrix: | |||||||
|       script: |       script: | ||||||
|         - sudo apt-get install -qq -y libpcre3-dev libssl-dev libexpat1-dev |         - sudo apt-get install -qq -y libpcre3-dev libssl-dev libexpat1-dev | ||||||
|         - ./configure --everything --unbundled && make -s -j2 |         - ./configure --everything --unbundled && make -s -j2 | ||||||
|  |         - sudo make install | ||||||
|         - ./travis/runtests.sh |         - ./travis/runtests.sh | ||||||
|      |      | ||||||
|     - env:    TEST_NAME="Linux clang (make)" |     - env:    TEST_NAME="Linux clang (make)" | ||||||
|       compiler: clang |       compiler: clang | ||||||
|       script: |       script: | ||||||
|         - ./configure --everything --config=Linux-clang && make -s -j2 |         - ./configure --everything --config=Linux-clang && make -s -j2 | ||||||
|  |         - sudo make install | ||||||
|         - ./travis/runtests.sh |         - ./travis/runtests.sh | ||||||
|  |  | ||||||
|     - env:    TEST_NAME="Linux arm-linux-gnueabi- (make)" |     - env:    TEST_NAME="Linux arm-linux-gnueabi- (make)" | ||||||
|   | |||||||
| @@ -21,6 +21,6 @@ target_include_directories( "${LIBNAME}" | |||||||
|     PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/src |     PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/src | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_SAMPLES) | ||||||
|   add_subdirectory(samples) |   add_subdirectory(samples) | ||||||
| endif () | endif () | ||||||
| @@ -5,6 +5,7 @@ | |||||||
| # | # | ||||||
| # ENABLE_{COMPONENT} | # ENABLE_{COMPONENT} | ||||||
| # ENABLE_TESTS | # ENABLE_TESTS | ||||||
|  | # ENABLE_SAMPLES | ||||||
|  |  | ||||||
| cmake_minimum_required(VERSION 3.0.0) | cmake_minimum_required(VERSION 3.0.0) | ||||||
|  |  | ||||||
| @@ -81,7 +82,10 @@ option(ENABLE_REDIS "Enable Redis" ON) | |||||||
| option(FORCE_OPENSSL "Force usage of OpenSSL even under windows" OFF) | option(FORCE_OPENSSL "Force usage of OpenSSL even under windows" OFF) | ||||||
|  |  | ||||||
| option(ENABLE_TESTS | option(ENABLE_TESTS | ||||||
|   "Set to OFF|ON (default is OFF) to control build of POCO tests & samples" OFF) |   "Set to OFF|ON (default is OFF) to control build of POCO tests" OFF) | ||||||
|  |  | ||||||
|  | option(ENABLE_SAMPLES | ||||||
|  |   "Set to OFF|ON (default is OFF) to control build of POCO samples" OFF) | ||||||
|  |  | ||||||
| option(POCO_STATIC | option(POCO_STATIC | ||||||
|   "Set to OFF|ON (default is OFF) to control build of POCO as STATIC library" OFF) |   "Set to OFF|ON (default is OFF) to control build of POCO as STATIC library" OFF) | ||||||
| @@ -111,9 +115,15 @@ endif(POCO_STATIC) | |||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|   include(CTest) |   include(CTest) | ||||||
|   enable_testing() |   enable_testing() | ||||||
|   message(STATUS "Building with unittests & samples") |   message(STATUS "Building with tests") | ||||||
| else () | else () | ||||||
|   message(STATUS "Building without tests & samples") |   message(STATUS "Building without tests") | ||||||
|  | endif () | ||||||
|  |  | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |   message(STATUS "Building with samples") | ||||||
|  | else () | ||||||
|  |   message(STATUS "Building without samples") | ||||||
| endif () | endif () | ||||||
|  |  | ||||||
| if (POCO_UNBUNDLED) | if (POCO_UNBUNDLED) | ||||||
|   | |||||||
| @@ -43,10 +43,10 @@ void TextTestResult::setup() | |||||||
| 		std::string::const_iterator end = ignored.end(); | 		std::string::const_iterator end = ignored.end(); | ||||||
| 		while (it != end) | 		while (it != end) | ||||||
| 		{ | 		{ | ||||||
| 			while (it != end && (std::isspace(*it) || *it == '"')) ++it; | 			while (it != end && (std::isspace(*it) || *it == '"' || *it == '\'')) ++it; | ||||||
| 			std::string test; | 			std::string test; | ||||||
| 			while (it != end && *it != ',' && *it != '"') test += *it++; | 			while (it != end && *it != ',' && *it != '"' && *it != '\'') test += *it++; | ||||||
| 			if (it != end && (*it == ',' || *it == '"')) ++it; | 			if (it != end && (*it == ',' || *it == '"' || *it == '\'')) ++it; | ||||||
| 			if (!test.empty()) _ignored.insert(test); | 			if (!test.empty()) _ignored.insert(test); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -25,7 +25,9 @@ target_include_directories( "${LIBNAME}" | |||||||
|     PUBLIC |     PUBLIC | ||||||
|         $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include> |         $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include> | ||||||
|         $<INSTALL_INTERFACE:include> |         $<INSTALL_INTERFACE:include> | ||||||
|     PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/src |     PRIVATE  | ||||||
|  |     	${CMAKE_CURRENT_SOURCE_DIR}/src | ||||||
|  |     	${OPENSSL_INCLUDE_DIR} | ||||||
|     ) |     ) | ||||||
| target_compile_definitions("${LIBNAME}" PUBLIC ${LIB_MODE_DEFINITIONS}) | target_compile_definitions("${LIBNAME}" PUBLIC ${LIB_MODE_DEFINITIONS}) | ||||||
|  |  | ||||||
| @@ -33,6 +35,8 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ POCO_SOURCES_AUTO_PLAT( TEST_SRCS WINCE | |||||||
|  |  | ||||||
| add_executable( ${TESTUNIT} ${TEST_SRCS} ) | add_executable( ${TESTUNIT} ${TEST_SRCS} ) | ||||||
| add_test(NAME ${LIBNAME} WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR} COMMAND ${TESTUNIT} -all) | add_test(NAME ${LIBNAME} WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR} COMMAND ${TESTUNIT} -all) | ||||||
| target_link_libraries( ${TESTUNIT} PocoCrypto PocoNetSSL PocoXML PocoUtil PocoFoundation CppUnit ) | target_link_libraries( ${TESTUNIT} PocoCrypto PocoXML PocoUtil PocoFoundation CppUnit ) | ||||||
| if(UNIX) | if(UNIX) | ||||||
|     target_link_libraries( ${TESTUNIT} pthread) |     target_link_libraries( ${TESTUNIT} pthread) | ||||||
| endif(UNIX) | endif(UNIX) | ||||||
|   | |||||||
| @@ -73,6 +73,8 @@ if(ENABLE_DATA_ODBC) | |||||||
| endif(ENABLE_DATA_ODBC) | endif(ENABLE_DATA_ODBC) | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|   | |||||||
| @@ -174,7 +174,9 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
| 	add_subdirectory( samples ) |  | ||||||
| 	add_subdirectory( testsuite ) | 	add_subdirectory( testsuite ) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  | 	add_subdirectory( samples ) | ||||||
|  | endif () | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,7 +31,9 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,7 +31,9 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|  |  | ||||||
|   | |||||||
| @@ -40,7 +40,9 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,7 +31,9 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|  |  | ||||||
|   | |||||||
| @@ -307,7 +307,6 @@ void HTTPSClientSessionTest::testInterop() | |||||||
|  |  | ||||||
| void HTTPSClientSessionTest::testProxy() | void HTTPSClientSessionTest::testProxy() | ||||||
| { | { | ||||||
| 	try { |  | ||||||
| 	HTTPSTestServer srv; | 	HTTPSTestServer srv; | ||||||
| 	HTTPSClientSession s("secure.appinf.com"); | 	HTTPSClientSession s("secure.appinf.com"); | ||||||
| 	s.setProxy( | 	s.setProxy( | ||||||
| @@ -324,10 +323,6 @@ void HTTPSClientSessionTest::testProxy() | |||||||
| 	std::string str(ostr.str()); | 	std::string str(ostr.str()); | ||||||
| 	assert(str == "This is a test file for NetSSL.\n"); | 	assert(str == "This is a test file for NetSSL.\n"); | ||||||
| 	assert(cert.commonName() == "secure.appinf.com" || cert.commonName() == "*.appinf.com"); | 	assert(cert.commonName() == "secure.appinf.com" || cert.commonName() == "*.appinf.com"); | ||||||
| 	} |  | ||||||
| 	catch (Poco::Net::HTTPException e) { |  | ||||||
| 		std::cout << e.displayText() << std::endl; |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -480,7 +475,7 @@ CppUnit::Test* HTTPSClientSessionTest::suite() | |||||||
| 	CppUnit_addTest(pSuite, HTTPSClientSessionTest, testKeepAlive); | 	CppUnit_addTest(pSuite, HTTPSClientSessionTest, testKeepAlive); | ||||||
| 	CppUnit_addTest(pSuite, HTTPSClientSessionTest, testInterop); | 	CppUnit_addTest(pSuite, HTTPSClientSessionTest, testInterop); | ||||||
| #ifdef FIXME | #ifdef FIXME | ||||||
| 	should use a public proxy server | 	testProxy should use a public proxy server | ||||||
| 	http://www.publicproxyservers.com/proxy/list1.html | 	http://www.publicproxyservers.com/proxy/list1.html | ||||||
| 	Really working public proxy servers - page 1 of 6. | 	Really working public proxy servers - page 1 of 6. | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -85,7 +85,6 @@ void HTTPSStreamFactoryTest::testRedirect() | |||||||
|  |  | ||||||
| void HTTPSStreamFactoryTest::testProxy() | void HTTPSStreamFactoryTest::testProxy() | ||||||
| { | { | ||||||
| 	try { |  | ||||||
| 	HTTPSTestServer server; | 	HTTPSTestServer server; | ||||||
| 	HTTPSStreamFactory factory( | 	HTTPSStreamFactory factory( | ||||||
| 		Application::instance().config().getString("testsuite.proxy.host"), | 		Application::instance().config().getString("testsuite.proxy.host"), | ||||||
| @@ -96,10 +95,7 @@ void HTTPSStreamFactoryTest::testProxy() | |||||||
| 	std::ostringstream ostr; | 	std::ostringstream ostr; | ||||||
| 	StreamCopier::copyStream(*pStr.get(), ostr); | 	StreamCopier::copyStream(*pStr.get(), ostr); | ||||||
| 	assert(ostr.str().length() > 0); | 	assert(ostr.str().length() > 0); | ||||||
| 	} |  | ||||||
| 	catch (Poco::Net::HTTPException e) { |  | ||||||
| 		std::cout << e.displayText() << std::endl; |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -139,7 +135,7 @@ CppUnit::Test* HTTPSStreamFactoryTest::suite() | |||||||
| 	CppUnit_addTest(pSuite, HTTPSStreamFactoryTest, testEmptyPath); | 	CppUnit_addTest(pSuite, HTTPSStreamFactoryTest, testEmptyPath); | ||||||
| 	CppUnit_addTest(pSuite, HTTPSStreamFactoryTest, testRedirect); | 	CppUnit_addTest(pSuite, HTTPSStreamFactoryTest, testRedirect); | ||||||
| #ifdef FIXME | #ifdef FIXME | ||||||
| 	should use a public proxy server | 	testProxy should use a public proxy server | ||||||
| 	http://www.publicproxyservers.com/proxy/list1.html | 	http://www.publicproxyservers.com/proxy/list1.html | ||||||
| 	Really working public proxy servers - page 1 of 6. | 	Really working public proxy servers - page 1 of 6. | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -31,8 +31,21 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     #TODO: Looks like the samples use crypto somehow? | if (WIN32) | ||||||
|     #add_subdirectory(samples) | #   FIXME:  | ||||||
|     #add_subdirectory(testsuite) | #	add_subdirectory(testsuite) | ||||||
|  |     message(STATUS "############ FIXME: ${LIBNAME} add_subdirectory(testsuite)") | ||||||
|  | else () | ||||||
|  |     add_subdirectory(testsuite) | ||||||
|  | endif () | ||||||
|  | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  | if (WIN32) | ||||||
|  | #   FIXME: Looks like the samples use crypto somehow? | ||||||
|  | #   add_subdirectory(samples) | ||||||
|  |     message(STATUS "############ FIXME: ${LIBNAME} add_subdirectory(samples)") | ||||||
|  | else () | ||||||
|  |     add_subdirectory(testsuite) | ||||||
|  | endif () | ||||||
| endif () | endif () | ||||||
|  |  | ||||||
|   | |||||||
| @@ -314,7 +314,11 @@ void HTTPSClientSessionTest::testInterop() | |||||||
|  |  | ||||||
| void HTTPSClientSessionTest::testProxy() | void HTTPSClientSessionTest::testProxy() | ||||||
| { | { | ||||||
| 	try { | #ifdef FIXME | ||||||
|  | 	testProxy should use a public proxy server | ||||||
|  | 	http://www.publicproxyservers.com/proxy/list1.html | ||||||
|  | 	Really working public proxy servers - page 1 of 6. | ||||||
|  | #endif | ||||||
| 	HTTPSTestServer srv; | 	HTTPSTestServer srv; | ||||||
| 	HTTPSClientSession s("secure.appinf.com"); | 	HTTPSClientSession s("secure.appinf.com"); | ||||||
| 	s.setProxy( | 	s.setProxy( | ||||||
| @@ -331,10 +335,6 @@ void HTTPSClientSessionTest::testProxy() | |||||||
| 	std::string str(ostr.str()); | 	std::string str(ostr.str()); | ||||||
| 	assert(str == "This is a test file for NetSSL.\n"); | 	assert(str == "This is a test file for NetSSL.\n"); | ||||||
| 	assert(cert.commonName() == "secure.appinf.com" || cert.commonName() == "*.appinf.com"); | 	assert(cert.commonName() == "secure.appinf.com" || cert.commonName() == "*.appinf.com"); | ||||||
| 	} |  | ||||||
| 	catch (Poco::Exception e) { |  | ||||||
| 		std::cout << e.displayText() << std::endl; |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -85,7 +85,11 @@ void HTTPSStreamFactoryTest::testRedirect() | |||||||
|  |  | ||||||
| void HTTPSStreamFactoryTest::testProxy() | void HTTPSStreamFactoryTest::testProxy() | ||||||
| { | { | ||||||
| 	try { | #ifdef FIXME | ||||||
|  | 	testProxy should use a public proxy server | ||||||
|  | 	http://www.publicproxyservers.com/proxy/list1.html | ||||||
|  | 	Really working public proxy servers - page 1 of 6. | ||||||
|  | #endif | ||||||
| 	HTTPSTestServer server; | 	HTTPSTestServer server; | ||||||
| 	HTTPSStreamFactory factory( | 	HTTPSStreamFactory factory( | ||||||
| 		Application::instance().config().getString("testsuite.proxy.host"), | 		Application::instance().config().getString("testsuite.proxy.host"), | ||||||
| @@ -96,10 +100,6 @@ void HTTPSStreamFactoryTest::testProxy() | |||||||
| 	std::ostringstream ostr; | 	std::ostringstream ostr; | ||||||
| 	StreamCopier::copyStream(*pStr.get(), ostr); | 	StreamCopier::copyStream(*pStr.get(), ostr); | ||||||
| 	assert(ostr.str().length() > 0); | 	assert(ostr.str().length() > 0); | ||||||
| 	} |  | ||||||
| 	catch (Poco::Exception e) { |  | ||||||
| 		std::cout << e.displayText() << std::endl; |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -136,7 +136,9 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|  |  | ||||||
|   | |||||||
| @@ -19,3 +19,7 @@ install( | |||||||
|     RUNTIME DESTINATION bin |     RUNTIME DESTINATION bin | ||||||
|     INCLUDES DESTINATION include |     INCLUDES DESTINATION include | ||||||
|     ) |     ) | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  | #    add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|  |      | ||||||
| @@ -31,7 +31,9 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
| #    add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  | #    add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|  |  | ||||||
|   | |||||||
| @@ -72,8 +72,10 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     # TODO: Add tests |     # TODO: Add tests | ||||||
|     #add_subdirectory(testsuite) |     #add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|  |  | ||||||
|   | |||||||
| @@ -48,6 +48,8 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|   | |||||||
| @@ -54,7 +54,9 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,7 +31,9 @@ POCO_INSTALL("${LIBNAME}") | |||||||
| POCO_GENERATE_PACKAGE("${LIBNAME}") | POCO_GENERATE_PACKAGE("${LIBNAME}") | ||||||
|  |  | ||||||
| if (ENABLE_TESTS) | if (ENABLE_TESTS) | ||||||
|     add_subdirectory(samples) |  | ||||||
|     add_subdirectory(testsuite) |     add_subdirectory(testsuite) | ||||||
| endif () | endif () | ||||||
|  | if (ENABLE_SAMPLES) | ||||||
|  |     add_subdirectory(samples) | ||||||
|  | endif () | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										398
									
								
								appveyor.yml
									
									
									
									
									
								
							
							
						
						
									
										398
									
								
								appveyor.yml
									
									
									
									
									
								
							| @@ -2,105 +2,202 @@ version: poco-1.7.0 {branch}-{build} | |||||||
|  |  | ||||||
| cache: | cache: | ||||||
|   - c:\mysql-5.7.9-win32 |   - c:\mysql-5.7.9-win32 | ||||||
|  |   - C:\ProgramData\chocolatey | ||||||
|  |   - C:\OpenSSL-Win32 | ||||||
|  |   - C:\OpenSSL-Win64 | ||||||
|    |    | ||||||
| hosts: | hosts: | ||||||
|   localhost: 127.0.0.1 |   localhost: 127.0.0.1 | ||||||
|   db.server.com: 127.0.0.2 |   db.server.com: 127.0.0.2 | ||||||
|    |    | ||||||
| services: | services: | ||||||
|  | # mysql : server: localhost, port: 3306 | ||||||
|  | # mysql : user  : root, password: Password12! | ||||||
| #  - mysql | #  - mysql | ||||||
|  |  | ||||||
|  | # mongodb config  : C:\mongodb\mongod.cfg | ||||||
|  | # mongodb database: C:\mongodb\data\db | ||||||
|   - mongodb |   - mongodb | ||||||
|  |  | ||||||
| platform: | platform: | ||||||
|   - Win32 |   - Win32 | ||||||
|   - x64 |   - x64 | ||||||
|    |    | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  | # building debug configuration doubles the round time and isn't so useful. | ||||||
|  | # tests are run only in release & shared. | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
| configuration: | configuration: | ||||||
|   - release |   - release | ||||||
|   - debug | #  - debug | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
| install: |  | ||||||
|   - systeminfo |  | ||||||
|   - c:\cygwin\bin\uname -a |  | ||||||
|   - c:\cygwin\bin\cat /proc/cpuinfo |  | ||||||
|   - c:\cygwin\bin\cat /proc/meminfo |  | ||||||
|   - set |  | ||||||
|  |  | ||||||
| #  MySQL 32 bit is not available by default on AppVeyor |  | ||||||
|   - ps: | |  | ||||||
|         if ($env:platform -eq "Win32") |  | ||||||
|         { |  | ||||||
|             if (Test-Path "c:\mysql-5.7.9-win32") { |  | ||||||
|                 echo "using mysql-5.7.9-win32 from cache" |  | ||||||
|             } |  | ||||||
|             else |  | ||||||
|             { |  | ||||||
|                 echo "downloading mysql-5.7.9-win32" |  | ||||||
|                 Invoke-WebRequest "http://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.9-win32.zip" -OutFile mysql-5.7.9-win32.zip |  | ||||||
|                 echo "installing mysql-5.7.9-win32" |  | ||||||
|                 7z x -y mysql-5.7.9-win32.zip -oc:\ |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
| environment: | environment: | ||||||
|   bundling: bundled |   bundling: bundled | ||||||
|   logger: 'C:\Progra~1\AppVeyor\BuildAgent\Appveyor.MSBuildLogger.dll' |  | ||||||
|   samples: samples |  | ||||||
|   tests: tests |  | ||||||
|   verbosity: minimal |  | ||||||
|  |  | ||||||
|   matrix: |   matrix: | ||||||
|     - builder: 120 |  | ||||||
|  |     - builder: cmake | ||||||
|  |       vsver: 120 | ||||||
|  |  | ||||||
|  |     - builder: msbuild | ||||||
|  |       vsver: 120 | ||||||
|       linkmode: shared |       linkmode: shared | ||||||
|  |  | ||||||
| #    - builder: 120 |     - builder: msbuild | ||||||
|  |       vsver: 120 | ||||||
|  |       linkmode: static_md | ||||||
|  |  | ||||||
|  |     - builder: msbuild | ||||||
|  |       vsver: 120 | ||||||
|  |       linkmode: static_mt | ||||||
|  |  | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  | # VS2013 runs a x64 or Win32 build & tests in around 32 mn | ||||||
|  | # Environment: builder=msbuild, vsver=120, linkmode=shared; Platform: Win32    31 min 33 sec | ||||||
|  | # Environment: builder=msbuild, vsver=120, linkmode=shared; Platform: x64      33 min 32 sec | ||||||
|  | # | ||||||
|  | # In VS2015 running either a x64 or Win32 build & tests takes twice time and thus makes the build failed since | ||||||
|  | # it overpasses 1 hour and free Appveyor account job are limited to 1 hour. Thus VS2015 builds  | ||||||
|  | # are removed until one finds out the reason why build time is doubled. | ||||||
|  | # | ||||||
|  | # Environment: builder=msbuild, vsver=140, linkmode=shared; Platform: Win32     1 hr | ||||||
|  | # Environment: builder=msbuild, vsver=140, linkmode=shared; Platform: x64       1 hr  | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  | #    - builder: msbuild | ||||||
|  | #      vsver: 140 | ||||||
|  | #      linkmode: shared | ||||||
|  |  | ||||||
|  | #    - builder: msbuild | ||||||
|  | #      vsver: 140 | ||||||
| #      linkmode: static_md | #      linkmode: static_md | ||||||
|  |  | ||||||
| #    - builder: 120 | #    - builder: msbuild | ||||||
| #      linkmode: static_mt | #      vsver: 140 | ||||||
|  |  | ||||||
|     - builder: 140 |  | ||||||
|       linkmode: shared |  | ||||||
|  |  | ||||||
| #    - builder: 140 |  | ||||||
| #      linkmode: static_md |  | ||||||
|  |  | ||||||
| #    - builder: 140 |  | ||||||
| #      linkmode: static_mt | #      linkmode: static_mt | ||||||
|  |  | ||||||
|  |  | ||||||
| matrix: | matrix: | ||||||
|   fast_finish: true |   fast_finish: true | ||||||
|  |  | ||||||
|  | install: | ||||||
|  |   - set PATH=C:\ProgramData\chocolatey\bin;%PATH% | ||||||
|  |   - systeminfo | ||||||
|  |   - c:\cygwin\bin\uname -a | ||||||
|  |   - c:\cygwin\bin\cat /proc/cpuinfo | ||||||
|  |   - c:\cygwin\bin\cat /proc/meminfo | ||||||
|  |   - ps: | | ||||||
|  |         if ($env:builder -eq "cmake") | ||||||
|  |         { | ||||||
|  |           if (Test-Path "$env:ChocolateyInstall\bin\jom.exe") { | ||||||
|  |               echo "using jom from cache" | ||||||
|  |           } else { | ||||||
|  |               choco install jom | ||||||
|  |           } | ||||||
|  |           if (Test-Path "$env:ChocolateyInstall\bin\cmake.exe") { | ||||||
|  |             echo "using cmake from cache" | ||||||
|  |           } else { | ||||||
|  |             choco install cmake | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |   - set | ||||||
|  |  | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  | #  chocolatey brokes jom, here's workaround | ||||||
|  | #  see https://github.com/jcfr/qt-easy-build/commit/6366f4275562bdaf4f686838600f46894579c41e) | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  |   - ps: | | ||||||
|  |       if ($env:builder -eq "cmake") | ||||||
|  |       { | ||||||
|  |         $env:PATH = $env:ChocolateyInstall + "\bin" + ";" + $env:PATH | ||||||
|  |         $env:PATH = $env:ChocolateyInstall + "\lib\jom\content" + ";" + $env:PATH | ||||||
|  |       } | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  | # OpenSSL-Win32 & OpenSSL-Win64 | ||||||
|  | # Download & use OpenSSL from  Shining Light Productions for CMake | ||||||
|  | # until CMake use implicitly the embedded openssl from the Poco repo. See issue #1093 | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  |   - ps: | | ||||||
|  |        if ($env:builder -eq "cmake") | ||||||
|  |        { | ||||||
|  |          if ($env:platform -eq "Win32") | ||||||
|  |          { | ||||||
|  |            if (Test-Path "C:\OpenSSL-Win32") { | ||||||
|  |              echo "using C:\OpenSSL-Win32 from cache" | ||||||
|  |            } else { | ||||||
|  |              echo "downloading OpenSSL-Win32" | ||||||
|  |              Start-FileDownload 'http://slproweb.com/download/Win32OpenSSL-1_0_2e.exe' | ||||||
|  |              echo "installing C:\OpenSSL-Win32" | ||||||
|  |              Start-Process "Win32OpenSSL-1_0_2e.exe" -Args "/silent /verysilent /sp- /suppressmsgboxes" -Wait | ||||||
|  |            } | ||||||
|  |          } | ||||||
|  |          if ($env:platform -eq "x64") | ||||||
|  |          { | ||||||
|  |            if (Test-Path "C:\OpenSSL-Win64") { | ||||||
|  |              echo "using C:\OpenSSL-Win64 from cache" | ||||||
|  |            } else { | ||||||
|  |              echo "downloading OpenSSL-Win64" | ||||||
|  |              Start-FileDownload 'http://slproweb.com/download/Win64OpenSSL-1_0_2e.exe' | ||||||
|  |              echo "installing C:\OpenSSL-Win64" | ||||||
|  |              Start-Process "Win64OpenSSL-1_0_2e.exe" -Args "/silent /verysilent /sp- /suppressmsgboxes" -Wait | ||||||
|  |            } | ||||||
|  |          } | ||||||
|  |        } | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  |     | ||||||
|  | #  MySQL 32 bit is not available by default on AppVeyor | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  |   - ps: | | ||||||
|  |         if ($env:platform -eq "Win32") | ||||||
|  |         { | ||||||
|  |             if (Test-Path "c:\mysql-5.7.9-win32") { | ||||||
|  |                 echo "using c:\mysql-5.7.9-win32 from cache" | ||||||
|  |             } | ||||||
|  |             else | ||||||
|  |             { | ||||||
|  |                 echo "downloading mysql-5.7.9-win32" | ||||||
|  |                 Invoke-WebRequest "http://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.9-win32.zip" -OutFile mysql-5.7.9-win32.zip | ||||||
|  |                 echo "installing c:\mysql-5.7.9-win32" | ||||||
|  |                 7z x -y mysql-5.7.9-win32.zip -oc:\ | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  # ------------------------------------------------------------------------------------------- | ||||||
|     |     | ||||||
| before_build: | before_build: | ||||||
|  |   - set POCO_BASE=%CD% | ||||||
|   - ps: | |   - ps: | | ||||||
|       if ($env:builder -eq "120") |         if ($env:vsver -eq "110") | ||||||
|         { |         { | ||||||
|           if ($env:platform -eq "Win32") |           $vspath= convert-path $env:VS110COMNTOOLS\..\..\VC\bin; $yyyy='2010' | ||||||
|           { |           if($env:platform -eq 'Win32') { $vctool='';} | ||||||
|             & "C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\vcvarsall.bat" x86 |           if($env:platform -eq 'x64')   { $vctool='x86_amd64';$vspath+='\'+$vctool } | ||||||
|             $env:suffix = "" |  | ||||||
|         } |         } | ||||||
|           if ($env:platform -eq "x64") |         if ($env:vsver -eq "120") | ||||||
|         { |         { | ||||||
|             & "C:\Program Files (x86)\Microsoft Visual Studio 12.0\VC\vcvarsall.bat" x86_amd64 |           $vspath= convert-path $env:VS120COMNTOOLS\..\..\VC\bin;$yyyy='2013' | ||||||
|             $env:suffix = 64 |           if($env:platform -eq 'Win32') { $vctool='';} | ||||||
|           } |           if($env:platform -eq 'x64')   { $vctool='x86_amd64';$vspath+='\'+$vctool } | ||||||
|       } |            | ||||||
|       if ($env:builder -eq "140") |         } | ||||||
|       { |         if ($env:vsver -eq "140") | ||||||
|           if ($env:platform -eq "Win32") |         { | ||||||
|           { |           $vspath= convert-path $env:VS140COMNTOOLS\..\..\VC\bin; $yyyy='2015' | ||||||
|             & "C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\vcvarsall.bat" x86 |           if($env:platform -eq 'Win32') { $vctool='';} | ||||||
|             $env:suffix = "" |           if($env:platform -eq 'x64')   { $vctool='x86_amd64';$vspath+='\'+$vctool } | ||||||
|           } |         } | ||||||
|           if ($env:platform -eq "x64") |         pushd $vspath; | ||||||
|           { |         $tool= if($vctool -eq '') {'32'} else {$vctool} | ||||||
|             & "C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\vcvarsall.bat" x86_amd64 |         cmd /c "vcvars$tool.bat&set" | | ||||||
|             $env:suffix = 64 |         foreach { | ||||||
|  |           if ($_ -match "=") { | ||||||
|  |             $v = $_.split("="); set-item -force -path "ENV:\$($v[0])"  -value "$($v[1])" | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|  |         popd | ||||||
|  |         write-host "`nVisual Studio $yyyy CLI variables set." -ForegroundColor Yellow | ||||||
|    |    | ||||||
| # MySQL | # MySQL | ||||||
|   - ps: | |   - ps: | | ||||||
| @@ -119,104 +216,193 @@ after_build: | |||||||
|   - ps: | |   - ps: | | ||||||
|       $line='-------------------------------------------------------------------------------------'; |       $line='-------------------------------------------------------------------------------------'; | ||||||
|       $find='c:\cygwin\bin\find.exe'; |       $find='c:\cygwin\bin\find.exe'; | ||||||
|       $arg1=". -type f -name '*.cpp' -exec c:\cygwin\bin\grep -n -H "; |       $arg1="$env:POCO_BASE -type f -name '*.cpp' -exec c:\cygwin\bin\grep -n -H "; | ||||||
|       $arg2=" {} ;" |       $arg2=" {} ;" | ||||||
|        |        | ||||||
|       Write-Host -ForegroundColor Yellow $line; |  | ||||||
|       $word='FIXME' |       $word='FIXME' | ||||||
|       Start-Process -NoNewWindow -Wait -FilePath $find -Args "$arg1 $word $arg2" -RSO "cout" -RSE "cerr";  |       Write-Host -ForegroundColor Yellow $word; | ||||||
|  |       Write-Host -ForegroundColor Yellow $line; | ||||||
|  |       Start-Process -nnw -Wait -FilePath $find -Args "$arg1 $word $arg2" -RSO cout -RSE cerr;  | ||||||
|       gc cout; gc cerr; |       gc cout; gc cerr; | ||||||
|  |       Write-Host -ForegroundColor Yellow $line; | ||||||
|       Write-Host;Write-Host; |       Write-Host;Write-Host; | ||||||
|  |  | ||||||
|       Write-Host -ForegroundColor Yellow $line; |  | ||||||
|       $word='TODO' |       $word='TODO' | ||||||
|       Start-Process -NoNewWindow -Wait -FilePath $find -Args "$arg1 $word $arg2" -RSO "cout" -RSE "cerr";  |       Write-Host -ForegroundColor Yellow $word; | ||||||
|  |       Write-Host -ForegroundColor Yellow $line; | ||||||
|  |       Start-Process -nnw -Wait -FilePath $find -Args "$arg1 $word $arg2" -RSO cout -RSE cerr;  | ||||||
|       gc cout; gc cerr; |       gc cout; gc cerr; | ||||||
|  |       Write-Host -ForegroundColor Yellow $line; | ||||||
|       Write-Host;Write-Host; |       Write-Host;Write-Host; | ||||||
|  |  | ||||||
|       Write-Host -ForegroundColor Yellow $line; |  | ||||||
|       $word='HACK' |       $word='HACK' | ||||||
|       Start-Process -NoNewWindow -Wait -FilePath $find -Args "$arg1 $word $arg2" -RSO "cout" -RSE "cerr";  |       Write-Host -ForegroundColor Yellow $word; | ||||||
|  |       Write-Host -ForegroundColor Yellow $line; | ||||||
|  |       Start-Process -nnw -Wait -FilePath $find -Args "$arg1 $word $arg2" -RSO cout -RSE cerr;  | ||||||
|       gc cout; gc cerr; |       gc cout; gc cerr; | ||||||
|  |       Write-Host -ForegroundColor Yellow $line; | ||||||
|       Write-Host;Write-Host; |       Write-Host;Write-Host; | ||||||
|  |  | ||||||
|  |  | ||||||
| build_script: | build_script: | ||||||
|   - buildwin %builder% build %linkmode% %configuration% %platform% %samples% %tests% msbuild %verbosity% %logger% | # ------------------------------------------------------------------------------------------- | ||||||
|  | # When building with cmake, it remains one exception reported below | ||||||
|  | # Once this problem be fixed, a fix from Microsoft about mc.exe outputing informative  | ||||||
|  | # message on stderr: https://connect.microsoft.com/VisualStudio/Feedback/Details/2161572 | ||||||
|  | # the try/catch around the cmake builder can be removed | ||||||
|  | # | ||||||
|  | # [  1%] Generating pocomsg.h | ||||||
|  | # cmake : MC: Compiling C:/projects/poco/Foundation/src/pocomsg.mc | ||||||
|  | # At line:16 char:3 | ||||||
|  | # +   cmake --build . --config $env:configuration | ||||||
|  | # +   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  | #     + CategoryInfo          : NotSpecified: (MC: Compiling C.../src/pocomsg.mc:String) [], RemoteException | ||||||
|  | #     + FullyQualifiedErrorId : NativeCommandError   | ||||||
|  | # | ||||||
|  | # Command executed with exception: MC: Compiling C:/projects/poco/Foundation/src/pocomsg.mc | ||||||
|  | # ------------------------------------------------------------------------------------------- | ||||||
|  |   - ps: | | ||||||
|  |       if ($env:builder -eq "msbuild") | ||||||
|  |       { | ||||||
|  |         $logger='"C:\Program Files\AppVeyor\BuildAgent\Appveyor.MSBuildLogger.dll"'; | ||||||
|  |         $verbosity='minimal'; | ||||||
|      |      | ||||||
|  |         $process = Start-Process -PassThru -nnw -Wait -FilePath "$env:poco_base\buildwin.cmd" -RSO cout -RSE cerr ` | ||||||
|  |         -Args "$env:vsver build $env:linkmode $env:configuration $env:platform samples tests msbuild $verbosity $logger"; | ||||||
|  |         gc cout; gc cerr; | ||||||
|  |         Write-Host -ForegroundColor Yellow '>>> current directory is '  $(get-location).Path; | ||||||
|  |       } | ||||||
|  |       if ($env:builder -eq "cmake") | ||||||
|  |       { | ||||||
|  |         mkdir cmake-build | out-null;pushd cmake-build; | ||||||
|  |         if ($env:platform -eq "Win32") | ||||||
|  |         { | ||||||
|  |             $opensslrootdir = 'C:\OpenSSL-Win32' | ||||||
|  |         } | ||||||
|  |         if ($env:platform -eq "x64") | ||||||
|  |         { | ||||||
|  |             $opensslrootdir = 'C:\OpenSSL-Win64' | ||||||
|  |         } | ||||||
|  |         $defs =' -G"NMake Makefiles"'; | ||||||
|  |         $defs+=" -DCMAKE_BUILD_TYPE=$env:configuration"; | ||||||
|  |         $defs+=" -DOPENSSL_ROOT_DIR=$opensslrootdir"; | ||||||
|  |         $defs+=" -DENABLE_NETSSL=OFF"; | ||||||
|  |         $defs+=" -DENABLE_NETSSL_WIN=ON"; | ||||||
|  |         $defs+=" -DENABLE_DATA_MYSQL=OFF"; | ||||||
|  |         $defs+=" -DENABLE_REDIS=OFF"; | ||||||
|  |         $defs+=" -DENABLE_SAMPLES=ON"; | ||||||
|  |         $defs+=" -DENABLE_TESTS=ON"; | ||||||
|  |         $defs+=" .."; | ||||||
|  |         Write-Host -ForegroundColor Yellow cmake $defs | ||||||
|  |         $process = Start-Process -PassThru -nnw -Wait -FilePath "cmake" -RSO cout -RSE cerr -Args $defs; | ||||||
|  |         gc cout; gc cerr; | ||||||
|  |         try { | ||||||
|  |           $ErrorActionPreference = 'Continue'; | ||||||
|  |           Write-Host -ForegroundColor Yellow cmake `-`-build .  | ||||||
|  |           cmake `-`-build .  | ||||||
|  |         } catch { | ||||||
|  |           Write-Warning "Oops: $_" | ||||||
|  |         } | ||||||
|  |         popd | ||||||
|  |         Write-Host -ForegroundColor Yellow '>>> current directory is '  $(get-location).Path; | ||||||
|  |         $ErrorActionPreference = 'Stop'; | ||||||
|  |       } | ||||||
|  |  | ||||||
| before_test: | before_test: | ||||||
|   - set PATH=%CD%\bin;%PATH% |   - ps: | | ||||||
|   - set PATH=%CD%\bin64;%PATH% |       $line='-------------------------------------------------------------------------------------'; | ||||||
|   - set CPPUNIT_IGNORE="class CppUnit::TestCaller<class NTPClientTest>.testTimeSync" |       $CPPUNIT_IGNORE=''; | ||||||
|   - set POCO_BASE=%CD% |       $CPPUNIT_IGNORE+='class CppUnit::TestCaller<class NTPClientTest>.testTimeSync'; | ||||||
|  |       $CPPUNIT_IGNORE+=', class CppUnit::TestCaller<class RawSocketTest>.testEchoIPv4'; | ||||||
|  |       $CPPUNIT_IGNORE+=', class CppUnit::TestCaller<class RawSocketTest>.testSendToReceiveFromIPv4'; | ||||||
|  |       $CPPUNIT_IGNORE+=', class CppUnit::TestCaller<class ICMPClientTest>.testPing'; | ||||||
|  |       $CPPUNIT_IGNORE+=', class CppUnit::TestCaller<class HTTPSClientSessionTest>.testProxy'; | ||||||
|  |       $CPPUNIT_IGNORE+=', class CppUnit::TestCaller<class HTTPSStreamFactoryTest>.testProxy'; | ||||||
|  |       set-item -force -path "ENV:CPPUNIT_IGNORE"  -value $CPPUNIT_IGNORE | ||||||
|  |       Write-Host -ForegroundColor Yellow 'CPPUNIT_IGNORE' | ||||||
|  |       Write-Host -ForegroundColor Yellow $line; | ||||||
|  |       foreach($t in $CPPUNIT_IGNORE.split(",")) { Write-Host -ForegroundColor Yellow $t.trim() }       | ||||||
|  |       Write-Host -ForegroundColor Yellow $line; | ||||||
|        |        | ||||||
| after_test: | after_test: | ||||||
|  |  | ||||||
| test_script: | test_script: | ||||||
|   - ps: | |   - ps: | | ||||||
|    |  | ||||||
|       $excluded   = @('Data', 'Data/MySQL', 'Data/ODBC','Redis', 'PDF')  |  | ||||||
|        |  | ||||||
|       $runs=0;$fails=0;$failedTests='';$status=0;$tab="`t"; |       $runs=0;$fails=0;$failedTests='';$status=0;$tab="`t"; | ||||||
|       $line='-------------------------------------------------------------------------------------'; |       $line='-------------------------------------------------------------------------------------'; | ||||||
|       $components = gc components; |       if ($env:configuration -eq "release") | ||||||
|  |       { | ||||||
|  |         if ($env:builder -eq "msbuild" -and $env:linkmode -eq "shared") | ||||||
|  |         { | ||||||
|  |           $suffix = ''; | ||||||
|  |           if ($env:platform -eq "Win32") | ||||||
|  |           { | ||||||
|  |             $env:PATH = "$env:POCO_BASE\bin;" + $env:PATH;$suffix = ''; | ||||||
|  |           } | ||||||
|  |           if ($env:platform -eq "x64") | ||||||
|  |           { | ||||||
|  |             $env:PATH = "$env:POCO_BASE\bin64;" + $env:PATH;$suffix = 64; | ||||||
|  |           } | ||||||
|  |  | ||||||
|  |           Write-Host -ForegroundColor Yellow '>>> current directory is '  $(get-location).Path; | ||||||
|  |  | ||||||
|  |           $components = gc $env:poco_base\components; | ||||||
|           Write-Host components; |           Write-Host components; | ||||||
|           Write-Host -ForegroundColor Yellow $line; |           Write-Host -ForegroundColor Yellow $line; | ||||||
|           $components; |           $components; | ||||||
|           Write-Host -ForegroundColor Yellow $line; |           Write-Host -ForegroundColor Yellow $line; | ||||||
|  |   | ||||||
|  |           $excluded   = @('Data', 'Data/MySQL', 'Data/ODBC','Redis', 'PDF') | ||||||
|  |            | ||||||
|           Write-Host excluded; |           Write-Host excluded; | ||||||
|           Write-Host -ForegroundColor Yellow $line; |           Write-Host -ForegroundColor Yellow $line; | ||||||
|           $excluded |           $excluded | ||||||
|           Write-Host -ForegroundColor Yellow $line; |           Write-Host -ForegroundColor Yellow $line; | ||||||
|            |            | ||||||
|       if ($env:configuration -eq "release") |  | ||||||
|       { |  | ||||||
|         $suffix = ''; |  | ||||||
|         if ($env:platform -eq "Win32") |  | ||||||
|         { |  | ||||||
|           $env:PATH = "$env:CD\bin;" + $env:PATH;$suffix = ''; |  | ||||||
|         } |  | ||||||
|         if ($env:platform -eq "x64") |  | ||||||
|         { |  | ||||||
|           $env:PATH = "$env:CD\bin64;" + $env:PATH;$suffix = 64; |  | ||||||
|         } |  | ||||||
|           foreach ($component in $components) {  |           foreach ($component in $components) {  | ||||||
|           if ($excluded -notcontains $component) |             if ($excluded -notcontains $component) { | ||||||
|           { |               $path = "$env:poco_base\" + $component + "\testsuite\bin$suffix\TestSuite.exe"; | ||||||
|             [string]$path = $component + "\testsuite\bin$suffix\TestSuite.exe"; |  | ||||||
|  |  | ||||||
|               if (Test-Path -Path $path) { |               if (Test-Path -Path $path) { | ||||||
|                 $runs += 1; |                 $runs += 1; | ||||||
|                 Add-AppveyorTest -Framework 'CppUnit' -Name $component -Outcome  'Running' |                 Add-AppveyorTest -Framework 'CppUnit' -Name $component -Outcome  'Running' | ||||||
|  |  | ||||||
|                 Write-Host -ForegroundColor Yellow $line;  |                 Write-Host -ForegroundColor Yellow $line;  | ||||||
|                 Write-Host -ForegroundColor Yellow '|' $env:APPVEYOR_BUILD_VERSION $env:vs$builder $env:Platform $env:Configuration $env:linkmode '|' $tab $tab $component;  |                 Write-Host -ForegroundColor Yellow '|' $env:APPVEYOR_BUILD_VERSION $env:vs$vsver $env:Platform $env:Configuration $env:linkmode '|' $tab $tab $component;  | ||||||
|                 Write-Host -ForegroundColor Yellow $line;  |                 Write-Host -ForegroundColor Yellow $line;  | ||||||
|  |  | ||||||
|                 $started = Get-Date |                 $started = Get-Date | ||||||
|                 $process = Start-Process -PassThru -NoNewWindow -Wait -FilePath "$path" -Args "-all" -RSO "cout" -RSE "cerr"; |                 $process = Start-Process -PassThru -nnw -Wait -FilePath "$path" -Args "-all" -RSO cout -RSE cerr; | ||||||
|                 $ended   = Get-Date |                 $ended   = Get-Date | ||||||
|                 $millisec = ($ended - $started).ticks |                 $millisec = ($ended - $started).totalmilliseconds | ||||||
|                   |                   | ||||||
|                 gc cout; gc cerr; |                 gc cout; gc cerr; | ||||||
|  |  | ||||||
|                 if ($process.ExitCode -gt 0) |                 if ($process.ExitCode -gt 0) { | ||||||
|                 { |  | ||||||
|                   $fails += 1;$failedTests += $component + ', '; |                   $fails += 1;$failedTests += $component + ', '; | ||||||
|                   Add-AppveyorTest -Framework 'CppUnit' -Name $component -Outcome  'Failed' -Duration $millisec |                   Add-AppveyorTest -Framework 'CppUnit' -Name $component -Outcome  'Failed' -Duration $millisec | ||||||
|                 } |                 } else { | ||||||
|                 else |  | ||||||
|                 { |  | ||||||
|                   Add-AppveyorTest -Framework 'CppUnit' -Name $component -Outcome  'Passed' -Duration $millisec |                   Add-AppveyorTest -Framework 'CppUnit' -Name $component -Outcome  'Passed' -Duration $millisec | ||||||
|                 } |                 } | ||||||
|  |               } else { | ||||||
|  |                  Add-AppveyorTest -Framework 'CppUnit' -Name $component -Outcome   'NotFound' | ||||||
|               } |               } | ||||||
|           } |             } else { | ||||||
|           else |  | ||||||
|           { |  | ||||||
|               Add-AppveyorTest -Framework 'CppUnit' -Name $component -Outcome  'Skipped' |               Add-AppveyorTest -Framework 'CppUnit' -Name $component -Outcome  'Skipped' | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|  |         }   | ||||||
|  |         if ($env:builder -eq "cmake" -and $env:platform -eq "Win32") | ||||||
|  |         { | ||||||
|  |           pushd cmake-build; | ||||||
|  |           Write-Host -ForegroundColor Yellow $line; | ||||||
|  |           ctest -N | ||||||
|  |           Write-Host -ForegroundColor Yellow $line; | ||||||
|  |  | ||||||
|  |           Write-Host -ForegroundColor Yellow 'ctest -VV -E Data*' | ||||||
|  |           ctest -VV -E Data* | ||||||
|  |           popd | ||||||
|  |         } | ||||||
|         Write-Host $runs' runs, ' $fails' fails' |         Write-Host $runs' runs, ' $fails' fails' | ||||||
|         if ($fails -gt 0) |         if ($fails -gt 0) | ||||||
|         { |         { | ||||||
| @@ -243,14 +429,6 @@ notifications: | |||||||
|     on_build_failure: false |     on_build_failure: false | ||||||
|     on_build_status_changed: false |     on_build_status_changed: false | ||||||
|     |     | ||||||
|        |  | ||||||
|   - provider: Slack |  | ||||||
|     auth_token: |  | ||||||
|       secure: xoOlP1UHshqjvh/INwMcNhZ5UHsTVKLGY5maTSjaxDc0fvRwoWIdYvY/CofQEuy2wOIBQK4eLD+tA0xG78ZgqQ== |  | ||||||
|     channel: poco |  | ||||||
|     on_build_success: false |  | ||||||
|     on_build_status_changed: true |  | ||||||
|    |  | ||||||
|   - provider: Slack |   - provider: Slack | ||||||
|     incoming_webhook: https://hooks.slack.com/services/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 |     incoming_webhook: https://hooks.slack.com/services/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 | ||||||
|     auth_token: |     auth_token: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Günter Obiltschnig
					Günter Obiltschnig