diff options
author | jcivelli@google.com <jcivelli@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-23 23:35:49 +0000 |
---|---|---|
committer | jcivelli@google.com <jcivelli@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-23 23:35:49 +0000 |
commit | 9190b7b454dfda0980bc7652e9cb62ace614f6cf (patch) | |
tree | 749977b7f429ec1e6010804914c4b88c2deaf4cb | |
parent | e35c67993153e338121eedd6413e40d39b7cb8f9 (diff) | |
download | chromium_src-9190b7b454dfda0980bc7652e9cb62ace614f6cf.zip chromium_src-9190b7b454dfda0980bc7652e9cb62ace614f6cf.tar.gz chromium_src-9190b7b454dfda0980bc7652e9cb62ace614f6cf.tar.bz2 |
Don't autotranslate in incognito mode (so we don't send information
to the translation server without the user consent).
Also added unit-tests for prefs.
BUG=38107
TEST=Visit a page that triggers the translate infobar. Translate the
page. Select "Always translate <lang1> to <lang2>".
Open a page in lang1. The page should automatically be translated
to lang2.
Open an incognito window. Navigate to a page in lang1, the page
should not automcatically be translated, an infobar should ask
if the user wants to translate the page.
Review URL: http://codereview.chromium.org/1184001
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@42400 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/translate/translate_manager.cc | 8 | ||||
-rw-r--r-- | chrome/browser/translate/translate_manager_unittest.cc | 129 |
2 files changed, 133 insertions, 4 deletions
diff --git a/chrome/browser/translate/translate_manager.cc b/chrome/browser/translate/translate_manager.cc index dd08b50..c494208 100644 --- a/chrome/browser/translate/translate_manager.cc +++ b/chrome/browser/translate/translate_manager.cc @@ -170,8 +170,12 @@ void TranslateManager::InitiateTranslation(TabContents* tab, return; } - if (TranslatePrefs::ShouldAutoTranslate(prefs, page_lang, ui_lang)) { - // The user has previously select "always translate" for this language. + // If the user has previously selected "always translate" for this language we + // automatically translate. Note that in incognito mode we disable that + // feature; the user will get an infobar, so they can control whether the + // page's text is sent to the translate server. + if (TranslatePrefs::ShouldAutoTranslate(prefs, page_lang, ui_lang) && + !tab->profile()->IsOffTheRecord()) { tab->TranslatePage(page_lang, ui_lang); return; } diff --git a/chrome/browser/translate/translate_manager_unittest.cc b/chrome/browser/translate/translate_manager_unittest.cc index d05c220..03c7be8 100644 --- a/chrome/browser/translate/translate_manager_unittest.cc +++ b/chrome/browser/translate/translate_manager_unittest.cc @@ -528,8 +528,8 @@ TEST_F(TranslateManagerTest, UnsupportedUILanguage) { browser_process->SetApplicationLocale(original_lang); } -// Tests that the translate preference is honored. -TEST_F(TranslateManagerTest, TranslatePref) { +// Tests that the translate enabled preference is honored. +TEST_F(TranslateManagerTest, TranslateEnabledPref) { // Make sure the pref allows translate. PrefService* prefs = contents()->profile()->GetPrefs(); prefs->SetBoolean(prefs::kEnableTranslate, true); @@ -556,3 +556,128 @@ TEST_F(TranslateManagerTest, TranslatePref) { infobar = GetTranslateInfoBar(); EXPECT_TRUE(infobar == NULL); } + +// Tests the "Never translate <language>" pref. +TEST_F(TranslateManagerTest, NeverTranslateLanguagePref) { + // Simulate navigating to a page and getting its language. + GURL url("http://www.google.fr"); + SimulateNavigation(url, 0, L"Le Google", "fr"); + + // An infobar should be shown. + EXPECT_TRUE(GetTranslateInfoBar() != NULL); + + // Select never translate this language. + PrefService* prefs = contents()->profile()->GetPrefs(); + TranslatePrefs translate_prefs(contents()->profile()->GetPrefs()); + EXPECT_FALSE(translate_prefs.IsLanguageBlacklisted("fr")); + EXPECT_TRUE(translate_prefs.CanTranslate(prefs, "fr", url)); + translate_prefs.BlacklistLanguage("fr"); + EXPECT_TRUE(translate_prefs.IsLanguageBlacklisted("fr")); + EXPECT_FALSE(translate_prefs.CanTranslate(prefs, "fr", url)); + + // Close the infobar. + EXPECT_TRUE(CloseTranslateInfoBar()); + + // Navigate to a new page also in French. + SimulateNavigation(GURL("http://wwww.youtube.fr"), 1, L"Le YouTube", "fr"); + + // There should not be a translate infobar. + EXPECT_TRUE(GetTranslateInfoBar() == NULL); + + // Remove the language from the blacklist. + translate_prefs.RemoveLanguageFromBlacklist("fr"); + EXPECT_FALSE(translate_prefs.IsLanguageBlacklisted("fr")); + EXPECT_TRUE(translate_prefs.CanTranslate(prefs, "fr", url)); + + // Navigate to a page in French. + SimulateNavigation(url, 2, L"Le Google", "fr"); + + // There should be a translate infobar. + EXPECT_TRUE(GetTranslateInfoBar() != NULL); +} + +// Tests the "Never translate this site" pref. +TEST_F(TranslateManagerTest, NeverTranslateSitePref) { + // Simulate navigating to a page and getting its language. + GURL url("http://www.google.fr"); + std::string host(url.host()); + SimulateNavigation(url, 0, L"Le Google", "fr"); + + // An infobar should be shown. + EXPECT_TRUE(GetTranslateInfoBar() != NULL); + + // Select never translate this site. + PrefService* prefs = contents()->profile()->GetPrefs(); + TranslatePrefs translate_prefs(contents()->profile()->GetPrefs()); + EXPECT_FALSE(translate_prefs.IsSiteBlacklisted(host)); + EXPECT_TRUE(translate_prefs.CanTranslate(prefs, "fr", url)); + translate_prefs.BlacklistSite(host); + EXPECT_TRUE(translate_prefs.IsSiteBlacklisted(host)); + EXPECT_FALSE(translate_prefs.CanTranslate(prefs, "fr", url)); + + // Close the infobar. + EXPECT_TRUE(CloseTranslateInfoBar()); + + // Navigate to a new page also on the same site. + SimulateNavigation(GURL("http://www.google.fr/hello"), 1, L"Bonjour", "fr"); + + // There should not be a translate infobar. + EXPECT_TRUE(GetTranslateInfoBar() == NULL); + + // Remove the site from the blacklist. + translate_prefs.RemoveSiteFromBlacklist(host); + EXPECT_FALSE(translate_prefs.IsSiteBlacklisted(host)); + EXPECT_TRUE(translate_prefs.CanTranslate(prefs, "fr", url)); + + // Navigate to a page in French. + SimulateNavigation(url, 0, L"Le Google", "fr"); + + // There should be a translate infobar. + EXPECT_TRUE(GetTranslateInfoBar() != NULL); +} + +// Tests the "Always translate this language" pref. +TEST_F(TranslateManagerTest, AlwaysTranslateLanguagePref) { + // Select always translate French to English. + TranslatePrefs translate_prefs(contents()->profile()->GetPrefs()); + translate_prefs.WhitelistLanguagePair("fr", "en"); + + // Load a page in French. + SimulateNavigation(GURL("http://www.google.fr"), 0, L"Le Google", "fr"); + + // It should have triggered an automatic translation to English. + int page_id = 0; + std::string original_lang, target_lang; + EXPECT_TRUE(GetTranslateMessage(&page_id, &original_lang, &target_lang)); + EXPECT_EQ(0, page_id); + EXPECT_EQ("fr", original_lang); + EXPECT_EQ("en", target_lang); + process()->sink().ClearMessages(); + // And we should have no infobar (since we don't send the page translated + // notification, the after translate infobar is not shown). + EXPECT_TRUE(GetTranslateInfoBar() == NULL); + + // Try another language, it should not be autotranslated. + SimulateNavigation(GURL("http://www.google.es"), 1, L"El Google", "es"); + EXPECT_FALSE(GetTranslateMessage(&page_id, &original_lang, &target_lang)); + EXPECT_TRUE(GetTranslateInfoBar() != NULL); + EXPECT_TRUE(CloseTranslateInfoBar()); + + // Let's switch to incognito mode, it should not be autotranslated in that + // case either. + TestingProfile* test_profile = + static_cast<TestingProfile*>(contents()->profile()); + test_profile->set_off_the_record(true); + SimulateNavigation(GURL("http://www.youtube.fr"), 2, L"Le YouTube", "fr"); + EXPECT_FALSE(GetTranslateMessage(&page_id, &original_lang, &target_lang)); + EXPECT_TRUE(GetTranslateInfoBar() != NULL); + EXPECT_TRUE(CloseTranslateInfoBar()); + test_profile->set_off_the_record(false); // Get back to non incognito. + + // Now revert the always translate pref and make sure we go back to expected + // behavior, which is show an infobar. + translate_prefs.RemoveLanguagePairFromWhitelist("fr", "en"); + SimulateNavigation(GURL("http://www.google.fr"), 3, L"Le Google", "fr"); + EXPECT_FALSE(GetTranslateMessage(&page_id, &original_lang, &target_lang)); + EXPECT_TRUE(GetTranslateInfoBar() != NULL); +} |