Index: rlz/lib/financial_ping_test.cc |
diff --git a/rlz/lib/financial_ping_test.cc b/rlz/lib/financial_ping_test.cc |
deleted file mode 100644 |
index c04cf46c272c8b90fe4a88e9afc6ea8c52b973ef..0000000000000000000000000000000000000000 |
--- a/rlz/lib/financial_ping_test.cc |
+++ /dev/null |
@@ -1,293 +0,0 @@ |
-// 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. |
-// |
-// A test application for the FinancialPing class. |
-// |
-// These tests should not be executed on the build server: |
-// - They modify machine state (registry). |
-// |
-// These tests require write access to HKCU and HKLM. |
-// |
-// The "GGLA" brand is used to test the normal code flow of the code, and the |
-// "TEST" brand is used to test the supplementary brand code code flow. In one |
-// case below, the brand "GOOG" is used because the code wants to use a brand |
-// that is neither of the two mentioned above. |
- |
-#include "rlz/lib/financial_ping.h" |
- |
-#include "base/basictypes.h" |
-#include "base/logging.h" |
-#include "base/string_util.h" |
-#include "base/stringprintf.h" |
-#include "base/utf_string_conversions.h" |
-#include "rlz/lib/lib_values.h" |
-#include "rlz/lib/machine_id.h" |
-#include "rlz/lib/rlz_lib.h" |
-#include "rlz/lib/rlz_value_store.h" |
-#include "rlz/test/rlz_test_helpers.h" |
-#include "testing/gmock/include/gmock/gmock.h" |
-#include "testing/gtest/include/gtest/gtest.h" |
- |
-#if defined(OS_WIN) |
-#include "rlz/win/lib/machine_deal.h" |
-#else |
-#include "base/time.h" |
-#endif |
- |
-namespace { |
- |
-// Must match the implementation in file_time.cc. |
-int64 GetSystemTimeAsInt64() { |
-#if defined(OS_WIN) |
- FILETIME now_as_file_time; |
- GetSystemTimeAsFileTime(&now_as_file_time); |
- LARGE_INTEGER integer; |
- integer.HighPart = now_as_file_time.dwHighDateTime; |
- integer.LowPart = now_as_file_time.dwLowDateTime; |
- return integer.QuadPart; |
-#else |
- double now_seconds = base::Time::Now().ToDoubleT(); |
- return static_cast<int64>(now_seconds * 1000 * 1000 * 10); |
-#endif |
-} |
- |
-// Ping times in 100-nanosecond intervals. |
-const int64 k1MinuteInterval = 60LL * 10000000LL; // 1 minute |
- |
-} // namespace anonymous |
- |
-class FinancialPingTest : public RlzLibTestBase { |
-}; |
- |
-TEST_F(FinancialPingTest, FormRequest) { |
- std::string brand_string = rlz_lib::SupplementaryBranding::GetBrand(); |
- const char* brand = brand_string.empty() ? "GGLA" : brand_string.c_str(); |
- |
-#if defined(OS_WIN) |
- EXPECT_TRUE(rlz_lib::MachineDealCode::Set("dcc_value")); |
-#define DCC_PARAM "&dcc=dcc_value" |
-#else |
-#define DCC_PARAM "" |
-#endif |
- |
- EXPECT_TRUE(rlz_lib::SetAccessPointRlz(rlz_lib::IETB_SEARCH_BOX, |
- "TbRlzValue")); |
- |
- EXPECT_TRUE(rlz_lib::ClearAllProductEvents(rlz_lib::TOOLBAR_NOTIFIER)); |
- EXPECT_TRUE(rlz_lib::RecordProductEvent(rlz_lib::TOOLBAR_NOTIFIER, |
- rlz_lib::IE_DEFAULT_SEARCH, rlz_lib::SET_TO_GOOGLE)); |
- EXPECT_TRUE(rlz_lib::RecordProductEvent(rlz_lib::TOOLBAR_NOTIFIER, |
- rlz_lib::IE_HOME_PAGE, rlz_lib::INSTALL)); |
- |
- rlz_lib::AccessPoint points[] = |
- {rlz_lib::IETB_SEARCH_BOX, rlz_lib::NO_ACCESS_POINT, |
- rlz_lib::NO_ACCESS_POINT}; |
- |
- std::string machine_id; |
- bool got_machine_id = rlz_lib::GetMachineId(&machine_id); |
- |
- std::string request; |
- EXPECT_TRUE(rlz_lib::FinancialPing::FormRequest(rlz_lib::TOOLBAR_NOTIFIER, |
- points, "swg", brand, NULL, "en", false, &request)); |
- std::string expected_response; |
- base::StringAppendF(&expected_response, |
- "/tools/pso/ping?as=swg&brand=%s&hl=en&" |
- "events=I7S,W1I&rep=2&rlz=T4:TbRlzValue" DCC_PARAM |
-, brand); |
- |
- if (got_machine_id) |
- base::StringAppendF(&expected_response, "&id=%s", machine_id.c_str()); |
- EXPECT_EQ(expected_response, request); |
- |
- EXPECT_TRUE(rlz_lib::SetAccessPointRlz(rlz_lib::IETB_SEARCH_BOX, "")); |
- EXPECT_TRUE(rlz_lib::FinancialPing::FormRequest(rlz_lib::TOOLBAR_NOTIFIER, |
- points, "swg", brand, "IdOk2", NULL, false, &request)); |
- expected_response.clear(); |
- base::StringAppendF(&expected_response, |
- "/tools/pso/ping?as=swg&brand=%s&pid=IdOk2&" |
- "events=I7S,W1I&rep=2&rlz=T4:" DCC_PARAM, brand); |
- |
- if (got_machine_id) |
- base::StringAppendF(&expected_response, "&id=%s", machine_id.c_str()); |
- EXPECT_EQ(expected_response, request); |
- |
- EXPECT_TRUE(rlz_lib::FinancialPing::FormRequest(rlz_lib::TOOLBAR_NOTIFIER, |
- points, "swg", brand, "IdOk", NULL, true, &request)); |
- expected_response.clear(); |
- base::StringAppendF(&expected_response, |
- "/tools/pso/ping?as=swg&brand=%s&pid=IdOk&" |
- "events=I7S,W1I&rep=2&rlz=T4:" DCC_PARAM, brand); |
- EXPECT_EQ(expected_response, request); |
- |
- EXPECT_TRUE(rlz_lib::FinancialPing::FormRequest(rlz_lib::TOOLBAR_NOTIFIER, |
- points, "swg", brand, NULL, NULL, true, &request)); |
- expected_response.clear(); |
- base::StringAppendF(&expected_response, |
- "/tools/pso/ping?as=swg&brand=%s&events=I7S,W1I&rep=2" |
- "&rlz=T4:" DCC_PARAM, brand); |
- EXPECT_EQ(expected_response, request); |
- |
- |
- // Clear all events. |
- EXPECT_TRUE(rlz_lib::ClearAllProductEvents(rlz_lib::TOOLBAR_NOTIFIER)); |
- |
- // Clear all RLZs. |
- char rlz[rlz_lib::kMaxRlzLength + 1]; |
- for (int ap = rlz_lib::NO_ACCESS_POINT + 1; |
- ap < rlz_lib::LAST_ACCESS_POINT; ap++) { |
- rlz[0] = 0; |
- rlz_lib::AccessPoint point = static_cast<rlz_lib::AccessPoint>(ap); |
- if (rlz_lib::GetAccessPointRlz(point, rlz, arraysize(rlz)) && rlz[0]) { |
- rlz_lib::SetAccessPointRlz(point, ""); |
- } |
- } |
- |
- EXPECT_TRUE(rlz_lib::SetAccessPointRlz(rlz_lib::IETB_SEARCH_BOX, |
- "TbRlzValue")); |
- EXPECT_TRUE(rlz_lib::SetAccessPointRlz(rlz_lib::QUICK_SEARCH_BOX, |
- "QsbRlzValue")); |
- EXPECT_TRUE(rlz_lib::FinancialPing::FormRequest(rlz_lib::TOOLBAR_NOTIFIER, |
- points, "swg", brand, NULL, NULL, false, &request)); |
- expected_response.clear(); |
- base::StringAppendF(&expected_response, |
- "/tools/pso/ping?as=swg&brand=%s&rep=2&rlz=T4:TbRlzValue," |
- "Q1:QsbRlzValue" DCC_PARAM, brand); |
- EXPECT_STREQ(expected_response.c_str(), request.c_str()); |
- |
- if (!GetAccessPointRlz(rlz_lib::IE_HOME_PAGE, rlz, arraysize(rlz))) { |
- points[2] = rlz_lib::IE_HOME_PAGE; |
- EXPECT_TRUE(rlz_lib::FinancialPing::FormRequest(rlz_lib::TOOLBAR_NOTIFIER, |
- points, "swg", brand, "MyId", "en-US", true, &request)); |
- expected_response.clear(); |
- base::StringAppendF(&expected_response, |
- "/tools/pso/ping?as=swg&brand=%s&hl=en-US&pid=MyId&rep=2" |
- "&rlz=T4:TbRlzValue,Q1:QsbRlzValue" DCC_PARAM, brand); |
- EXPECT_STREQ(expected_response.c_str(), request.c_str()); |
- } |
-} |
- |
-TEST_F(FinancialPingTest, FormRequestBadBrand) { |
- rlz_lib::AccessPoint points[] = |
- {rlz_lib::IETB_SEARCH_BOX, rlz_lib::NO_ACCESS_POINT, |
- rlz_lib::NO_ACCESS_POINT}; |
- |
- std::string request; |
- bool ok = rlz_lib::FinancialPing::FormRequest(rlz_lib::TOOLBAR_NOTIFIER, |
- points, "swg", "GOOG", NULL, "en", false, &request); |
- EXPECT_EQ(rlz_lib::SupplementaryBranding::GetBrand().empty(), ok); |
-} |
- |
- |
-static void SetLastPingTime(int64 time, rlz_lib::Product product) { |
- rlz_lib::ScopedRlzValueStoreLock lock; |
- rlz_lib::RlzValueStore* store = lock.GetStore(); |
- ASSERT_TRUE(store); |
- ASSERT_TRUE(store->HasAccess(rlz_lib::RlzValueStore::kWriteAccess)); |
- store->WritePingTime(product, time); |
-} |
- |
-TEST_F(FinancialPingTest, IsPingTime) { |
- int64 now = GetSystemTimeAsInt64(); |
- int64 last_ping = now - rlz_lib::kEventsPingInterval - k1MinuteInterval; |
- SetLastPingTime(last_ping, rlz_lib::TOOLBAR_NOTIFIER); |
- |
- // No events, last ping just over a day ago. |
- EXPECT_TRUE(rlz_lib::ClearAllProductEvents(rlz_lib::TOOLBAR_NOTIFIER)); |
- EXPECT_FALSE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- |
- // Has events, last ping just over a day ago. |
- EXPECT_TRUE(rlz_lib::RecordProductEvent(rlz_lib::TOOLBAR_NOTIFIER, |
- rlz_lib::IE_DEFAULT_SEARCH, rlz_lib::SET_TO_GOOGLE)); |
- EXPECT_TRUE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- |
- // Has events, last ping just under a day ago. |
- last_ping = now - rlz_lib::kEventsPingInterval + k1MinuteInterval; |
- SetLastPingTime(last_ping, rlz_lib::TOOLBAR_NOTIFIER); |
- EXPECT_FALSE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- |
- EXPECT_TRUE(rlz_lib::ClearAllProductEvents(rlz_lib::TOOLBAR_NOTIFIER)); |
- |
- // No events, last ping just under a week ago. |
- last_ping = now - rlz_lib::kNoEventsPingInterval + k1MinuteInterval; |
- SetLastPingTime(last_ping, rlz_lib::TOOLBAR_NOTIFIER); |
- EXPECT_FALSE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- |
- // No events, last ping just over a week ago. |
- last_ping = now - rlz_lib::kNoEventsPingInterval - k1MinuteInterval; |
- SetLastPingTime(last_ping, rlz_lib::TOOLBAR_NOTIFIER); |
- EXPECT_TRUE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- |
- // Last ping was in future (invalid). |
- last_ping = now + k1MinuteInterval; |
- SetLastPingTime(last_ping, rlz_lib::TOOLBAR_NOTIFIER); |
- EXPECT_TRUE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- EXPECT_TRUE(rlz_lib::RecordProductEvent(rlz_lib::TOOLBAR_NOTIFIER, |
- rlz_lib::IE_DEFAULT_SEARCH, rlz_lib::SET_TO_GOOGLE)); |
- EXPECT_TRUE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
-} |
- |
-TEST_F(FinancialPingTest, BrandingIsPingTime) { |
- // Don't run these tests if a supplementary brand is already in place. That |
- // way we can control the branding. |
- if (!rlz_lib::SupplementaryBranding::GetBrand().empty()) |
- return; |
- |
- int64 now = GetSystemTimeAsInt64(); |
- int64 last_ping = now - rlz_lib::kEventsPingInterval - k1MinuteInterval; |
- SetLastPingTime(last_ping, rlz_lib::TOOLBAR_NOTIFIER); |
- |
- // Has events, last ping just over a day ago. |
- EXPECT_TRUE(rlz_lib::RecordProductEvent(rlz_lib::TOOLBAR_NOTIFIER, |
- rlz_lib::IE_DEFAULT_SEARCH, rlz_lib::SET_TO_GOOGLE)); |
- EXPECT_TRUE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- |
- { |
- rlz_lib::SupplementaryBranding branding("TEST"); |
- SetLastPingTime(last_ping, rlz_lib::TOOLBAR_NOTIFIER); |
- |
- // Has events, last ping just over a day ago. |
- EXPECT_TRUE(rlz_lib::RecordProductEvent(rlz_lib::TOOLBAR_NOTIFIER, |
- rlz_lib::IE_DEFAULT_SEARCH, rlz_lib::SET_TO_GOOGLE)); |
- EXPECT_TRUE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- } |
- |
- last_ping = now - k1MinuteInterval; |
- SetLastPingTime(last_ping, rlz_lib::TOOLBAR_NOTIFIER); |
- |
- EXPECT_FALSE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- |
- { |
- rlz_lib::SupplementaryBranding branding("TEST"); |
- EXPECT_TRUE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- } |
-} |
- |
-TEST_F(FinancialPingTest, ClearLastPingTime) { |
- int64 now = GetSystemTimeAsInt64(); |
- int64 last_ping = now - rlz_lib::kEventsPingInterval + k1MinuteInterval; |
- SetLastPingTime(last_ping, rlz_lib::TOOLBAR_NOTIFIER); |
- |
- // Has events, last ping just under a day ago. |
- EXPECT_TRUE(rlz_lib::ClearAllProductEvents(rlz_lib::TOOLBAR_NOTIFIER)); |
- EXPECT_TRUE(rlz_lib::RecordProductEvent(rlz_lib::TOOLBAR_NOTIFIER, |
- rlz_lib::IE_DEFAULT_SEARCH, rlz_lib::SET_TO_GOOGLE)); |
- EXPECT_FALSE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
- |
- EXPECT_TRUE(rlz_lib::FinancialPing::ClearLastPingTime( |
- rlz_lib::TOOLBAR_NOTIFIER)); |
- EXPECT_TRUE(rlz_lib::FinancialPing::IsPingTime(rlz_lib::TOOLBAR_NOTIFIER, |
- false)); |
-} |