From cbf436621e2343d4c769258d0d74daebe3c5ac74 Mon Sep 17 00:00:00 2001
From: gcontini <1121667+gcontini@users.noreply.github.com>
Date: 周日, 13 10月 2019 19:44:07 +0800
Subject: [PATCH] fix test windows

---
 test/library/LicenseLocator_test.cpp |   85 +++++++++++++++++++++++++-----------------
 1 files changed, 51 insertions(+), 34 deletions(-)

diff --git a/test/library/LicenseLocator_test.cpp b/test/library/LicenseLocator_test.cpp
index 512ffb1..ce966fe 100644
--- a/test/library/LicenseLocator_test.cpp
+++ b/test/library/LicenseLocator_test.cpp
@@ -7,6 +7,8 @@
 #include <string>
 #include <vector>
 
+#include <boost/filesystem.hpp>
+#include <boost/optional.hpp>
 #include <boost/test/unit_test.hpp>
 #include <stdlib.h>
 #include <cstdio>
@@ -22,51 +24,66 @@
 namespace test {
 using namespace license::locate;
 using namespace std;
+using namespace boost::filesystem;
+
+static boost::optional<path> find_file(const path& dir_path, const path& file_name) {
+	const recursive_directory_iterator end;
+	const auto it = find_if(recursive_directory_iterator(dir_path), end,
+		[&file_name](const directory_entry& e) {
+			return e.path().filename() == file_name;
+		});
+	return it == end ? boost::optional<path>() : it->path();
+}
+
 
 /*****************************************************************************
  * Application Folder tests
  *****************************************************************************/
 BOOST_AUTO_TEST_CASE( read_license_near_module ) {
-#ifdef _WIN32
-#ifdef _DEBUG
-	const string testExeFolder = PROJECT_BINARY_DIR "/test/library/Debug";
-#else
-	const string testExeFolder = PROJECT_BINARY_DIR "/test/library/Release";
-#endif
-	const string testExe = testExeFolder + "/" + BOOST_TEST_MODULE ".exe";
-#else
 	const string testExeFolder = PROJECT_BINARY_DIR "/test/library";
-	const string testExe = testExeFolder + "/" + BOOST_TEST_MODULE;
+	bool exeFileFound = false;
+	string referenceExeFileName;
+	string referenceLicenseFileName;
+	//Verify we're pointing the correct executable, in windows isn't clear where it's built
+#ifdef _WIN32
+	boost::optional<path> exeLocation(find_file(path(testExeFolder), path(BOOST_TEST_MODULE ".exe")));
+	exeFileFound = exeLocation.has_value();
+	if (exeFileFound) {
+		referenceExeFileName = exeLocation.get().string();
+		referenceLicenseFileName = referenceExeFileName.replace(referenceExeFileName.find(BOOST_TEST_MODULE ".exe"), 
+			string(BOOST_TEST_MODULE ".exe").size(), BOOST_TEST_MODULE ".lic");
+	}
+#else
+	const string referenceExeFileName = testExeFolder + "/" + BOOST_TEST_MODULE;
+	ifstream f(referenceExeFileName.c_str());
+	exeFileFound = f.good();
+	referenceLicenseFileName = testExeFolder + "/" + BOOST_TEST_MODULE ".lic";
 #endif	
-	const string referenceLicenseFileName = testExeFolder + "/"
-			+ BOOST_TEST_MODULE ".lic";
+	BOOST_WARN_MESSAGE(!exeFileFound, "File [" + referenceExeFileName + "] NOT found");
+	if (exeFileFound) {
+		//copy test license near module
+		std::ifstream src(MOCK_LICENSE, std::ios::binary);
+		std::ofstream dst(referenceLicenseFileName, std::ios::binary);
+		dst << src.rdbuf();
+		dst.close();
 
-	//Verify we're pointing the correct executable
-	ifstream f(testExe.c_str());
-	BOOST_REQUIRE_MESSAGE(f.good(), "File [" + testExe + "] NOT found");
-
-	//copy test license near module
-	std::ifstream src(MOCK_LICENSE, std::ios::binary);
-	std::ofstream dst(referenceLicenseFileName, std::ios::binary);
-	dst << src.rdbuf();
-	dst.close();
-
-	license::EventRegistry registry;
-	ApplicationFolder applicationFolder;
-	vector<string> licenseInfos = applicationFolder.licenseLocations(registry);
-	BOOST_CHECK(registry.isGood());
-	BOOST_REQUIRE_EQUAL(1, licenseInfos.size());
-	string currentLocation = licenseInfos[0];
-	BOOST_CHECK_MESSAGE(referenceLicenseFileName.compare(currentLocation) == 0,
-			"file found at expected location");
-	string licenseRealContent = applicationFolder.retrieveLicense(
+		license::EventRegistry registry;
+		ApplicationFolder applicationFolder;
+		vector<string> licenseInfos = applicationFolder.licenseLocations(registry);
+		BOOST_CHECK(registry.isGood());
+		BOOST_REQUIRE_EQUAL(1, licenseInfos.size());
+		string currentLocation = licenseInfos[0];
+		BOOST_CHECK_MESSAGE(equivalent(path(referenceLicenseFileName),path(currentLocation)),
+			"file " +currentLocation + "found at expected location");
+		string licenseRealContent = applicationFolder.retrieveLicense(
 			currentLocation);
-	src.seekg(0, ios::beg);
-	std::string referenceContent((std::istreambuf_iterator<char>(src)),
+		src.seekg(0, ios::beg);
+		std::string referenceContent((std::istreambuf_iterator<char>(src)),
 			std::istreambuf_iterator<char>());
-	BOOST_CHECK_MESSAGE(referenceContent.compare(licenseRealContent) == 0,
+		BOOST_CHECK_MESSAGE(referenceContent.compare(licenseRealContent) == 0,
 			"File content is same");
-	remove(referenceLicenseFileName.c_str());
+		remove(referenceLicenseFileName.c_str());
+	}
 }
 
 /*****************************************************************************

--
Gitblit v1.9.1