blob: 7f7747e43e57d15ce8db48606d3d27624ff82991 [file] [log] [blame]
// Copyright 2015 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 "components/metrics/net/net_metrics_log_uploader.h"
#include "base/base64.h"
#include "base/bind.h"
#include "base/macros.h"
#include "components/encrypted_messages/encrypted_message.pb.h"
#include "net/url_request/test_url_fetcher_factory.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "third_party/metrics_proto/reporting_info.pb.h"
#include "third_party/zlib/google/compression_utils.h"
#include "url/gurl.h"
namespace metrics {
class NetMetricsLogUploaderTest : public testing::Test {
public:
NetMetricsLogUploaderTest() : on_upload_complete_count_(0) {
}
void CreateAndOnUploadCompleteReuseUploader() {
ReportingInfo reporting_info;
reporting_info.set_attempt_count(10);
uploader_.reset(new NetMetricsLogUploader(
nullptr, "https://dummy_server", "dummy_mime", MetricsLogUploader::UMA,
base::Bind(&NetMetricsLogUploaderTest::OnUploadCompleteReuseUploader,
base::Unretained(this))));
uploader_->UploadLog("initial_dummy_data", "initial_dummy_hash",
reporting_info);
}
void CreateUploaderAndUploadToSecureURL() {
ReportingInfo dummy_reporting_info;
uploader_.reset(new NetMetricsLogUploader(
nullptr, "https://dummy_secure_server", "dummy_mime",
MetricsLogUploader::UMA,
base::Bind(&NetMetricsLogUploaderTest::DummyOnUploadComplete,
base::Unretained(this))));
uploader_->UploadLog("dummy_data", "dummy_hash", dummy_reporting_info);
}
void CreateUploaderAndUploadToInsecureURL() {
ReportingInfo dummy_reporting_info;
uploader_.reset(new NetMetricsLogUploader(
nullptr, "http://dummy_insecure_server", "dummy_mime",
MetricsLogUploader::UMA,
base::Bind(&NetMetricsLogUploaderTest::DummyOnUploadComplete,
base::Unretained(this))));
std::string compressed_message;
// Compress the data since the encryption code expects a compressed log,
// and tries to decompress it before encrypting it.
compression::GzipCompress("dummy_data", &compressed_message);
uploader_->UploadLog(compressed_message, "dummy_hash",
dummy_reporting_info);
}
void DummyOnUploadComplete(int response_code,
int error_code,
bool was_https) {}
void OnUploadCompleteReuseUploader(int response_code,
int error_code,
bool was_https) {
++on_upload_complete_count_;
if (on_upload_complete_count_ == 1) {
ReportingInfo reporting_info;
reporting_info.set_attempt_count(20);
uploader_->UploadLog("dummy_data", "dummy_hash", reporting_info);
}
}
int on_upload_complete_count() const {
return on_upload_complete_count_;
}
private:
std::unique_ptr<NetMetricsLogUploader> uploader_;
int on_upload_complete_count_;
DISALLOW_COPY_AND_ASSIGN(NetMetricsLogUploaderTest);
};
void CheckReportingInfoHeader(net::TestURLFetcher* fetcher,
int expected_attempt_count) {
net::HttpRequestHeaders headers;
fetcher->GetExtraRequestHeaders(&headers);
std::string reporting_info_base64;
EXPECT_TRUE(
headers.GetHeader("X-Chrome-UMA-ReportingInfo", &reporting_info_base64));
std::string reporting_info_string;
EXPECT_TRUE(
base::Base64Decode(reporting_info_base64, &reporting_info_string));
ReportingInfo reporting_info;
EXPECT_TRUE(reporting_info.ParseFromString(reporting_info_string));
EXPECT_EQ(reporting_info.attempt_count(), expected_attempt_count);
}
TEST_F(NetMetricsLogUploaderTest, OnUploadCompleteReuseUploader) {
net::TestURLFetcherFactory factory;
CreateAndOnUploadCompleteReuseUploader();
// Mimic the initial fetcher callback.
net::TestURLFetcher* fetcher = factory.GetFetcherByID(0);
CheckReportingInfoHeader(fetcher, 10);
fetcher->delegate()->OnURLFetchComplete(fetcher);
// Mimic the second fetcher callback.
fetcher = factory.GetFetcherByID(0);
CheckReportingInfoHeader(fetcher, 20);
fetcher->delegate()->OnURLFetchComplete(fetcher);
EXPECT_EQ(on_upload_complete_count(), 2);
}
// Test that attempting to upload to an HTTP URL results in an encrypted
// message.
TEST_F(NetMetricsLogUploaderTest, MessageOverHTTPIsEncrypted) {
net::TestURLFetcherFactory factory;
CreateUploaderAndUploadToInsecureURL();
net::TestURLFetcher* fetcher = factory.GetFetcherByID(0);
encrypted_messages::EncryptedMessage message;
EXPECT_TRUE(message.ParseFromString(fetcher->upload_data()));
}
// Test that attempting to upload to an HTTPS URL results in an unencrypted
// message.
TEST_F(NetMetricsLogUploaderTest, MessageOverHTTPSIsNotEncrypted) {
net::TestURLFetcherFactory factory;
CreateUploaderAndUploadToSecureURL();
net::TestURLFetcher* fetcher = factory.GetFetcherByID(0);
EXPECT_EQ(fetcher->upload_data(), "dummy_data");
}
} // namespace metrics