Index: chrome/browser/metrics/metrics_state_manager_unittest.cc |
=================================================================== |
--- chrome/browser/metrics/metrics_state_manager_unittest.cc (revision 0) |
+++ chrome/browser/metrics/metrics_state_manager_unittest.cc (working copy) |
@@ -0,0 +1,160 @@ |
+// Copyright 2014 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/metrics/metrics_state_manager.h" |
+ |
+#include <ctype.h> |
+#include <string> |
+ |
+#include "base/command_line.h" |
+#include "base/prefs/testing_pref_service.h" |
+#include "chrome/common/chrome_switches.h" |
+#include "chrome/common/metrics/caching_permuted_entropy_provider.h" |
+#include "chrome/common/pref_names.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace metrics { |
+ |
+class MetricsStateManagerTest : public testing::Test { |
+ public: |
+ MetricsStateManagerTest() { |
+ MetricsStateManager::RegisterPrefs(prefs_.registry()); |
+ } |
+ |
+ scoped_ptr<MetricsStateManager> CreateStateManager() { |
+ return MetricsStateManager::Create(&prefs_).Pass(); |
+ } |
+ |
+ protected: |
+ TestingPrefServiceSimple prefs_; |
+ |
+ private: |
+ DISALLOW_COPY_AND_ASSIGN(MetricsStateManagerTest); |
+}; |
+ |
+// Ensure the ClientId is formatted as expected. |
+TEST_F(MetricsStateManagerTest, ClientIdCorrectlyFormatted) { |
+ scoped_ptr<MetricsStateManager> state_manager(CreateStateManager()); |
+ state_manager->ForceClientIdCreation(); |
+ |
+ const std::string client_id = state_manager->client_id(); |
+ EXPECT_EQ(36U, client_id.length()); |
+ |
+ for (size_t i = 0; i < client_id.length(); ++i) { |
+ char current = client_id[i]; |
+ if (i == 8 || i == 13 || i == 18 || i == 23) |
+ EXPECT_EQ('-', current); |
+ else |
+ EXPECT_TRUE(isxdigit(current)); |
+ } |
+} |
+ |
+TEST_F(MetricsStateManagerTest, EntropySourceUsed_Low) { |
+ scoped_ptr<MetricsStateManager> state_manager(CreateStateManager()); |
+ state_manager->CreateEntropyProvider(); |
+ EXPECT_EQ(MetricsStateManager::ENTROPY_SOURCE_LOW, |
+ state_manager->entropy_source_returned()); |
+} |
+ |
+TEST_F(MetricsStateManagerTest, EntropySourceUsed_High) { |
+ CommandLine::ForCurrentProcess()->AppendSwitch( |
+ switches::kEnableMetricsReportingForTesting); |
+ |
+ scoped_ptr<MetricsStateManager> state_manager(CreateStateManager()); |
+ state_manager->CreateEntropyProvider(); |
+ EXPECT_EQ(MetricsStateManager::ENTROPY_SOURCE_HIGH, |
+ state_manager->entropy_source_returned()); |
+} |
+ |
+TEST_F(MetricsStateManagerTest, LowEntropySource0NotReset) { |
+ scoped_ptr<MetricsStateManager> state_manager(CreateStateManager()); |
+ |
+ // Get the low entropy source once, to initialize it. |
+ state_manager->GetLowEntropySource(); |
+ |
+ // Now, set it to 0 and ensure it doesn't get reset. |
+ state_manager->low_entropy_source_ = 0; |
+ EXPECT_EQ(0, state_manager->GetLowEntropySource()); |
+ // Call it another time, just to make sure. |
+ EXPECT_EQ(0, state_manager->GetLowEntropySource()); |
+} |
+ |
+TEST_F(MetricsStateManagerTest, |
+ PermutedEntropyCacheClearedWhenLowEntropyReset) { |
+ const PrefService::Preference* low_entropy_pref = |
+ prefs_.FindPreference(prefs::kMetricsLowEntropySource); |
+ const char* kCachePrefName = prefs::kMetricsPermutedEntropyCache; |
+ int low_entropy_value = -1; |
+ |
+ // First, generate an initial low entropy source value. |
+ { |
+ EXPECT_TRUE(low_entropy_pref->IsDefaultValue()); |
+ |
+ scoped_ptr<MetricsStateManager> state_manager(CreateStateManager()); |
+ state_manager->GetLowEntropySource(); |
+ |
+ EXPECT_FALSE(low_entropy_pref->IsDefaultValue()); |
+ EXPECT_TRUE(low_entropy_pref->GetValue()->GetAsInteger(&low_entropy_value)); |
+ } |
+ |
+ // Now, set a dummy value in the permuted entropy cache pref and verify that |
+ // another call to GetLowEntropySource() doesn't clobber it when |
+ // --reset-variation-state wasn't specified. |
+ { |
+ prefs_.SetString(kCachePrefName, "test"); |
+ |
+ scoped_ptr<MetricsStateManager> state_manager(CreateStateManager()); |
+ state_manager->GetLowEntropySource(); |
+ |
+ EXPECT_EQ("test", prefs_.GetString(kCachePrefName)); |
+ EXPECT_EQ(low_entropy_value, |
+ prefs_.GetInteger(prefs::kMetricsLowEntropySource)); |
+ } |
+ |
+ // Verify that the cache does get reset if --reset-variations-state is passed. |
+ { |
+ CommandLine::ForCurrentProcess()->AppendSwitch( |
+ switches::kResetVariationState); |
+ |
+ scoped_ptr<MetricsStateManager> state_manager(CreateStateManager()); |
+ state_manager->GetLowEntropySource(); |
+ |
+ EXPECT_TRUE(prefs_.GetString(kCachePrefName).empty()); |
+ } |
+} |
+ |
+// Check that setting the kMetricsResetIds pref to true causes the client id to |
+// be reset. We do not check that the low entropy source is reset because we |
+// cannot ensure that metrics state manager won't generate the same id again. |
+TEST_F(MetricsStateManagerTest, ResetMetricsIDs) { |
+ // Set an initial client id in prefs. It should not be possible for the |
+ // metrics state manager to generate this id randomly. |
+ const std::string kInitialClientId = "initial client id"; |
+ prefs_.SetString(prefs::kMetricsClientID, kInitialClientId); |
+ |
+ // Make sure the initial client id isn't reset by the metrics state manager. |
+ { |
+ scoped_ptr<MetricsStateManager> state_manager(CreateStateManager()); |
+ state_manager->ForceClientIdCreation(); |
+ EXPECT_EQ(kInitialClientId, state_manager->client_id()); |
+ } |
+ |
+ // Set the reset pref to cause the IDs to be reset. |
+ prefs_.SetBoolean(prefs::kMetricsResetIds, true); |
+ |
+ // Cause the actual reset to happen. |
+ { |
+ scoped_ptr<MetricsStateManager> state_manager(CreateStateManager()); |
+ state_manager->ForceClientIdCreation(); |
+ EXPECT_NE(kInitialClientId, state_manager->client_id()); |
+ |
+ state_manager->GetLowEntropySource(); |
+ |
+ EXPECT_FALSE(prefs_.GetBoolean(prefs::kMetricsResetIds)); |
+ } |
+ |
+ EXPECT_NE(kInitialClientId, prefs_.GetString(prefs::kMetricsClientID)); |
+} |
+ |
+} // namespace metrics |