diff options
author | davidben <davidben@chromium.org> | 2015-04-08 20:59:20 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2015-04-09 04:00:47 +0000 |
commit | f4877890bdacd8a446a24afba3043aa87da86471 (patch) | |
tree | a374c5c01fd68e34941028ed01c8e32e4c3f12fc /chrome/browser/mod_pagespeed/mod_pagespeed_metrics_unittest.cc | |
parent | 65a9d1d2258c3068196b8a25261b9ad7fa0b107c (diff) | |
download | chromium_src-f4877890bdacd8a446a24afba3043aa87da86471.zip chromium_src-f4877890bdacd8a446a24afba3043aa87da86471.tar.gz chromium_src-f4877890bdacd8a446a24afba3043aa87da86471.tar.bz2 |
Move mod_pagespeed metrics out of prerender.
The metrics don't have much to do with prerender. Move them out into a
dedicated file.
BUG=none
Review URL: https://codereview.chromium.org/1051463003
Cr-Commit-Position: refs/heads/master@{#324358}
Diffstat (limited to 'chrome/browser/mod_pagespeed/mod_pagespeed_metrics_unittest.cc')
-rw-r--r-- | chrome/browser/mod_pagespeed/mod_pagespeed_metrics_unittest.cc | 166 |
1 files changed, 166 insertions, 0 deletions
diff --git a/chrome/browser/mod_pagespeed/mod_pagespeed_metrics_unittest.cc b/chrome/browser/mod_pagespeed/mod_pagespeed_metrics_unittest.cc new file mode 100644 index 0000000..38ef0cb --- /dev/null +++ b/chrome/browser/mod_pagespeed/mod_pagespeed_metrics_unittest.cc @@ -0,0 +1,166 @@ +// 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 "chrome/browser/mod_pagespeed/mod_pagespeed_metrics.h" + +#include <algorithm> +#include <string> + +#include "base/memory/ref_counted.h" +#include "base/memory/scoped_ptr.h" +#include "base/metrics/histogram.h" +#include "base/metrics/histogram_samples.h" +#include "base/metrics/statistics_recorder.h" +#include "content/public/common/resource_type.h" +#include "net/http/http_response_headers.h" +#include "testing/gtest/include/gtest/gtest.h" +#include "url/gurl.h" + +namespace mod_pagespeed { + +// Ensure that we count PageSpeed headers correctly. +TEST(ModPagespeedMetricsTest, CountPageSpeedHeadersTest) { + base::StatisticsRecorder::Initialize(); + GURL url("http://google.com"); + std::string temp("HTTP/1.1 200 OK\n\n"); + std::replace(temp.begin(), temp.end(), '\n', '\0'); + scoped_refptr<net::HttpResponseHeaders> headers( + new net::HttpResponseHeaders(temp)); + + int num_responses = 0; + int num_mps = 0; + int num_ngx = 0; + int num_pss = 0; + int num_other = 0; + int num_bucket_1 = 0; // unrecognized format/value bucket + int num_bucket_30 = 0; // 1.2.24.1 bucket + int num_bucket_33 = 0; // 1.3.25.2 bucket + + scoped_ptr<base::HistogramSamples> server_samples; + scoped_ptr<base::HistogramSamples> version_samples; + + // No PageSpeed header. The VersionCounts histogram isn't created yet. + RecordMetrics(content::RESOURCE_TYPE_MAIN_FRAME, url, headers.get()); + base::HistogramBase* server_histogram = + base::StatisticsRecorder::FindHistogram( + "Prerender.PagespeedHeader.ServerCounts"); + ASSERT_TRUE(server_histogram != NULL); + ASSERT_TRUE(NULL == base::StatisticsRecorder::FindHistogram( + "Prerender.PagespeedHeader.VersionCounts")); + + server_samples = server_histogram->SnapshotSamples(); + EXPECT_EQ(++num_responses, server_samples->GetCount(0)); + EXPECT_EQ(num_mps, server_samples->GetCount(1)); + EXPECT_EQ(num_ngx, server_samples->GetCount(2)); + EXPECT_EQ(num_pss, server_samples->GetCount(3)); + EXPECT_EQ(num_other, server_samples->GetCount(4)); + + // X-Mod-Pagespeed header in expected format. VersionCounts now exists. + headers->AddHeader("X-Mod-Pagespeed: 1.2.24.1-2300"); + RecordMetrics(content::RESOURCE_TYPE_MAIN_FRAME, url, headers.get()); + base::HistogramBase* version_histogram = + base::StatisticsRecorder::FindHistogram( + "Prerender.PagespeedHeader.VersionCounts"); + ASSERT_TRUE(version_histogram != NULL); + server_samples = server_histogram->SnapshotSamples(); + version_samples = version_histogram->SnapshotSamples(); + EXPECT_EQ(++num_responses, server_samples->GetCount(0)); + EXPECT_EQ(++num_mps, server_samples->GetCount(1)); + EXPECT_EQ(num_ngx, server_samples->GetCount(2)); + EXPECT_EQ(num_pss, server_samples->GetCount(3)); + EXPECT_EQ(num_other, server_samples->GetCount(4)); + EXPECT_EQ(num_bucket_1, version_samples->GetCount(1)); + EXPECT_EQ(++num_bucket_30, version_samples->GetCount(30)); // +1 for #30 + EXPECT_EQ(num_bucket_33, version_samples->GetCount(33)); + headers->RemoveHeader("X-Mod-Pagespeed"); + + // X-Mod-Pagespeed header in unexpected format. + headers->AddHeader("X-Mod-Pagespeed: Powered By PageSpeed!"); + RecordMetrics(content::RESOURCE_TYPE_MAIN_FRAME, url, headers.get()); + server_samples = server_histogram->SnapshotSamples(); + version_samples = version_histogram->SnapshotSamples(); + EXPECT_EQ(++num_responses, server_samples->GetCount(0)); + EXPECT_EQ(++num_mps, server_samples->GetCount(1)); + EXPECT_EQ(num_ngx, server_samples->GetCount(2)); + EXPECT_EQ(num_pss, server_samples->GetCount(3)); + EXPECT_EQ(num_other, server_samples->GetCount(4)); + EXPECT_EQ(++num_bucket_1, version_samples->GetCount(1)); // +1 for 'huh?' + EXPECT_EQ(num_bucket_30, version_samples->GetCount(30)); + EXPECT_EQ(num_bucket_33, version_samples->GetCount(33)); + headers->RemoveHeader("X-Mod-Pagespeed"); + + // X-Page-Speed header in mod_pagespeed format (so ngx_pagespeed). + headers->AddHeader("X-Page-Speed: 1.3.25.2-2530"); + RecordMetrics(content::RESOURCE_TYPE_MAIN_FRAME, url, headers.get()); + server_samples = server_histogram->SnapshotSamples(); + version_samples = version_histogram->SnapshotSamples(); + EXPECT_EQ(++num_responses, server_samples->GetCount(0)); + EXPECT_EQ(num_mps, server_samples->GetCount(1)); + EXPECT_EQ(++num_ngx, server_samples->GetCount(2)); + EXPECT_EQ(num_pss, server_samples->GetCount(3)); + EXPECT_EQ(num_other, server_samples->GetCount(4)); + EXPECT_EQ(num_bucket_1, version_samples->GetCount(1)); + EXPECT_EQ(num_bucket_30, version_samples->GetCount(30)); + EXPECT_EQ(++num_bucket_33, version_samples->GetCount(33)); // +1 for #33 + headers->RemoveHeader("X-Page-Speed"); + + // X-Page-Speed header in PageSpeed Service format. + headers->AddHeader("X-Page-Speed: 97_4_bo"); + RecordMetrics(content::RESOURCE_TYPE_MAIN_FRAME, url, headers.get()); + server_samples = server_histogram->SnapshotSamples(); + version_samples = version_histogram->SnapshotSamples(); + EXPECT_EQ(++num_responses, server_samples->GetCount(0)); + EXPECT_EQ(num_mps, server_samples->GetCount(1)); // no change + EXPECT_EQ(num_ngx, server_samples->GetCount(2)); + EXPECT_EQ(++num_pss, server_samples->GetCount(3)); // +1 for PSS + EXPECT_EQ(num_other, server_samples->GetCount(4)); + EXPECT_EQ(num_bucket_1, version_samples->GetCount(1)); + EXPECT_EQ(num_bucket_30, version_samples->GetCount(30)); + EXPECT_EQ(num_bucket_33, version_samples->GetCount(33)); + headers->RemoveHeader("X-Page-Speed"); + + // X-Page-Speed header in an unrecognized format (IISpeed in this case). + headers->AddHeader("X-Page-Speed: 1.0PS1.2-20130615"); + RecordMetrics(content::RESOURCE_TYPE_MAIN_FRAME, url, headers.get()); + server_samples = server_histogram->SnapshotSamples(); + version_samples = version_histogram->SnapshotSamples(); + EXPECT_EQ(++num_responses, server_samples->GetCount(0)); + EXPECT_EQ(num_mps, server_samples->GetCount(1)); // no change + EXPECT_EQ(num_pss, server_samples->GetCount(3)); + EXPECT_EQ(++num_other, server_samples->GetCount(4)); // +1 for 'other' + EXPECT_EQ(num_bucket_1, version_samples->GetCount(1)); + EXPECT_EQ(num_bucket_30, version_samples->GetCount(30)); + EXPECT_EQ(num_bucket_33, version_samples->GetCount(33)); + + // Not a main frame => not counted at all. + RecordMetrics(content::RESOURCE_TYPE_SUB_FRAME, url, headers.get()); + server_samples = server_histogram->SnapshotSamples(); + version_samples = version_histogram->SnapshotSamples(); + EXPECT_EQ(num_responses, server_samples->GetCount(0)); + EXPECT_EQ(num_mps, server_samples->GetCount(1)); + EXPECT_EQ(num_ngx, server_samples->GetCount(2)); + EXPECT_EQ(num_pss, server_samples->GetCount(3)); + EXPECT_EQ(num_other, server_samples->GetCount(4)); + EXPECT_EQ(num_bucket_1, version_samples->GetCount(1)); + EXPECT_EQ(num_bucket_30, version_samples->GetCount(30)); + EXPECT_EQ(num_bucket_33, version_samples->GetCount(33)); + + // Not a http/https URL => not counted at all. + GURL data_url("data:image/png;base64,yadda yadda=="); + RecordMetrics(content::RESOURCE_TYPE_MAIN_FRAME, data_url, headers.get()); + server_samples = server_histogram->SnapshotSamples(); + version_samples = version_histogram->SnapshotSamples(); + EXPECT_EQ(num_responses, server_samples->GetCount(0)); + EXPECT_EQ(num_mps, server_samples->GetCount(1)); + EXPECT_EQ(num_ngx, server_samples->GetCount(2)); + EXPECT_EQ(num_pss, server_samples->GetCount(3)); + EXPECT_EQ(num_other, server_samples->GetCount(4)); + EXPECT_EQ(num_bucket_1, version_samples->GetCount(1)); + EXPECT_EQ(num_bucket_30, version_samples->GetCount(30)); + EXPECT_EQ(num_bucket_33, version_samples->GetCount(33)); + + headers->RemoveHeader("X-Page-Speed"); +} + +} // namespace mod_pagespeed |