| // 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 <iostream> |
| |
| #include "base/bind.h" |
| #include "base/build_time.h" |
| #include "base/test/launcher/unit_test_launcher.h" |
| #include "build/build_config.h" |
| #include "crypto/nss_util.h" |
| #include "net/socket/transport_client_socket_pool.h" |
| #include "net/test/net_test_suite.h" |
| #include "url/buildflags.h" |
| |
| namespace { |
| |
| bool VerifyBuildIsTimely() { |
| // This lines up with various //net security features, like Certificate |
| // Transparency or HPKP, in that they require the build time be less than 70 |
| // days old. Moreover, operating on the assumption that tests are run against |
| // recently compiled builds, this also serves as a sanity check for the |
| // system clock, which should be close to the build date. |
| base::TimeDelta kMaxAge = base::TimeDelta::FromDays(70); |
| |
| base::Time build_time = base::GetBuildTime(); |
| base::Time now = base::Time::Now(); |
| |
| if ((now - build_time).magnitude() <= kMaxAge) |
| return true; |
| |
| std::cerr |
| << "ERROR: This build is more than " << kMaxAge.InDays() |
| << " days out of date.\n" |
| "This could indicate a problem with the device's clock, or the build " |
| "is simply too old.\n" |
| "See crbug.com/666821 for why this is a problem\n" |
| << " base::Time::Now() --> " << now << " (" << now.ToInternalValue() |
| << ")\n" |
| << " base::GetBuildTime() --> " << build_time << " (" |
| << build_time.ToInternalValue() << ")\n"; |
| |
| return false; |
| } |
| |
| } // namespace |
| |
| int main(int argc, char** argv) { |
| if (!VerifyBuildIsTimely()) |
| return 1; |
| |
| NetTestSuite test_suite(argc, argv); |
| net::TransportClientSocketPool::set_connect_backup_jobs_enabled(false); |
| |
| return base::LaunchUnitTests( |
| argc, argv, |
| base::BindOnce(&NetTestSuite::Run, base::Unretained(&test_suite))); |
| } |