blob: 13781462110b4da373e6ec8945fe85d7347b83d1 [file] [log] [blame]
// Copyright 2013 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/ui/search/search_tab_helper.h"
#include <stdint.h>
#include <memory>
#include <string>
#include <utility>
#include "base/bind.h"
#include "base/strings/utf_string_conversions.h"
#include "base/time/time.h"
#include "chrome/browser/signin/identity_test_environment_profile_adaptor.h"
#include "chrome/browser/sync/profile_sync_service_factory.h"
#include "chrome/browser/sync/profile_sync_test_util.h"
#include "chrome/browser/ui/search/search_ipc_router.h"
#include "chrome/common/search/mock_embedded_search_client.h"
#include "chrome/common/url_constants.h"
#include "chrome/grit/generated_resources.h"
#include "chrome/test/base/browser_with_test_window_test.h"
#include "chrome/test/base/chrome_render_view_host_test_harness.h"
#include "chrome/test/base/testing_profile.h"
#include "components/browser_sync/profile_sync_service.h"
#include "components/strings/grit/components_strings.h"
#include "content/public/browser/web_contents.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "ui/base/l10n/l10n_util.h"
#include "url/gurl.h"
using testing::_;
using testing::NiceMock;
using testing::Return;
namespace {
class MockEmbeddedSearchClientFactory
: public SearchIPCRouter::EmbeddedSearchClientFactory {
public:
MOCK_METHOD0(GetEmbeddedSearchClient,
chrome::mojom::EmbeddedSearchClient*(void));
};
} // namespace
class SearchTabHelperTest : public ChromeRenderViewHostTestHarness {
public:
SearchTabHelperTest() {}
void SetUp() override {
ChromeRenderViewHostTestHarness::SetUp();
identity_test_env_adaptor_ =
std::make_unique<IdentityTestEnvironmentProfileAdaptor>(profile());
SearchTabHelper::CreateForWebContents(web_contents());
auto* search_tab = SearchTabHelper::FromWebContents(web_contents());
auto factory =
std::make_unique<NiceMock<MockEmbeddedSearchClientFactory>>();
ON_CALL(*factory, GetEmbeddedSearchClient())
.WillByDefault(Return(&mock_embedded_search_client_));
search_tab->ipc_router_for_testing()
.set_embedded_search_client_factory_for_testing(std::move(factory));
}
void TearDown() override {
// |identity_test_env_adaptor_| must be destroyed before profile().
identity_test_env_adaptor_.reset();
ChromeRenderViewHostTestHarness::TearDown();
}
content::BrowserContext* CreateBrowserContext() override {
TestingProfile::TestingFactories factories = {
{ProfileSyncServiceFactory::GetInstance(),
base::BindRepeating(&BuildMockProfileSyncService)}};
// Per comments on content::RenderViewHostTestHarness, it takes ownership of
// the returned object.
return IdentityTestEnvironmentProfileAdaptor::
CreateProfileForIdentityTestEnvironment(factories)
.release();
}
// Associates |email| with profile as the primary account. |email|
// should not be empty.
void SetUpAccount(const std::string& email) {
ASSERT_FALSE(email.empty());
identity_test_env()->SetPrimaryAccount(email);
}
// Configure the account to |sync_history| or not.
void SetHistorySync(bool sync_history) {
browser_sync::ProfileSyncServiceMock* sync_service =
static_cast<browser_sync::ProfileSyncServiceMock*>(
ProfileSyncServiceFactory::GetForProfile(profile()));
ON_CALL(*sync_service->GetUserSettingsMock(), IsFirstSetupComplete())
.WillByDefault(Return(true));
syncer::ModelTypeSet types;
if (sync_history) {
types.Put(syncer::TYPED_URLS);
}
ON_CALL(*sync_service->GetUserSettingsMock(), GetChosenDataTypes())
.WillByDefault(Return(types));
}
identity::IdentityTestEnvironment* identity_test_env() {
DCHECK(identity_test_env_adaptor_);
return identity_test_env_adaptor_->identity_test_env();
}
private:
NiceMock<MockEmbeddedSearchClient> mock_embedded_search_client_;
std::unique_ptr<IdentityTestEnvironmentProfileAdaptor>
identity_test_env_adaptor_;
};
TEST_F(SearchTabHelperTest, ChromeIdentityCheckMatch) {
NavigateAndCommit(GURL(chrome::kChromeSearchLocalNtpUrl));
SetUpAccount("foo@bar.com");
SearchTabHelper* search_tab_helper =
SearchTabHelper::FromWebContents(web_contents());
ASSERT_NE(nullptr, search_tab_helper);
const base::string16 test_identity = base::ASCIIToUTF16("foo@bar.com");
EXPECT_TRUE(search_tab_helper->ChromeIdentityCheck(test_identity));
}
TEST_F(SearchTabHelperTest, ChromeIdentityCheckMatchSlightlyDifferentGmail) {
NavigateAndCommit(GURL(chrome::kChromeSearchLocalNtpUrl));
SetUpAccount("foobar123@gmail.com");
SearchTabHelper* search_tab_helper =
SearchTabHelper::FromWebContents(web_contents());
ASSERT_NE(nullptr, search_tab_helper);
// For gmail, canonicalization is done so that email addresses have a
// standard form.
const base::string16 test_identity =
base::ASCIIToUTF16("Foo.Bar.123@gmail.com");
EXPECT_TRUE(search_tab_helper->ChromeIdentityCheck(test_identity));
}
TEST_F(SearchTabHelperTest, ChromeIdentityCheckMatchSlightlyDifferentGmail2) {
NavigateAndCommit(GURL(chrome::kChromeSearchLocalNtpUrl));
SetUpAccount("chrome.user.7FOREVER");
SearchTabHelper* search_tab_helper =
SearchTabHelper::FromWebContents(web_contents());
ASSERT_NE(nullptr, search_tab_helper);
// For gmail/googlemail, canonicalization is done so that email addresses have
// a standard form.
const base::string16 test_identity =
base::ASCIIToUTF16("chromeuser7forever@googlemail.com");
EXPECT_TRUE(search_tab_helper->ChromeIdentityCheck(test_identity));
}
TEST_F(SearchTabHelperTest, ChromeIdentityCheckMismatch) {
NavigateAndCommit(GURL(chrome::kChromeSearchLocalNtpUrl));
SetUpAccount("foo@bar.com");
SearchTabHelper* search_tab_helper =
SearchTabHelper::FromWebContents(web_contents());
ASSERT_NE(nullptr, search_tab_helper);
const base::string16 test_identity = base::ASCIIToUTF16("bar@foo.com");
EXPECT_FALSE(search_tab_helper->ChromeIdentityCheck(test_identity));
}
TEST_F(SearchTabHelperTest, ChromeIdentityCheckSignedOutMismatch) {
NavigateAndCommit(GURL(chrome::kChromeSearchLocalNtpUrl));
// This test does not sign in.
SearchTabHelper* search_tab_helper =
SearchTabHelper::FromWebContents(web_contents());
ASSERT_NE(nullptr, search_tab_helper);
const base::string16 test_identity = base::ASCIIToUTF16("bar@foo.com");
EXPECT_FALSE(search_tab_helper->ChromeIdentityCheck(test_identity));
}
TEST_F(SearchTabHelperTest, HistorySyncCheckSyncing) {
NavigateAndCommit(GURL(chrome::kChromeSearchLocalNtpUrl));
SetHistorySync(true);
SearchTabHelper* search_tab_helper =
SearchTabHelper::FromWebContents(web_contents());
ASSERT_NE(nullptr, search_tab_helper);
EXPECT_TRUE(search_tab_helper->HistorySyncCheck());
}
TEST_F(SearchTabHelperTest, HistorySyncCheckNotSyncing) {
NavigateAndCommit(GURL(chrome::kChromeSearchLocalNtpUrl));
SetHistorySync(false);
SearchTabHelper* search_tab_helper =
SearchTabHelper::FromWebContents(web_contents());
ASSERT_NE(nullptr, search_tab_helper);
EXPECT_FALSE(search_tab_helper->HistorySyncCheck());
}
TEST_F(SearchTabHelperTest, FileSelectedUpdatesLastSelectedDirectory) {
NavigateAndCommit(GURL(chrome::kChromeUINewTabURL));
SearchTabHelper* search_tab_helper =
SearchTabHelper::FromWebContents(web_contents());
ASSERT_NE(nullptr, search_tab_helper);
base::FilePath filePath =
base::FilePath::FromUTF8Unsafe("a/b/c/Picture/kitten.png");
search_tab_helper->FileSelected(filePath, 0, {});
Profile* profile = search_tab_helper->profile();
EXPECT_EQ(filePath.DirName(), profile->last_selected_directory());
}
TEST_F(SearchTabHelperTest, TitleIsSetForNTP) {
NavigateAndCommit(GURL(chrome::kChromeUINewTabURL));
EXPECT_EQ(l10n_util::GetStringUTF16(IDS_NEW_TAB_TITLE),
web_contents()->GetTitle());
}