// 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 <atlbase.h>
#include "base/command_line.h"
#include "base/process/kill.h"
#include "base/process/memory.h"
#include "base/test/test_suite.h"
#include "base/threading/platform_thread.h"
#include "base/win/scoped_com_initializer.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/test/logging/win/test_log_collector.h"
#include "chrome_frame/crash_server_init.h"
#include "chrome_frame/test/chrome_frame_test_utils.h"
#include "chrome_frame/test/chrome_frame_ui_test_utils.h"
#include "chrome_frame/test/ie_configurator.h"
#include "chrome_frame/test/test_scrubber.h"
#include "chrome_frame/test_utils.h"
#include "chrome_frame/utils.h"
#include "components/variations/entropy_provider.h"
// To enable ATL-based code to run in this module
class ChromeFrameUnittestsModule
: public CAtlExeModuleT<ChromeFrameUnittestsModule> {
public:
// Called at static init time, for versions of ATL included in VS2008 and
// earlier only. The default implementation initializes COM in MTA mode,
// which we don't want. We could init STA mode here, but since we have to
// init in main() for VS2010 and above anyway, we simply do nothing, since
// nothing needs COM before main() runs.
static HRESULT InitializeCom() { return S_OK; }
static void UninitializeCom() {}
};
ChromeFrameUnittestsModule _AtlModule;
const char kNoCrashService[] = "no-crash-service";
const char kNoLogCollector[] = "no-log-collector";
const char kNoRegistrationSwitch[] = "no-registration";
void PureCall() {
__debugbreak();
}
int main(int argc, char **argv) {
// For ATL in VS2010 and up, ChromeFrameUnittestsModule::InitializeCom() is
// not called, so we init COM here.
base::win::ScopedCOMInitializer com_initializer_;
ScopedChromeFrameRegistrar::RegisterAndExitProcessIfDirected();
base::EnableTerminationOnHeapCorruption();
base::PlatformThread::SetName("ChromeFrame tests");
_set_purecall_handler(PureCall);
base::TestSuite test_suite(argc, argv);
SetConfigBool(kChromeFrameHeadlessMode, true);
SetConfigBool(kChromeFrameAccessibleMode, true);
base::ProcessHandle crash_service = NULL;
google_breakpad::scoped_ptr<google_breakpad::ExceptionHandler> breakpad;
if (!CommandLine::ForCurrentProcess()->HasSwitch(kNoCrashService)) {
crash_service = chrome_frame_test::StartCrashService();
breakpad.reset(InitializeCrashReporting(HEADLESS));
}
// Install the log collector before anything else that adds a Google Test
// event listener so that it's the last one to run after each test (the
// listeners are invoked in reverse order at the end of a test). This allows
// the collector to emit logs if other listeners ADD_FAILURE or EXPECT_*.
if (!CommandLine::ForCurrentProcess()->HasSwitch(kNoLogCollector))
logging_win::InstallTestLogCollector(testing::UnitTest::GetInstance());
chrome_frame_test::InstallIEConfigurator();
chrome_frame_test::InstallTestScrubber(testing::UnitTest::GetInstance());
int ret = -1;
// If mini_installer is used to register CF, we use the switch
// --no-registration to avoid repetitive registration.
if (CommandLine::ForCurrentProcess()->HasSwitch(kNoRegistrationSwitch)) {
ret = test_suite.Run();
} else {
// This will register the chrome frame in the build directory. It currently
// leaves that chrome frame registered once the tests are done. It must be
// constructed AFTER the TestSuite is created since TestSuites create THE
// AtExitManager.
// TODO(robertshield): Make these tests restore the original registration
// once done.
ScopedChromeFrameRegistrar registrar(chrome_frame_test::GetTestBedType());
// Register IAccessible2 proxy stub DLL, needed for some tests.
ScopedChromeFrameRegistrar ia2_registrar(
chrome_frame_test::GetIAccessible2ProxyStubPath().value(),
ScopedChromeFrameRegistrar::SYSTEM_LEVEL);
ret = test_suite.Run();
}
DeleteConfigValue(kChromeFrameHeadlessMode);
DeleteConfigValue(kChromeFrameAccessibleMode);
if (crash_service)
base::KillProcess(crash_service, 0, false);
return ret;
}