shortcuts_provider_unittest.cc revision f2477e01787aa58f445919b809d89e252beef54f
15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved.
25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be
35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file.
45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/autocomplete/shortcuts_provider.h"
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <math.h>
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <algorithm>
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <functional>
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <set>
125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <string>
135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include <vector>
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/memory/ref_counted.h"
169ab5563a3196760eb381d102cbb2bc0f7abc6a50Ben Murdoch#include "base/message_loop/message_loop.h"
172a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "base/prefs/pref_service.h"
18868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)#include "base/strings/stringprintf.h"
19868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)#include "base/strings/utf_string_conversions.h"
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/autocomplete/autocomplete_input.h"
215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/autocomplete/autocomplete_match.h"
225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/autocomplete/autocomplete_provider.h"
235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/autocomplete/autocomplete_provider_listener.h"
24ba5b9a6411cb1792fd21f0a078d7a25cd1ceec16Ben Murdoch#include "chrome/browser/autocomplete/autocomplete_result.h"
254e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)#include "chrome/browser/chrome_notification_types.h"
262a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "chrome/browser/history/history_service.h"
275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/history/in_memory_url_index.h"
285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/history/shortcuts_backend.h"
295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/history/shortcuts_backend_factory.h"
305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/history/url_database.h"
315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/common/pref_names.h"
325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/test/base/testing_profile.h"
334e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)#include "content/public/browser/notification_service.h"
345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/public/test/test_browser_thread.h"
35f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "extensions/common/extension.h"
36f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "extensions/common/extension_builder.h"
37f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "extensions/common/value_builder.h"
385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "testing/gtest/include/gtest/gtest.h"
395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
404e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
414e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)// TestShortcutInfo -----------------------------------------------------------
425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace {
445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)struct TestShortcutInfo {
465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  std::string guid;
474e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  std::string text;
484e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  std::string fill_into_edit;
494e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  std::string destination_url;
505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  std::string contents;
515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  std::string contents_class;
525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  std::string description;
535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  std::string description_class;
544e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  content::PageTransition transition;
554e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  AutocompleteMatch::Type type;
564e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  std::string keyword;
575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  int days_from_now;
584e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  int number_of_hits;
595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} shortcut_test_db[] = {
604e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880E0", "goog", "www.google.com",
614e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://www.google.com/", "Google", "0,1,4,0", "Google", "0,3,4,1",
624e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    content::PAGE_TRANSITION_TYPED, AutocompleteMatchType::HISTORY_URL, "", 1,
634e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    100 },
644e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880E1", "slash", "slashdot.org",
654e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://slashdot.org/", "slashdot.org", "0,3,5,1",
664e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "Slashdot - News for nerds, stuff that matters", "0,2,5,0",
674e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    content::PAGE_TRANSITION_TYPED, AutocompleteMatchType::HISTORY_URL, "", 0,
684e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    100 },
694e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880E2", "news", "slashdot.org",
704e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://slashdot.org/", "slashdot.org", "0,1",
714e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "Slashdot - News for nerds, stuff that matters", "0,0,11,2,15,0",
724e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    content::PAGE_TRANSITION_TYPED, AutocompleteMatchType::HISTORY_TITLE, "", 0,
734e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    5 },
744e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880E3", "news", "sports.yahoo.com",
754e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://sports.yahoo.com/", "sports.yahoo.com", "0,1",
765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    "Yahoo! Sports - Sports News, Scores, Rumors, Fantasy Games, and more",
774e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "0,0,23,2,27,0", content::PAGE_TRANSITION_TYPED,
784e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    AutocompleteMatchType::HISTORY_TITLE, "", 2, 5 },
794e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880E4", "news weather",
804e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "www.cnn.com/index.html", "http://www.cnn.com/index.html",
815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    "www.cnn.com/index.html", "0,1",
825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    "CNN.com - Breaking News, U.S., World, Weather, Entertainment & Video",
834e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "0,0,19,2,23,0,38,2,45,0", content::PAGE_TRANSITION_TYPED,
844e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    AutocompleteMatchType::HISTORY_TITLE, "", 1, 10 },
854e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880E5", "nhl scores", "sports.yahoo.com",
864e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://sports.yahoo.com/", "sports.yahoo.com", "0,1",
875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    "Yahoo! Sports - Sports News, Scores, Rumors, Fantasy Games, and more",
884e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "0,0,29,2,35,0", content::PAGE_TRANSITION_TYPED,
894e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    AutocompleteMatchType::HISTORY_BODY, "", 1, 10 },
904e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880E6", "nhl scores",
914e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "www.nhl.com/scores/index.html", "http://www.nhl.com/scores/index.html",
925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    "www.nhl.com/scores/index.html", "0,1,4,3,7,1",
934e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "January 13, 2010 - NHL.com - Scores", "0,0,19,2,22,0,29,2,35,0",
944e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    content::PAGE_TRANSITION_TYPED, AutocompleteMatchType::HISTORY_URL, "", 5,
954e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    1 },
964e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880E7", "just", "www.testsite.com/a.html",
974e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://www.testsite.com/a.html", "www.testsite.com/a.html", "0,1",
984e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "Test - site - just a test", "0,0,14,2,18,0",
994e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    content::PAGE_TRANSITION_TYPED, AutocompleteMatchType::HISTORY_TITLE, "", 5,
1004e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    1 },
1014e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880E8", "just", "www.testsite.com/b.html",
1024e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://www.testsite.com/b.html", "www.testsite.com/b.html", "0,1",
1034e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "Test - site - just a test", "0,0,14,2,18,0",
1044e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    content::PAGE_TRANSITION_TYPED, AutocompleteMatchType::HISTORY_TITLE, "", 5,
1054e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    2 },
1064e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880E9", "just", "www.testsite.com/c.html",
1074e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://www.testsite.com/c.html", "www.testsite.com/c.html", "0,1",
1084e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "Test - site - just a test", "0,0,14,2,18,0",
1094e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    content::PAGE_TRANSITION_TYPED, AutocompleteMatchType::HISTORY_TITLE, "", 8,
1104e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    1 },
1114e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880EA", "just a", "www.testsite.com/d.html",
1124e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://www.testsite.com/d.html", "www.testsite.com/d.html", "0,1",
1134e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "Test - site - just a test", "0,0,14,2,18,0",
1144e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    content::PAGE_TRANSITION_TYPED, AutocompleteMatchType::HISTORY_TITLE, "",
1154e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    12, 1 },
1164e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880EB", "just a t",
1174e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "www.testsite.com/e.html", "http://www.testsite.com/e.html",
1184e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "www.testsite.com/e.html", "0,1", "Test - site - just a test",
1194e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "0,0,14,2,18,0", content::PAGE_TRANSITION_TYPED,
1204e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    AutocompleteMatchType::HISTORY_TITLE, "", 12, 1 },
1214e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880EC", "just a te",
1224e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "www.testsite.com/f.html", "http://www.testsite.com/f.html",
1234e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "www.testsite.com/f.html", "0,1", "Test - site - just a test",
1244e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "0,0,14,2,18,0", content::PAGE_TRANSITION_TYPED,
1254e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    AutocompleteMatchType::HISTORY_TITLE, "", 12, 1 },
1264e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880ED", "ago", "www.daysagotest.com/a.html",
1274e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://www.daysagotest.com/a.html", "www.daysagotest.com/a.html",
1284e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "0,1,8,3,11,1", "Test - site", "0,0", content::PAGE_TRANSITION_TYPED,
1294e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    AutocompleteMatchType::HISTORY_URL, "", 1, 1 },
1304e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880EE", "ago", "www.daysagotest.com/b.html",
1314e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://www.daysagotest.com/b.html", "www.daysagotest.com/b.html",
1324e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "0,1,8,3,11,1", "Test - site", "0,0", content::PAGE_TRANSITION_TYPED,
1334e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    AutocompleteMatchType::HISTORY_URL, "", 2, 1 },
1344e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880EF", "ago", "www.daysagotest.com/c.html",
1354e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://www.daysagotest.com/c.html", "www.daysagotest.com/c.html",
1364e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "0,1,8,3,11,1", "Test - site", "0,0", content::PAGE_TRANSITION_TYPED,
1374e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    AutocompleteMatchType::HISTORY_URL, "", 3, 1 },
1384e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880F0", "ago", "www.daysagotest.com/d.html",
1394e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "http://www.daysagotest.com/d.html", "www.daysagotest.com/d.html",
1404e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "0,1,8,3,11,1", "Test - site", "0,0", content::PAGE_TRANSITION_TYPED,
1414e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    AutocompleteMatchType::HISTORY_URL, "", 4, 1 },
1424e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  { "BD85DBA2-8C29-49F9-84AE-48E1E90880F1", "echo echo", "echo echo",
1434e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "chrome-extension://cedabbhfglmiikkmdgcpjdkocfcmbkee/?q=echo",
1444e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "Run Echo command: echo", "0,0", "Echo", "0,4",
1454e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    content::PAGE_TRANSITION_TYPED, AutocompleteMatchType::EXTENSION_APP,
1464e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    "echo", 1, 1 },
1475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)};
1485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}  // namespace
1505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1514e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1524e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)// ClassifyTest ---------------------------------------------------------------
1534e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1544e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)// Helper class to make running tests of ClassifyAllMatchesInString() more
1554e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)// convenient.
1564e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)class ClassifyTest {
1574e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles) public:
1584e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  ClassifyTest(const string16& text, ACMatchClassifications matches);
1594e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  ~ClassifyTest();
1604e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1614e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  ACMatchClassifications RunTest(const string16& find_text);
1624e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1634e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles) private:
1644e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  const string16 text_;
1654e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  const ACMatchClassifications matches_;
1664e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)};
1674e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1684e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)ClassifyTest::ClassifyTest(const string16& text, ACMatchClassifications matches)
1694e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    : text_(text),
1704e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      matches_(matches) {
1714e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)}
1724e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1734e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)ClassifyTest::~ClassifyTest() {
1744e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)}
1754e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1764e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)ACMatchClassifications ClassifyTest::RunTest(const string16& find_text) {
1774e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  return ShortcutsProvider::ClassifyAllMatchesInString(find_text,
1784e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      ShortcutsProvider::CreateWordMapForString(find_text), text_, matches_);
1794e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)}
1804e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1814e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)namespace history {
1824e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1834e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1844e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)// ShortcutsProviderTest ------------------------------------------------------
1854e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
1865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class ShortcutsProviderTest : public testing::Test,
1875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                              public AutocompleteProviderListener {
1885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) public:
1895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ShortcutsProviderTest();
1905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // AutocompleteProviderListener:
1925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  virtual void OnProviderUpdate(bool updated_matches) OVERRIDE;
1935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
1945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) protected:
1955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  class SetShouldContain
1965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      : public std::unary_function<const std::string&, std::set<std::string> > {
1975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)   public:
1985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    explicit SetShouldContain(const ACMatches& matched_urls);
1995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    void operator()(const std::string& expected);
2015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    std::set<std::string> Leftovers() const { return matches_; }
2025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)   private:
2045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    std::set<std::string> matches_;
2055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  };
2065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2074e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  typedef std::vector<std::string> URLs;
2084e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
2092a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  virtual void SetUp();
2102a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  virtual void TearDown();
2115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Fills test data into the provider.
2135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  void FillData(TestShortcutInfo* db, size_t db_size);
2145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Runs an autocomplete query on |text| and checks to see that the returned
2165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // results' destination URLs match those provided. |expected_urls| does not
2175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // need to be in sorted order.
2185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  void RunTest(const string16 text,
2194e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)               const URLs& expected_urls,
2205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)               std::string expected_top_result);
2215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2224e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  // Passthrough to the private function in provider_.
2234e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  int CalculateScore(const std::string& terms,
2244e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)                     const ShortcutsBackend::Shortcut& shortcut,
2254e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)                     int max_relevance);
2264e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
22790dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)  base::MessageLoopForUI message_loop_;
2285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  content::TestBrowserThread ui_thread_;
2295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  content::TestBrowserThread file_thread_;
2305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  TestingProfile profile_;
2325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatches ac_matches_;  // The resulting matches after running RunTest.
2345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  scoped_refptr<ShortcutsBackend> backend_;
2365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  scoped_refptr<ShortcutsProvider> provider_;
2375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)};
2385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)ShortcutsProviderTest::ShortcutsProviderTest()
2404e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    : ui_thread_(content::BrowserThread::UI, &message_loop_),
2414e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      file_thread_(content::BrowserThread::FILE, &message_loop_) {
2425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void ShortcutsProviderTest::OnProviderUpdate(bool updated_matches) {}
2455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void ShortcutsProviderTest::SetUp() {
2475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ShortcutsBackendFactory::GetInstance()->SetTestingFactoryAndUse(
2485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      &profile_, &ShortcutsBackendFactory::BuildProfileNoDatabaseForTesting);
2495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  backend_ = ShortcutsBackendFactory::GetForProfile(&profile_);
2505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ASSERT_TRUE(backend_.get());
251bbcdd45c55eb7c4641ab97aef9889b0fc828e7d3Ben Murdoch  ASSERT_TRUE(profile_.CreateHistoryService(true, false));
2525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  provider_ = new ShortcutsProvider(this, &profile_);
2535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  FillData(shortcut_test_db, arraysize(shortcut_test_db));
2545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void ShortcutsProviderTest::TearDown() {
2575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Run all pending tasks or else some threads hold on to the message loop
2585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // and prevent it from being deleted.
2592a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  message_loop_.RunUntilIdle();
2605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  provider_ = NULL;
2615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void ShortcutsProviderTest::FillData(TestShortcutInfo* db, size_t db_size) {
2645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(provider_.get());
2655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  size_t expected_size = backend_->shortcuts_map().size() + db_size;
2665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  for (size_t i = 0; i < db_size; ++i) {
2675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const TestShortcutInfo& cur = db[i];
2684e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    ShortcutsBackend::Shortcut shortcut(
2694e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)        cur.guid, ASCIIToUTF16(cur.text),
2704e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)        ShortcutsBackend::Shortcut::MatchCore(
2714e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            ASCIIToUTF16(cur.fill_into_edit), GURL(cur.destination_url),
2724e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            ASCIIToUTF16(cur.contents),
2734e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsFromString(cur.contents_class),
2744e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            ASCIIToUTF16(cur.description),
2754e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsFromString(cur.description_class),
2764e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            cur.transition, cur.type, ASCIIToUTF16(cur.keyword)),
2775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)        base::Time::Now() - base::TimeDelta::FromDays(cur.days_from_now),
2784e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)        cur.number_of_hits);
2795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    backend_->AddShortcut(shortcut);
2805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
2815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_EQ(expected_size, backend_->shortcuts_map().size());
2825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)ShortcutsProviderTest::SetShouldContain::SetShouldContain(
2855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const ACMatches& matched_urls) {
2865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  for (ACMatches::const_iterator iter = matched_urls.begin();
2875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)       iter != matched_urls.end(); ++iter)
2885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    matches_.insert(iter->destination_url.spec());
2895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void ShortcutsProviderTest::SetShouldContain::operator()(
2925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    const std::string& expected) {
2935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_EQ(1U, matches_.erase(expected));
2945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
2955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
2965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void ShortcutsProviderTest::RunTest(const string16 text,
2974e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)                                    const URLs& expected_urls,
2984e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)                                    std::string expected_top_result) {
29990dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)  base::MessageLoop::current()->RunUntilIdle();
300d3868032626d59662ff73b372b5d584c1d144c53Ben Murdoch  AutocompleteInput input(text, string16::npos, string16(), GURL(),
301d3868032626d59662ff73b372b5d584c1d144c53Ben Murdoch                          AutocompleteInput::INVALID_SPEC, false, false, true,
302d3868032626d59662ff73b372b5d584c1d144c53Ben Murdoch                          AutocompleteInput::ALL_MATCHES);
3035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  provider_->Start(input, false);
3045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_TRUE(provider_->done());
3055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ac_matches_ = provider_->matches();
3075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // We should have gotten back at most AutocompleteProvider::kMaxMatches.
3095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LE(ac_matches_.size(), AutocompleteProvider::kMaxMatches);
3105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // If the number of expected and actual matches aren't equal then we need
3125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // test no further, but let's do anyway so that we know which URLs failed.
3135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_EQ(expected_urls.size(), ac_matches_.size());
3145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Verify that all expected URLs were found and that all found URLs
3165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // were expected.
3175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  std::set<std::string> Leftovers =
3185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      for_each(expected_urls.begin(), expected_urls.end(),
3195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)               SetShouldContain(ac_matches_)).Leftovers();
3205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_EQ(0U, Leftovers.size());
3215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // See if we got the expected top scorer.
3235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (!ac_matches_.empty()) {
3245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    std::partial_sort(ac_matches_.begin(), ac_matches_.begin() + 1,
3255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                      ac_matches_.end(), AutocompleteMatch::MoreRelevant);
3265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    EXPECT_EQ(expected_top_result, ac_matches_[0].destination_url.spec());
3275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
328c2db58bd994c04d98e4ee2cd7565b71548655fe3Ben Murdoch
329c2db58bd994c04d98e4ee2cd7565b71548655fe3Ben Murdoch  // No shortcuts matches are allowed to be inlined no matter how highly
330c2db58bd994c04d98e4ee2cd7565b71548655fe3Ben Murdoch  // they score.
331c2db58bd994c04d98e4ee2cd7565b71548655fe3Ben Murdoch  for (ACMatches::const_iterator it = ac_matches_.begin();
332c2db58bd994c04d98e4ee2cd7565b71548655fe3Ben Murdoch       it != ac_matches_.end(); ++it)
333c2db58bd994c04d98e4ee2cd7565b71548655fe3Ben Murdoch    EXPECT_FALSE(it->allowed_to_be_default_match);
3345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
3355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3364e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)int ShortcutsProviderTest::CalculateScore(
3374e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    const std::string& terms,
3384e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    const ShortcutsBackend::Shortcut& shortcut,
3394e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    int max_relevance) {
3404e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  return provider_->CalculateScore(ASCIIToUTF16(terms), shortcut,
3414e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)                                   max_relevance);
3424e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)}
3434e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
3444e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
3454e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)// Actual tests ---------------------------------------------------------------
3464e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
3475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)TEST_F(ShortcutsProviderTest, SimpleSingleMatch) {
3485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  string16 text(ASCIIToUTF16("go"));
3495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  std::string expected_url("http://www.google.com/");
3504e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  URLs expected_urls;
3515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back(expected_url);
3525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  RunTest(text, expected_urls, expected_url);
3535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
3545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)TEST_F(ShortcutsProviderTest, MultiMatch) {
3565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  string16 text(ASCIIToUTF16("NEWS"));
3574e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  URLs expected_urls;
3585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Scores high because of completion length.
3595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://slashdot.org/");
3605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Scores high because of visit count.
3615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://sports.yahoo.com/");
3625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Scores high because of visit count but less match span,
3635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // which is more important.
3645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://www.cnn.com/index.html");
3655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  RunTest(text, expected_urls, "http://slashdot.org/");
3665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
3675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)TEST_F(ShortcutsProviderTest, TypedCountMatches) {
3695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  string16 text(ASCIIToUTF16("just"));
3704e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  URLs expected_urls;
3715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://www.testsite.com/b.html");
3725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://www.testsite.com/a.html");
3735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://www.testsite.com/c.html");
3745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  RunTest(text, expected_urls, "http://www.testsite.com/b.html");
3755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
3765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)TEST_F(ShortcutsProviderTest, FragmentLengthMatches) {
3785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  string16 text(ASCIIToUTF16("just a"));
3794e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  URLs expected_urls;
3805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://www.testsite.com/d.html");
3815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://www.testsite.com/e.html");
3825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://www.testsite.com/f.html");
3835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  RunTest(text, expected_urls, "http://www.testsite.com/d.html");
3845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
3855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)TEST_F(ShortcutsProviderTest, DaysAgoMatches) {
3875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  string16 text(ASCIIToUTF16("ago"));
3884e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  URLs expected_urls;
3895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://www.daysagotest.com/a.html");
3905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://www.daysagotest.com/b.html");
3915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  expected_urls.push_back("http://www.daysagotest.com/c.html");
3925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  RunTest(text, expected_urls, "http://www.daysagotest.com/a.html");
3935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
3945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
3955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)TEST_F(ShortcutsProviderTest, ClassifyAllMatchesInString) {
3964e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  ACMatchClassifications matches =
3974e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      AutocompleteMatch::ClassificationsFromString("0,0");
3985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ClassifyTest classify_test(ASCIIToUTF16("A man, a plan, a canal Panama"),
3995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                             matches);
4005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_a = classify_test.RunTest(ASCIIToUTF16("man"));
4025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // ACMatch spans should be: '--MMM------------------------'
4034e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,0,2,2,5,0", AutocompleteMatch::ClassificationsToString(spans_a));
4045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_b = classify_test.RunTest(ASCIIToUTF16("man p"));
4065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // ACMatch spans should be: '--MMM----M-------------M-----'
4074e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,0,2,2,5,0,9,2,10,0,23,2,24,0",
4084e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsToString(spans_b));
4095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_c =
4115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      classify_test.RunTest(ASCIIToUTF16("man plan panama"));
4125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // ACMatch spans should be:'--MMM----MMMM----------MMMMMM'
4134e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,0,2,2,5,0,9,2,13,0,23,2",
4144e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsToString(spans_c));
4155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ClassifyTest classify_test2(ASCIIToUTF16("Yahoo! Sports - Sports News, "
4175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      "Scores, Rumors, Fantasy Games, and more"), matches);
4185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_d = classify_test2.RunTest(ASCIIToUTF16("ne"));
4205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // ACMatch spans should match first two letters of the "news".
4214e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,0,23,2,25,0",
4224e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsToString(spans_d));
4235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_e =
4255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      classify_test2.RunTest(ASCIIToUTF16("news r"));
4264e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,0,10,2,11,0,19,2,20,0,23,2,27,0,32,2,33,0,37,2,38,0,41,2,42,0,"
4274e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            "66,2,67,0", AutocompleteMatch::ClassificationsToString(spans_e));
4284e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
4294e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  matches = AutocompleteMatch::ClassificationsFromString("0,1");
4305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ClassifyTest classify_test3(ASCIIToUTF16("livescore.goal.com"), matches);
4315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_f = classify_test3.RunTest(ASCIIToUTF16("go"));
4335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // ACMatch spans should match first two letters of the "goal".
4344e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,1,10,3,12,1",
4354e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsToString(spans_f));
4364e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
4374e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  matches = AutocompleteMatch::ClassificationsFromString("0,0,13,1");
4385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ClassifyTest classify_test4(ASCIIToUTF16("Email login: mail.somecorp.com"),
4395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)                              matches);
4405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_g = classify_test4.RunTest(ASCIIToUTF16("ail"));
4424e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,0,2,2,5,0,13,1,14,3,17,1",
4434e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsToString(spans_g));
4445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_h =
4465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      classify_test4.RunTest(ASCIIToUTF16("lo log"));
4474e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,0,6,2,9,0,13,1",
4484e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsToString(spans_h));
4495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_i =
4515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      classify_test4.RunTest(ASCIIToUTF16("ail em"));
4525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // 'Email' and 'ail' should be matched.
4534e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,2,5,0,13,1,14,3,17,1",
4544e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsToString(spans_i));
4555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Some web sites do not have a description.  If the string being searched is
4575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // empty, the classifications must also be empty: http://crbug.com/148647
4585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Extra parens in the next line hack around C++03's "most vexing parse".
4595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  class ClassifyTest classify_test5((string16()), ACMatchClassifications());
4605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_j = classify_test5.RunTest(ASCIIToUTF16("man"));
4615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ASSERT_EQ(0U, spans_j.size());
4625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Matches which end at beginning of classification merge properly.
4644e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  matches = AutocompleteMatch::ClassificationsFromString("0,4,9,0");
4655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ClassifyTest classify_test6(ASCIIToUTF16("html password example"), matches);
4665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Extra space in the next string avoids having the string be a prefix of the
4685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // text above, which would allow for two different valid classification sets,
4695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // one of which uses two spans (the first of which would mark all of "html
4705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // pass" as a match) and one which uses four (which marks the individual words
4715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // as matches but not the space between them).  This way only the latter is
4725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // valid.
4735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_k =
4745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      classify_test6.RunTest(ASCIIToUTF16("html  pass"));
4754e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,6,4,4,5,6,9,0",
4764e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsToString(spans_k));
4775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Multiple matches with both beginning and end at beginning of
4795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // classifications merge properly.
4804e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  matches = AutocompleteMatch::ClassificationsFromString("0,1,11,0");
4815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ClassifyTest classify_test7(ASCIIToUTF16("http://a.co is great"), matches);
4825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ACMatchClassifications spans_l =
4845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      classify_test7.RunTest(ASCIIToUTF16("ht co"));
4854e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ("0,3,2,1,9,3,11,0",
4864e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)            AutocompleteMatch::ClassificationsToString(spans_l));
4875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
4885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
4895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)TEST_F(ShortcutsProviderTest, CalculateScore) {
4904e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  ShortcutsBackend::Shortcut shortcut(
4914e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      std::string(), ASCIIToUTF16("test"),
4924e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      ShortcutsBackend::Shortcut::MatchCore(
4934e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)          ASCIIToUTF16("www.test.com"), GURL("http://www.test.com"),
4944e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)          ASCIIToUTF16("www.test.com"),
4954e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)          AutocompleteMatch::ClassificationsFromString("0,1,4,3,8,1"),
4964e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)          ASCIIToUTF16("A test"),
4974e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)          AutocompleteMatch::ClassificationsFromString("0,0,2,2"),
4984e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)          content::PAGE_TRANSITION_TYPED, AutocompleteMatchType::HISTORY_URL,
4994e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)          string16()),
5004e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      base::Time::Now(), 1);
5015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Maximal score.
503ba5b9a6411cb1792fd21f0a078d7a25cd1ceec16Ben Murdoch  const int max_relevance = AutocompleteResult::kLowestDefaultScore - 1;
5044e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  const int kMaxScore = CalculateScore("test", shortcut, max_relevance);
5055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Score decreases as percent of the match is decreased.
5074e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  int score_three_quarters = CalculateScore("tes", shortcut, max_relevance);
5085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LT(score_three_quarters, kMaxScore);
5094e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  int score_one_half = CalculateScore("te", shortcut, max_relevance);
5105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LT(score_one_half, score_three_quarters);
5114e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  int score_one_quarter = CalculateScore("t", shortcut, max_relevance);
5125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LT(score_one_quarter, score_one_half);
5135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Should decay with time - one week.
5155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  shortcut.last_access_time = base::Time::Now() - base::TimeDelta::FromDays(7);
5164e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  int score_week_old = CalculateScore("test", shortcut, max_relevance);
5175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LT(score_week_old, kMaxScore);
5185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Should decay more in two weeks.
5205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  shortcut.last_access_time = base::Time::Now() - base::TimeDelta::FromDays(14);
5214e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  int score_two_weeks_old = CalculateScore("test", shortcut, max_relevance);
5225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LT(score_two_weeks_old, score_week_old);
5235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // But not if it was activly clicked on. 2 hits slow decaying power.
5255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  shortcut.number_of_hits = 2;
5265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  shortcut.last_access_time = base::Time::Now() - base::TimeDelta::FromDays(14);
5275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  int score_popular_two_weeks_old =
5284e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      CalculateScore("test", shortcut, max_relevance);
5295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LT(score_two_weeks_old, score_popular_two_weeks_old);
5305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // But still decayed.
5315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LT(score_popular_two_weeks_old, kMaxScore);
5325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // 3 hits slow decaying power even more.
5345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  shortcut.number_of_hits = 3;
5355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  shortcut.last_access_time = base::Time::Now() - base::TimeDelta::FromDays(14);
5365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  int score_more_popular_two_weeks_old =
5374e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      CalculateScore("test", shortcut, max_relevance);
5385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LT(score_two_weeks_old, score_more_popular_two_weeks_old);
5395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LT(score_popular_two_weeks_old, score_more_popular_two_weeks_old);
5405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // But still decayed.
5415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_LT(score_more_popular_two_weeks_old, kMaxScore);
5425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
5435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)TEST_F(ShortcutsProviderTest, DeleteMatch) {
5454e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  TestShortcutInfo shortcuts_to_test_delete[] = {
5464e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    { "BD85DBA2-8C29-49F9-84AE-48E1E90881F1", "delete", "www.deletetest.com/1",
5474e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      "http://www.deletetest.com/1", "http://www.deletetest.com/1", "0,2",
5484e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      "Erase this shortcut!", "0,0", content::PAGE_TRANSITION_TYPED,
5494e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      AutocompleteMatchType::HISTORY_URL, "", 1, 1},
5504e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    { "BD85DBA2-8C29-49F9-84AE-48E1E90881F2", "erase", "www.deletetest.com/1",
5514e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      "http://www.deletetest.com/1", "http://www.deletetest.com/1", "0,2",
5524e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      "Erase this shortcut!", "0,0", content::PAGE_TRANSITION_TYPED,
5534e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      AutocompleteMatchType::HISTORY_TITLE, "", 1, 1},
5544e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    { "BD85DBA2-8C29-49F9-84AE-48E1E90881F3", "keep", "www.deletetest.com/1/2",
5554e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      "http://www.deletetest.com/1/2", "http://www.deletetest.com/1/2", "0,2",
5564e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      "Keep this shortcut!", "0,0", content::PAGE_TRANSITION_TYPED,
5574e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      AutocompleteMatchType::HISTORY_TITLE, "", 1, 1},
5584e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)    { "BD85DBA2-8C29-49F9-84AE-48E1E90881F4", "delete", "www.deletetest.com/2",
5594e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      "http://www.deletetest.com/2", "http://www.deletetest.com/2", "0,2",
5604e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      "Erase this shortcut!", "0,0", content::PAGE_TRANSITION_TYPED,
5614e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      AutocompleteMatchType::HISTORY_URL, "", 1, 1},
5625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  };
5635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  size_t original_shortcuts_count = backend_->shortcuts_map().size();
5655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  FillData(shortcuts_to_test_delete, arraysize(shortcuts_to_test_delete));
5675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5684e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ(original_shortcuts_count + 4, backend_->shortcuts_map().size());
5695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_FALSE(backend_->shortcuts_map().end() ==
5705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)               backend_->shortcuts_map().find(ASCIIToUTF16("delete")));
5715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_FALSE(backend_->shortcuts_map().end() ==
5725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)               backend_->shortcuts_map().find(ASCIIToUTF16("erase")));
5735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
574868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  AutocompleteMatch match(
575868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)      provider_.get(), 1200, true, AutocompleteMatchType::HISTORY_TITLE);
5765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5774e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  match.destination_url = GURL(shortcuts_to_test_delete[0].destination_url);
5785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  match.contents = ASCIIToUTF16(shortcuts_to_test_delete[0].contents);
5795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  match.description = ASCIIToUTF16(shortcuts_to_test_delete[0].description);
5805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  provider_->DeleteMatch(match);
5825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5834e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  // shortcuts_to_test_delete[0] and shortcuts_to_test_delete[1] should be
5844e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  // deleted, but not shortcuts_to_test_delete[2] or
5854e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  // shortcuts_to_test_delete[3], which have different URLs.
5864e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ(original_shortcuts_count + 2, backend_->shortcuts_map().size());
5875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_FALSE(backend_->shortcuts_map().end() ==
5885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)               backend_->shortcuts_map().find(ASCIIToUTF16("delete")));
5895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_TRUE(backend_->shortcuts_map().end() ==
5905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)              backend_->shortcuts_map().find(ASCIIToUTF16("erase")));
5915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5924e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  match.destination_url = GURL(shortcuts_to_test_delete[3].destination_url);
5934e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  match.contents = ASCIIToUTF16(shortcuts_to_test_delete[3].contents);
5944e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  match.description = ASCIIToUTF16(shortcuts_to_test_delete[3].description);
5955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
5965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  provider_->DeleteMatch(match);
5974e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  EXPECT_EQ(original_shortcuts_count + 1, backend_->shortcuts_map().size());
5985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  EXPECT_TRUE(backend_->shortcuts_map().end() ==
5995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)              backend_->shortcuts_map().find(ASCIIToUTF16("delete")));
6005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
6014e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
6024e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)TEST_F(ShortcutsProviderTest, Extension) {
6034e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  // Try an input string that matches an extension URL.
6044e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  string16 text(ASCIIToUTF16("echo"));
6054e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  std::string expected_url(
6064e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      "chrome-extension://cedabbhfglmiikkmdgcpjdkocfcmbkee/?q=echo");
6074e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  URLs expected_urls;
6084e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  expected_urls.push_back(expected_url);
6094e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  RunTest(text, expected_urls, expected_url);
6104e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
6114e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  // Claim the extension has been unloaded.
6124e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  scoped_refptr<const extensions::Extension> extension =
6134e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      extensions::ExtensionBuilder()
6144e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)          .SetManifest(extensions::DictionaryBuilder()
6154e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)              .Set("name", "Echo")
6164e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)              .Set("version", "1.0"))
6174e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)          .SetID("cedabbhfglmiikkmdgcpjdkocfcmbkee")
6184e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)          .Build();
6194e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  extensions::UnloadedExtensionInfo details(
6201e9bf3e0803691d0a228da41fc608347b6db4340Torne (Richard Coles)      extension.get(), extensions::UnloadedExtensionInfo::REASON_UNINSTALL);
6214e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  content::NotificationService::current()->Notify(
6224e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      chrome::NOTIFICATION_EXTENSION_UNLOADED,
6234e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      content::Source<Profile>(&profile_),
6244e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)      content::Details<extensions::UnloadedExtensionInfo>(&details));
6254e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
6264e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  // Now the URL should have disappeared.
6274e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)  RunTest(text, URLs(), std::string());
6284e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)}
6294e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)
6304e180b6a0b4720a9b8e9e959a882386f690f08ffTorne (Richard Coles)}  // namespace history
631