aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWladimir J. van der Laan <laanwj@gmail.com>2015-04-20 13:42:33 +0200
committerWladimir J. van der Laan <laanwj@gmail.com>2015-04-20 13:44:11 +0200
commit3a7061339874da58ce966da29a2944b57aadcf97 (patch)
tree86878516c1b1fe7936de3a115b049be235128806
parent57d1f46952bb6ee5c7b1200f29e8854d3191923a (diff)
parent323de27f4b6a9673902cb414c3b0e3879b1366e7 (diff)
downloadbitcoin-3a7061339874da58ce966da29a2944b57aadcf97.tar.xz
Merge pull request #6025
323de27 Initialization: setup environment before starting QT tests (dexX7) 7494e09 Initialization: setup environment before starting tests (dexX7) df45564 Initialization: set fallback locale as environment variable (dexX7)
-rw-r--r--src/qt/test/test_main.cpp2
-rw-r--r--src/test/test_bitcoin.cpp1
-rw-r--r--src/util.cpp7
3 files changed, 7 insertions, 3 deletions
diff --git a/src/qt/test/test_main.cpp b/src/qt/test/test_main.cpp
index f2161c2f79..7d7282db17 100644
--- a/src/qt/test/test_main.cpp
+++ b/src/qt/test/test_main.cpp
@@ -6,6 +6,7 @@
#include "config/bitcoin-config.h"
#endif
+#include "util.h"
#include "uritests.h"
#ifdef ENABLE_WALLET
@@ -27,6 +28,7 @@ Q_IMPORT_PLUGIN(qkrcodecs)
// This is all you need to run all the tests
int main(int argc, char *argv[])
{
+ SetupEnvironment();
bool fInvalid = false;
// Don't remove this, it's needed to access
diff --git a/src/test/test_bitcoin.cpp b/src/test/test_bitcoin.cpp
index 5269e3bda7..30626267ff 100644
--- a/src/test/test_bitcoin.cpp
+++ b/src/test/test_bitcoin.cpp
@@ -30,6 +30,7 @@ struct TestingSetup {
boost::thread_group threadGroup;
TestingSetup() {
+ SetupEnvironment();
fPrintToDebugLog = false; // don't want to write to debug.log file
fCheckBlockIndex = true;
SelectParams(CBaseChainParams::UNITTEST);
diff --git a/src/util.cpp b/src/util.cpp
index a03f55c910..4fea18b306 100644
--- a/src/util.cpp
+++ b/src/util.cpp
@@ -713,18 +713,19 @@ void RenameThread(const char* name)
void SetupEnvironment()
{
+ std::locale loc("C");
// On most POSIX systems (e.g. Linux, but not BSD) the environment's locale
// may be invalid, in which case the "C" locale is used as fallback.
#if !defined(WIN32) && !defined(MAC_OSX) && !defined(__FreeBSD__) && !defined(__OpenBSD__)
try {
- std::locale(""); // Raises a runtime error if current locale is invalid
+ loc = std::locale(""); // Raises a runtime error if current locale is invalid
} catch (const std::runtime_error&) {
- std::locale::global(std::locale("C"));
+ setenv("LC_ALL", "C", 1);
}
#endif
// The path locale is lazy initialized and to avoid deinitialization errors
// in multithreading environments, it is set explicitly by the main thread.
- boost::filesystem::path::imbue(std::locale());
+ boost::filesystem::path::imbue(loc);
}
void SetThreadPriority(int nPriority)