// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "base/at_exit.h"
#include "base/logging.h"
#include "base/test/test_suite.h"
#include "sandbox/linux/tests/test_utils.h"
#include "sandbox/linux/tests/unit_tests.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace sandbox {
namespace {
// Check for leaks in our tests.
void RunPostTestsChecks() {
if (TestUtils::CurrentProcessHasChildren()) {
LOG(ERROR) << "One of the tests created a child that was not waited for. "
<< "Please, clean-up after your tests!";
}
}
} // namespace
} // namespace sandbox
#if defined(OS_ANDROID)
void UnitTestAssertHandler(const std::string& str) {
_exit(1);
}
#endif
int main(int argc, char* argv[]) {
#if defined(OS_ANDROID)
// The use of Callbacks requires an AtExitManager.
base::AtExitManager exit_manager;
testing::InitGoogleTest(&argc, argv);
// Death tests rely on LOG(FATAL) triggering an exit (the default behavior is
// SIGABRT). The normal test launcher does this at initialization, but since
// we still do not use this on Android, we must install the handler ourselves.
logging::SetLogAssertHandler(UnitTestAssertHandler);
#endif
// Always go through re-execution for death tests.
// This makes gtest only marginally slower for us and has the
// additional side effect of getting rid of gtest warnings about fork()
// safety.
::testing::FLAGS_gtest_death_test_style = "threadsafe";
#if defined(OS_ANDROID)
int tests_result = RUN_ALL_TESTS();
#else
int tests_result = base::RunUnitTestsUsingBaseTestSuite(argc, argv);
#endif
sandbox::RunPostTestsChecks();
return tests_result;
}