// Copyright 2016 The Chromium Authors // 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/command_line.h" #include "base/i18n/icu_util.h" #include "base/logging.h" #include "base/test/scoped_run_loop_timeout.h" #include "base/test/task_environment.h" #include "base/test/test_timeouts.h" namespace { // Set up globals that a number of network tests use. // // Note that in general static initializers are not allowed, however this is // just being used by test code. struct InitGlobals { InitGlobals() { base::CommandLine::Init(0, nullptr); // |test| instances uses TaskEnvironment, which needs TestTimeouts. TestTimeouts::Initialize(); task_environment = std::make_unique( base::test::TaskEnvironment::MainThreadType::IO); increased_timeout_ = std::make_unique( FROM_HERE, TestTimeouts::action_max_timeout()); // Set up ICU. ICU is used internally by GURL, which is used throughout the // //net code. Initializing ICU is important to prevent fuzztests from // asserting when handling non-ASCII urls. CHECK(base::i18n::InitializeICU()); // Disable noisy logging as per "libFuzzer in Chrome" documentation: // testing/libfuzzer/getting_started.md#Disable-noisy-error-message-logging. logging::SetMinLogLevel(logging::LOGGING_FATAL); } // A number of tests use async code which depends on there being a // TaskEnvironment. Setting one up here allows tests to reuse the // TaskEnvironment between runs. std::unique_ptr task_environment; // Fuzzing tests often need to Run() for longer than action_timeout(). std::unique_ptr increased_timeout_; base::AtExitManager at_exit_manager; }; InitGlobals* init_globals = new InitGlobals(); } // namespace