io_win32_unittest: make //:win32_test run again
Do not use "googletest.h", apprently that leads to linking errors on Windows which I couldn't figure out how to solve, and decided to just go with plain gTest instead. See https://github.com/google/protobuf/issues/3951
This commit is contained in:
parent
b140cb3145
commit
953a0253fc
@ -48,7 +48,6 @@
|
|||||||
|
|
||||||
#include <google/protobuf/stubs/io_win32.h>
|
#include <google/protobuf/stubs/io_win32.h>
|
||||||
#include <google/protobuf/stubs/scoped_ptr.h>
|
#include <google/protobuf/stubs/scoped_ptr.h>
|
||||||
#include <google/protobuf/testing/googletest.h>
|
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
@ -89,62 +88,43 @@ void StripTrailingSlashes(string* str) {
|
|||||||
for (; i >= 0 && ((*str)[i] == '/' || (*str)[i] == '\\'); --i) {}
|
for (; i >= 0 && ((*str)[i] == '/' || (*str)[i] == '\\'); --i) {}
|
||||||
str->resize(i+1);
|
str->resize(i+1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool GetEnvVar(const char* name, string* result) {
|
||||||
|
DWORD size = ::GetEnvironmentVariableA(name, NULL, 0);
|
||||||
|
if (size > 0 && GetLastError() != ERROR_ENVVAR_NOT_FOUND) {
|
||||||
|
scoped_array<char> str(new char[size]);
|
||||||
|
::GetEnvironmentVariableA(name, str.get(), size);
|
||||||
|
result->assign(str.get());
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
void IoWin32Test::SetUp() {
|
void IoWin32Test::SetUp() {
|
||||||
test_tmpdir = string(TestTempDir());
|
string tmp;
|
||||||
wtest_tmpdir.clear();
|
bool ok = false;
|
||||||
if (test_tmpdir.empty()) {
|
if (!ok) {
|
||||||
const char* test_tmpdir_env = getenv("TEST_TMPDIR");
|
ok = GetEnvVar("TEST_TMPDIR", &tmp);
|
||||||
if (test_tmpdir_env != NULL && *test_tmpdir_env) {
|
}
|
||||||
test_tmpdir = string(test_tmpdir_env);
|
if (!ok) {
|
||||||
}
|
ok = GetEnvVar("TEMP", &tmp);
|
||||||
|
}
|
||||||
// Only Bazel defines TEST_TMPDIR, CMake does not, so look for other
|
if (!ok) {
|
||||||
// suitable environment variables.
|
ok = GetEnvVar("TMP", &tmp);
|
||||||
if (test_tmpdir.empty()) {
|
}
|
||||||
static const char* names[] = {"TEMP", "TMP"};
|
if (!ok || tmp.empty()) {
|
||||||
for (int i = 0; i < sizeof(names)/sizeof(names[0]); ++i) {
|
FAIL();
|
||||||
const char* name = names[i];
|
|
||||||
test_tmpdir_env = getenv(name);
|
|
||||||
if (test_tmpdir_env != NULL && *test_tmpdir_env) {
|
|
||||||
test_tmpdir = string(test_tmpdir_env);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// No other temp directory was found. Use the current director
|
|
||||||
if (test_tmpdir.empty()) {
|
|
||||||
char buffer[MAX_PATH];
|
|
||||||
// Use GetCurrentDirectoryA instead of GetCurrentDirectoryW, because the
|
|
||||||
// current working directory must always be shorter than MAX_PATH, even
|
|
||||||
// with
|
|
||||||
// "\\?\" prefix (except on Windows 10 version 1607 and beyond, after
|
|
||||||
// opting in to long paths by default [1]).
|
|
||||||
//
|
|
||||||
// [1] https://msdn.microsoft.com/en-us/library/windows/desktop/aa365247(v=vs.85).aspx#maxpath
|
|
||||||
DWORD result = ::GetCurrentDirectoryA(MAX_PATH, buffer);
|
|
||||||
if (result > 0) {
|
|
||||||
test_tmpdir = string(buffer);
|
|
||||||
} else {
|
|
||||||
// Using assertions in SetUp/TearDown seems to confuse the test
|
|
||||||
// framework, so just leave the member variables empty in case of
|
|
||||||
// failure.
|
|
||||||
GOOGLE_CHECK_OK(false);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
StripTrailingSlashes(&test_tmpdir);
|
|
||||||
test_tmpdir += "\\io_win32_unittest.tmp";
|
|
||||||
|
|
||||||
// CreateDirectoryA's limit is 248 chars, see MSDN.
|
StripTrailingSlashes(&tmp);
|
||||||
// https://msdn.microsoft.com/en-us/library/windows/desktop/aa363855(v=vs.85).aspx
|
test_tmpdir = tmp + "\\io_win32_unittest.tmp";
|
||||||
wtest_tmpdir = testonly_path_to_winpath(test_tmpdir);
|
wtest_tmpdir = testonly_path_to_winpath(test_tmpdir);
|
||||||
if (!DeleteAllUnder(wtest_tmpdir) || !CreateAllUnder(wtest_tmpdir)) {
|
if (!DeleteAllUnder(wtest_tmpdir) || !CreateAllUnder(wtest_tmpdir)) {
|
||||||
GOOGLE_CHECK_OK(false);
|
FAIL();
|
||||||
test_tmpdir.clear();
|
test_tmpdir.clear();
|
||||||
wtest_tmpdir.clear();
|
wtest_tmpdir.clear();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user