| Index: chrome/browser/web_resource/promo_resource_service_unittest.cc
|
| diff --git a/chrome/browser/web_resource/promo_resource_service_unittest.cc b/chrome/browser/web_resource/promo_resource_service_unittest.cc
|
| index b196b128e02c2bcff7e635acc6ba0c21fefdcd08..a69385cd50ac7bbd7742546bbaa49c253923b0c4 100644
|
| --- a/chrome/browser/web_resource/promo_resource_service_unittest.cc
|
| +++ b/chrome/browser/web_resource/promo_resource_service_unittest.cc
|
| @@ -15,6 +15,7 @@
|
| #include "chrome/test/base/testing_browser_process.h"
|
| #include "chrome/test/base/testing_pref_service.h"
|
| #include "chrome/test/base/testing_profile.h"
|
| +#include "content/test/test_url_fetcher_factory.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
|
|
| class PromoResourceServiceTest : public testing::Test {
|
| @@ -28,6 +29,7 @@ class PromoResourceServiceTest : public testing::Test {
|
| TestingProfile profile_;
|
| ScopedTestingLocalState local_state_;
|
| scoped_refptr<PromoResourceService> web_resource_service_;
|
| + MessageLoop loop_;
|
| };
|
|
|
| // Verifies that custom dates read from a web resource server are written to
|
| @@ -131,9 +133,6 @@ TEST_F(PromoResourceServiceTest, UnpackPromoSignal) {
|
| scoped_ptr<DictionaryValue> test_json(static_cast<DictionaryValue*>(
|
| base::JSONReader::Read(json, false)));
|
|
|
| - // Initialize a message loop for this to run on.
|
| - MessageLoop loop;
|
| -
|
| // Check that prefs are set correctly.
|
| web_resource_service_->UnpackPromoSignal(*(test_json.get()));
|
| PrefService* prefs = profile_.GetPrefs();
|
| @@ -187,22 +186,24 @@ TEST_F(PromoResourceServiceTest, UnpackWebStoreSignal) {
|
| scoped_ptr<DictionaryValue> test_json(static_cast<DictionaryValue*>(
|
| base::JSONReader::Read(json, false)));
|
|
|
| - // Initialize a message loop for this to run on.
|
| - MessageLoop loop;
|
| + // Set the source logo URL to verify that it gets cleared.
|
| + AppsPromo::SetSourcePromoLogoURL(GURL("https://www.google.com/test.png"));
|
|
|
| // Check that prefs are set correctly.
|
| web_resource_service_->UnpackWebStoreSignal(*(test_json.get()));
|
| - PrefService* prefs = profile_.GetPrefs();
|
| - ASSERT_TRUE(prefs != NULL);
|
|
|
| - EXPECT_EQ("341252", AppsPromo::GetPromoId());
|
| - EXPECT_EQ("The header!", AppsPromo::GetPromoHeaderText());
|
| - EXPECT_EQ("The button label!", AppsPromo::GetPromoButtonText());
|
| - EXPECT_EQ(GURL("http://link.com"), AppsPromo::GetPromoLink());
|
| - EXPECT_EQ("No thanks, hide this.", AppsPromo::GetPromoExpireText());
|
| - EXPECT_EQ(AppsPromo::USERS_NEW, AppsPromo::GetPromoUserGroup());
|
| - EXPECT_EQ(GURL("chrome://theme/IDR_WEBSTORE_ICON"),
|
| - AppsPromo::GetPromoLogo());
|
| + AppsPromo::PromoData actual_data = AppsPromo::GetPromo();
|
| + EXPECT_EQ("341252", actual_data.id);
|
| + EXPECT_EQ("The header!", actual_data.header);
|
| + EXPECT_EQ("The button label!", actual_data.button);
|
| + EXPECT_EQ(GURL("http://link.com"), actual_data.link);
|
| + EXPECT_EQ("No thanks, hide this.", actual_data.expire);
|
| + EXPECT_EQ(AppsPromo::USERS_NEW, actual_data.user_group);
|
| +
|
| + // When we don't download a logo, we revert to the default and clear the
|
| + // source pref.
|
| + EXPECT_EQ(GURL("chrome://theme/IDR_WEBSTORE_ICON"), actual_data.logo);
|
| + EXPECT_EQ(GURL(""), AppsPromo::GetSourcePromoLogoURL());
|
| }
|
|
|
| // Tests that the "web store active" flag is set even when the web store promo
|
| @@ -221,15 +222,174 @@ TEST_F(PromoResourceServiceTest, UnpackPartialWebStoreSignal) {
|
| scoped_ptr<DictionaryValue> test_json(static_cast<DictionaryValue*>(
|
| base::JSONReader::Read(json, false)));
|
|
|
| - // Initialize a message loop for this to run on.
|
| - MessageLoop loop;
|
| -
|
| // Check that prefs are set correctly.
|
| web_resource_service_->UnpackWebStoreSignal(*(test_json.get()));
|
| EXPECT_FALSE(AppsPromo::IsPromoSupportedForLocale());
|
| EXPECT_TRUE(AppsPromo::IsWebStoreSupportedForLocale());
|
| }
|
|
|
| +// Tests that we can successfully unpack web store signals with HTTPS
|
| +// logos.
|
| +TEST_F(PromoResourceServiceTest, UnpackWebStoreSignalHttpsLogo) {
|
| + web_resource_service_->set_channel(chrome::VersionInfo::CHANNEL_DEV);
|
| +
|
| + std::string logo_url = "https://www.google.com/image/test.png";
|
| + std::string png_data = "!$#%,./nvl;iadh9oh82";
|
| + std::string png_base64 = "";
|
| +
|
| + FakeURLFetcherFactory factory;
|
| + factory.SetFakeResponse(logo_url, png_data, true);
|
| +
|
| + std::string json =
|
| + "{ "
|
| + " \"topic\": {"
|
| + " \"answers\": ["
|
| + " {"
|
| + " \"answer_id\": \"340252\","
|
| + " \"name\": \"webstore_promo:15:1:" + logo_url + "\","
|
| + " \"question\": \"Header!\","
|
| + " \"inproduct_target\": \"The button label!\","
|
| + " \"inproduct\": \"http://link.com\","
|
| + " \"tooltip\": \"No thanks, hide this.\""
|
| + " }"
|
| + " ]"
|
| + " }"
|
| + "}";
|
| +
|
| + scoped_ptr<DictionaryValue> test_json(static_cast<DictionaryValue*>(
|
| + base::JSONReader::Read(json, false)));
|
| +
|
| + // Update the promo multiple times to verify the logo is cached correctly.
|
| + for (size_t i = 0; i < 2; ++i) {
|
| + web_resource_service_->UnpackWebStoreSignal(*(test_json.get()));
|
| +
|
| + // We should only need to run the message loop the first time since the
|
| + // image is then cached.
|
| + if (i == 0)
|
| + loop_.RunAllPending();
|
| +
|
| + // Reset this scoped_ptr to prevent a DCHECK.
|
| + web_resource_service_->apps_promo_logo_fetcher_.reset();
|
| +
|
| + AppsPromo::PromoData actual_data = AppsPromo::GetPromo();
|
| + EXPECT_EQ("340252", actual_data.id);
|
| + EXPECT_EQ("Header!", actual_data.header);
|
| + EXPECT_EQ("The button label!", actual_data.button);
|
| + EXPECT_EQ(GURL("http://link.com"), actual_data.link);
|
| + EXPECT_EQ("No thanks, hide this.", actual_data.expire);
|
| + EXPECT_EQ(AppsPromo::USERS_NEW, actual_data.user_group);
|
| +
|
| + // The logo should now be a base64 DATA URL.
|
| + EXPECT_EQ(GURL(png_base64), actual_data.logo);
|
| +
|
| + // And the source pref should hold the source HTTPS URL.
|
| + EXPECT_EQ(GURL(logo_url), AppsPromo::GetSourcePromoLogoURL());
|
| + }
|
| +}
|
| +
|
| +// Tests that we revert to the default logo when the fetch fails.
|
| +TEST_F(PromoResourceServiceTest, UnpackWebStoreSignalHttpsLogoError) {
|
| + web_resource_service_->set_channel(chrome::VersionInfo::CHANNEL_DEV);
|
| +
|
| + std::string logo_url = "https://www.google.com/image/test.png";
|
| + std::string png_data = "!$#%,./nvl;iadh9oh82";
|
| + std::string png_base64 = "ISQjJSwuL252bDtpYWRoOW9oODI=";
|
| +
|
| + FakeURLFetcherFactory factory;
|
| +
|
| + // Have URLFetcher return a 500 error.
|
| + factory.SetFakeResponse(logo_url, png_data, false);
|
| +
|
| + std::string json =
|
| + "{ "
|
| + " \"topic\": {"
|
| + " \"answers\": ["
|
| + " {"
|
| + " \"answer_id\": \"340252\","
|
| + " \"name\": \"webstore_promo:15:1:" + logo_url + "\","
|
| + " \"question\": \"Header!\","
|
| + " \"inproduct_target\": \"The button label!\","
|
| + " \"inproduct\": \"http://link.com\","
|
| + " \"tooltip\": \"No thanks, hide this.\""
|
| + " }"
|
| + " ]"
|
| + " }"
|
| + "}";
|
| +
|
| + scoped_ptr<DictionaryValue> test_json(static_cast<DictionaryValue*>(
|
| + base::JSONReader::Read(json, false)));
|
| +
|
| + web_resource_service_->UnpackWebStoreSignal(*(test_json.get()));
|
| +
|
| + loop_.RunAllPending();
|
| +
|
| + // Reset this scoped_ptr to prevent a DCHECK.
|
| + web_resource_service_->apps_promo_logo_fetcher_.reset();
|
| +
|
| + AppsPromo::PromoData actual_data = AppsPromo::GetPromo();
|
| + EXPECT_EQ("340252", actual_data.id);
|
| + EXPECT_EQ("Header!", actual_data.header);
|
| + EXPECT_EQ("The button label!", actual_data.button);
|
| + EXPECT_EQ(GURL("http://link.com"), actual_data.link);
|
| + EXPECT_EQ("No thanks, hide this.", actual_data.expire);
|
| + EXPECT_EQ(AppsPromo::USERS_NEW, actual_data.user_group);
|
| +
|
| + // Logos are the default values.
|
| + EXPECT_EQ(GURL("chrome://theme/IDR_WEBSTORE_ICON"), actual_data.logo);
|
| + EXPECT_EQ(GURL(""), AppsPromo::GetSourcePromoLogoURL());
|
| +}
|
| +
|
| +// Tests that we don't download images over HTTP.
|
| +TEST_F(PromoResourceServiceTest, UnpackWebStoreSignalHttpLogo) {
|
| + web_resource_service_->set_channel(chrome::VersionInfo::CHANNEL_DEV);
|
| +
|
| + // Use an HTTP URL.
|
| + std::string logo_url = "http://www.google.com/image/test.png";
|
| + std::string png_data = "!$#%,./nvl;iadh9oh82";
|
| + std::string png_base64 = "ISQjJSwuL252bDtpYWRoOW9oODI=";
|
| +
|
| + FakeURLFetcherFactory factory;
|
| + factory.SetFakeResponse(logo_url, png_data, true);
|
| +
|
| + std::string json =
|
| + "{ "
|
| + " \"topic\": {"
|
| + " \"answers\": ["
|
| + " {"
|
| + " \"answer_id\": \"340252\","
|
| + " \"name\": \"webstore_promo:15:1:" + logo_url + "\","
|
| + " \"question\": \"Header!\","
|
| + " \"inproduct_target\": \"The button label!\","
|
| + " \"inproduct\": \"http://link.com\","
|
| + " \"tooltip\": \"No thanks, hide this.\""
|
| + " }"
|
| + " ]"
|
| + " }"
|
| + "}";
|
| +
|
| + scoped_ptr<DictionaryValue> test_json(static_cast<DictionaryValue*>(
|
| + base::JSONReader::Read(json, false)));
|
| +
|
| + web_resource_service_->UnpackWebStoreSignal(*(test_json.get()));
|
| +
|
| + loop_.RunAllPending();
|
| +
|
| + // Reset this scoped_ptr to prevent a DCHECK.
|
| + web_resource_service_->apps_promo_logo_fetcher_.reset();
|
| +
|
| + AppsPromo::PromoData actual_data = AppsPromo::GetPromo();
|
| + EXPECT_EQ("340252", actual_data.id);
|
| + EXPECT_EQ("Header!", actual_data.header);
|
| + EXPECT_EQ("The button label!", actual_data.button);
|
| + EXPECT_EQ(GURL("http://link.com"), actual_data.link);
|
| + EXPECT_EQ("No thanks, hide this.", actual_data.expire);
|
| + EXPECT_EQ(AppsPromo::USERS_NEW, actual_data.user_group);
|
| +
|
| + // Logos should be the default values because HTTP URLs are not valid.
|
| + EXPECT_EQ(GURL("chrome://theme/IDR_WEBSTORE_ICON"), actual_data.logo);
|
| + EXPECT_EQ(GURL(""), AppsPromo::GetSourcePromoLogoURL());
|
| +}
|
| +
|
| TEST_F(PromoResourceServiceTest, IsBuildTargeted) {
|
| // canary
|
| const chrome::VersionInfo::Channel canary =
|
|
|