// Copyright (c) 2010 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 #include #include "base/path_service.h" #include "base/platform_thread.h" #include "base/process_util.h" #include "base/sys_info.h" #include "chrome/common/env_vars.h" #include "base/test/test_suite.h" #include "base/command_line.h" #include "chrome/common/chrome_paths.h" #include "chrome_frame/test/chrome_frame_test_utils.h" #include "chrome_frame/test/http_server.h" #include "chrome_frame/test_utils.h" #include "chrome_frame/utils.h" // To enable ATL-based code to run in this module class ChromeFrameUnittestsModule : public CAtlExeModuleT { public: static HRESULT InitializeCom() { return CoInitializeEx(NULL, COINIT_APARTMENTTHREADED); } }; ChromeFrameUnittestsModule _AtlModule; const wchar_t kNoRegistrationSwitch[] = L"no-registration"; // Causes the test executable to just run the web server and quit when the // server is killed. Useful for debugging tests. const wchar_t kRunAsServer[] = L"server"; void PureCall() { __debugbreak(); } int main(int argc, char **argv) { base::EnableTerminationOnHeapCorruption(); PlatformThread::SetName("ChromeFrame tests"); _set_purecall_handler(PureCall); TestSuite test_suite(argc, argv); if (CommandLine::ForCurrentProcess()->HasSwitch(kRunAsServer)) { ChromeFrameHTTPServer server; server.SetUp(); GURL server_url(server.test_server()->GetURL("")); std::cout << std::endl << "Server waiting on " << server_url.spec().c_str() << std::endl << std::endl << "Test output will be written to " << server.test_server()->document_root().value() << "\\dump" << std::endl << std::endl << "Hit Ctrl-C or navigate to " << server_url.spec().c_str() << "kill to shut down the server." << std::endl; server.WaitToFinish(INFINITE); server.TearDown(); std::cout << "Server stopped."; return 0; } SetConfigBool(kChromeFrameHeadlessMode, true); // Pretend that a screenreader is in use to cause Chrome to generate the // accessibility tree during page load. Otherwise, Chrome will send back // an unpopulated tree for the first request while it fetches the tree // from the renderer. BOOL is_screenreader_on = FALSE; SystemParametersInfo(SPI_SETSCREENREADER, TRUE, NULL, 0); SystemParametersInfo(SPI_GETSCREENREADER, 0, &is_screenreader_on, 0); if (!is_screenreader_on) { LOG(ERROR) << "Could not set screenreader property. Tests depending on " << "MSAA in CF will likely fail..."; } base::ProcessHandle crash_service = chrome_frame_test::StartCrashService(); 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 { // Register paths needed by the ScopedChromeFrameRegistrar. chrome::RegisterPathProvider(); // 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; ret = test_suite.Run(); } DeleteConfigValue(kChromeFrameHeadlessMode); if (crash_service) base::KillProcess(crash_service, 0, false); }