Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include <vector> | 5 #include <vector> |
| 6 | 6 |
| 7 #include "base/scoped_temp_dir.h" | |
| 7 #include "chrome/browser/spellchecker/spellcheck_host.h" | 8 #include "chrome/browser/spellchecker/spellcheck_host.h" |
| 8 #include "chrome/browser/spellchecker/spellcheck_profile.h" | 9 #include "chrome/browser/spellchecker/spellcheck_profile.h" |
| 9 #include "content/browser/browser_thread.h" | 10 #include "content/browser/browser_thread.h" |
| 10 #include "testing/gmock/include/gmock/gmock.h" | 11 #include "testing/gmock/include/gmock/gmock.h" |
| 11 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
| 12 | 13 |
| 13 namespace { | 14 namespace { |
| 14 | 15 |
| 15 class MockSpellCheckHost : public SpellCheckHost { | 16 class MockSpellCheckHost : public SpellCheckHost { |
| 16 public: | 17 public: |
| 17 MOCK_METHOD0(UnsetProfile, void()); | 18 MOCK_METHOD0(UnsetProfile, void()); |
| 18 MOCK_METHOD1(InitForRenderer, void(RenderProcessHost* process)); | 19 MOCK_METHOD1(InitForRenderer, void(RenderProcessHost* process)); |
| 19 MOCK_METHOD1(AddWord, void(const std::string& word)); | 20 MOCK_METHOD1(AddWord, void(const std::string& word)); |
| 20 MOCK_CONST_METHOD0(GetDictionaryFile, const base::PlatformFile&()); | 21 MOCK_CONST_METHOD0(GetDictionaryFile, const base::PlatformFile&()); |
| 21 MOCK_CONST_METHOD0(GetCustomWords, | 22 MOCK_CONST_METHOD0(GetCustomWords, |
| 22 const SpellCheckProfile::CustomWordList&()); | 23 const SpellCheckProfile::CustomWordList&()); |
| 23 MOCK_CONST_METHOD0(GetLastAddedFile, const std::string&()); | 24 MOCK_CONST_METHOD0(GetLastAddedFile, const std::string&()); |
| 24 MOCK_CONST_METHOD0(GetLanguage, const std::string&()); | 25 MOCK_CONST_METHOD0(GetLanguage, const std::string&()); |
| 25 MOCK_CONST_METHOD0(IsUsingPlatformChecker, bool()); | 26 MOCK_CONST_METHOD0(IsUsingPlatformChecker, bool()); |
| 26 MOCK_CONST_METHOD0(GetMetrics, SpellCheckHostMetrics*()); | 27 MOCK_CONST_METHOD0(GetMetrics, SpellCheckHostMetrics*()); |
| 27 MOCK_CONST_METHOD0(IsReady, bool()); | 28 MOCK_CONST_METHOD0(IsReady, bool()); |
| 28 }; | 29 }; |
| 29 | 30 |
| 30 class TestingSpellCheckProfile : public SpellCheckProfile { | 31 class TestingSpellCheckProfile : public SpellCheckProfile { |
| 31 public: | 32 public: |
| 32 TestingSpellCheckProfile() | 33 explicit TestingSpellCheckProfile(const FilePath& profile_dir) |
| 33 : create_host_calls_(0) { | 34 : SpellCheckProfile(profile_dir), |
| 35 create_host_calls_(0) { | |
| 34 } | 36 } |
| 35 | 37 |
| 36 virtual SpellCheckHost* CreateHost( | 38 virtual SpellCheckHost* CreateHost( |
| 37 SpellCheckProfileProvider* profile, | 39 SpellCheckProfileProvider* profile, |
| 38 const std::string& language, | 40 const std::string& language, |
| 39 net::URLRequestContextGetter* request_context, | 41 net::URLRequestContextGetter* request_context, |
| 40 SpellCheckHostMetrics* metrics) { | 42 SpellCheckHostMetrics* metrics) { |
| 41 create_host_calls_++; | 43 create_host_calls_++; |
| 42 return returning_from_create_.get(); | 44 return returning_from_create_.get(); |
| 43 } | 45 } |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 68 SpellCheckProfileTest() | 70 SpellCheckProfileTest() |
| 69 : file_thread_(BrowserThread::FILE) { | 71 : file_thread_(BrowserThread::FILE) { |
| 70 } | 72 } |
| 71 | 73 |
| 72 // SpellCheckHost will be deleted on FILE thread. | 74 // SpellCheckHost will be deleted on FILE thread. |
| 73 BrowserThread file_thread_; | 75 BrowserThread file_thread_; |
| 74 }; | 76 }; |
| 75 | 77 |
| 76 TEST_F(SpellCheckProfileTest, ReinitializeEnabled) { | 78 TEST_F(SpellCheckProfileTest, ReinitializeEnabled) { |
| 77 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); | 79 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); |
| 78 TestingSpellCheckProfile target; | 80 ScopedTempDir dir; |
| 81 ASSERT_TRUE(dir.CreateUniqueTempDir()); | |
| 82 TestingSpellCheckProfile target(dir.path()); | |
| 79 target.SetHostToBeCreated(host.get()); | 83 target.SetHostToBeCreated(host.get()); |
| 80 | 84 |
| 81 // The first call should create host. | 85 // The first call should create host. |
| 82 ResultType result1 = target.ReinitializeHost(false, true, "", NULL); | 86 ResultType result1 = target.ReinitializeHost(false, true, "", NULL); |
| 83 EXPECT_EQ(target.create_host_calls_, 1U); | 87 EXPECT_EQ(target.create_host_calls_, 1U); |
| 84 EXPECT_EQ(result1, SpellCheckProfile::REINITIALIZE_CREATED_HOST); | 88 EXPECT_EQ(result1, SpellCheckProfile::REINITIALIZE_CREATED_HOST); |
| 85 | 89 |
| 86 // The second call should be ignored. | 90 // The second call should be ignored. |
| 87 ResultType result2 = target.ReinitializeHost(false, true, "", NULL); | 91 ResultType result2 = target.ReinitializeHost(false, true, "", NULL); |
| 88 EXPECT_EQ(result2, SpellCheckProfile::REINITIALIZE_DID_NOTHING); | 92 EXPECT_EQ(result2, SpellCheckProfile::REINITIALIZE_DID_NOTHING); |
| 89 EXPECT_EQ(target.create_host_calls_, 1U); | 93 EXPECT_EQ(target.create_host_calls_, 1U); |
| 90 | 94 |
| 91 // Host should become ready after the notification. | 95 // Host should become ready after the notification. |
| 92 EXPECT_FALSE(target.IsCreatedHostReady()); | 96 EXPECT_FALSE(target.IsCreatedHostReady()); |
| 93 target.SpellCheckHostInitialized(0); | 97 target.SpellCheckHostInitialized(0); |
| 94 EXPECT_TRUE(target.IsCreatedHostReady()); | 98 EXPECT_TRUE(target.IsCreatedHostReady()); |
| 95 } | 99 } |
| 96 | 100 |
| 97 TEST_F(SpellCheckProfileTest, ReinitializeDisabled) { | 101 TEST_F(SpellCheckProfileTest, ReinitializeDisabled) { |
| 98 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); | 102 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); |
| 99 TestingSpellCheckProfile target; | 103 ScopedTempDir dir; |
| 104 ASSERT_TRUE(dir.CreateUniqueTempDir()); | |
| 105 TestingSpellCheckProfile target(dir.path()); | |
| 106 | |
| 100 target.returning_from_create_ = host.get(); | 107 target.returning_from_create_ = host.get(); |
| 101 | 108 |
| 102 // If enabled is false, nothing should happen | 109 // If enabled is false, nothing should happen |
| 103 ResultType result1 = target.ReinitializeHost(false, false, "", NULL); | 110 ResultType result1 = target.ReinitializeHost(false, false, "", NULL); |
| 104 EXPECT_EQ(target.create_host_calls_, 0U); | 111 EXPECT_EQ(target.create_host_calls_, 0U); |
| 105 EXPECT_EQ(result1, SpellCheckProfile::REINITIALIZE_DID_NOTHING); | 112 EXPECT_EQ(result1, SpellCheckProfile::REINITIALIZE_DID_NOTHING); |
| 106 | 113 |
| 107 // Nothing should happen even if forced. | 114 // Nothing should happen even if forced. |
| 108 ResultType result2 = target.ReinitializeHost(true, false, "", NULL); | 115 ResultType result2 = target.ReinitializeHost(true, false, "", NULL); |
| 109 EXPECT_EQ(target.create_host_calls_, 0U); | 116 EXPECT_EQ(target.create_host_calls_, 0U); |
| 110 EXPECT_EQ(result2, SpellCheckProfile::REINITIALIZE_DID_NOTHING); | 117 EXPECT_EQ(result2, SpellCheckProfile::REINITIALIZE_DID_NOTHING); |
| 111 } | 118 } |
| 112 | 119 |
| 113 TEST_F(SpellCheckProfileTest, ReinitializeRemove) { | 120 TEST_F(SpellCheckProfileTest, ReinitializeRemove) { |
| 114 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); | 121 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); |
| 115 TestingSpellCheckProfile target; | 122 ScopedTempDir dir; |
| 123 ASSERT_TRUE(dir.CreateUniqueTempDir()); | |
| 124 TestingSpellCheckProfile target(dir.path()); | |
| 125 | |
| 116 target.SetHostToBeCreated(host.get()); | 126 target.SetHostToBeCreated(host.get()); |
| 117 | 127 |
| 118 | |
| 119 // At first, create the host. | 128 // At first, create the host. |
| 120 ResultType result1 = target.ReinitializeHost(false, true, "", NULL); | 129 ResultType result1 = target.ReinitializeHost(false, true, "", NULL); |
| 121 target.SpellCheckHostInitialized(0); | 130 target.SpellCheckHostInitialized(0); |
| 122 EXPECT_EQ(result1, SpellCheckProfile::REINITIALIZE_CREATED_HOST); | 131 EXPECT_EQ(result1, SpellCheckProfile::REINITIALIZE_CREATED_HOST); |
| 123 EXPECT_TRUE(target.IsCreatedHostReady()); | 132 EXPECT_TRUE(target.IsCreatedHostReady()); |
| 124 | 133 |
| 125 // Then the host should be deleted if it's forced to be disabled. | 134 // Then the host should be deleted if it's forced to be disabled. |
| 126 ResultType result2 = target.ReinitializeHost(true, false, "", NULL); | 135 ResultType result2 = target.ReinitializeHost(true, false, "", NULL); |
| 127 target.SpellCheckHostInitialized(0); | 136 target.SpellCheckHostInitialized(0); |
| 128 EXPECT_EQ(result2, SpellCheckProfile::REINITIALIZE_REMOVED_HOST); | 137 EXPECT_EQ(result2, SpellCheckProfile::REINITIALIZE_REMOVED_HOST); |
| 129 EXPECT_FALSE(target.IsCreatedHostReady()); | 138 EXPECT_FALSE(target.IsCreatedHostReady()); |
| 130 } | 139 } |
| 131 | 140 |
| 132 TEST_F(SpellCheckProfileTest, ReinitializeRecreate) { | 141 TEST_F(SpellCheckProfileTest, ReinitializeRecreate) { |
| 133 scoped_refptr<MockSpellCheckHost> host1(new MockSpellCheckHost()); | 142 scoped_refptr<MockSpellCheckHost> host1(new MockSpellCheckHost()); |
| 134 TestingSpellCheckProfile target; | 143 ScopedTempDir dir; |
| 144 ASSERT_TRUE(dir.CreateUniqueTempDir()); | |
| 145 TestingSpellCheckProfile target(dir.path()); | |
| 146 | |
| 135 target.SetHostToBeCreated(host1.get()); | 147 target.SetHostToBeCreated(host1.get()); |
| 136 | 148 |
| 137 // At first, create the host. | 149 // At first, create the host. |
| 138 ResultType result1 = target.ReinitializeHost(false, true, "", NULL); | 150 ResultType result1 = target.ReinitializeHost(false, true, "", NULL); |
| 139 target.SpellCheckHostInitialized(0); | 151 target.SpellCheckHostInitialized(0); |
| 140 EXPECT_EQ(target.create_host_calls_, 1U); | 152 EXPECT_EQ(target.create_host_calls_, 1U); |
| 141 EXPECT_EQ(result1, SpellCheckProfile::REINITIALIZE_CREATED_HOST); | 153 EXPECT_EQ(result1, SpellCheckProfile::REINITIALIZE_CREATED_HOST); |
| 142 EXPECT_TRUE(target.IsCreatedHostReady()); | 154 EXPECT_TRUE(target.IsCreatedHostReady()); |
| 143 | 155 |
| 144 // Then the host should be re-created if it's forced to recreate. | 156 // Then the host should be re-created if it's forced to recreate. |
| 145 scoped_refptr<MockSpellCheckHost> host2(new MockSpellCheckHost()); | 157 scoped_refptr<MockSpellCheckHost> host2(new MockSpellCheckHost()); |
| 146 target.SetHostToBeCreated(host2.get()); | 158 target.SetHostToBeCreated(host2.get()); |
| 147 | 159 |
| 148 ResultType result2 = target.ReinitializeHost(true, true, "", NULL); | 160 ResultType result2 = target.ReinitializeHost(true, true, "", NULL); |
| 149 target.SpellCheckHostInitialized(0); | 161 target.SpellCheckHostInitialized(0); |
| 150 EXPECT_EQ(target.create_host_calls_, 2U); | 162 EXPECT_EQ(target.create_host_calls_, 2U); |
| 151 EXPECT_EQ(result2, SpellCheckProfile::REINITIALIZE_CREATED_HOST); | 163 EXPECT_EQ(result2, SpellCheckProfile::REINITIALIZE_CREATED_HOST); |
| 152 EXPECT_TRUE(target.IsCreatedHostReady()); | 164 EXPECT_TRUE(target.IsCreatedHostReady()); |
| 153 } | 165 } |
| 154 | 166 |
| 155 TEST_F(SpellCheckProfileTest, SpellCheckHostInitializedWithCustomWords) { | 167 TEST_F(SpellCheckProfileTest, SpellCheckHostInitializedWithCustomWords) { |
| 156 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); | 168 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); |
| 157 TestingSpellCheckProfile target; | 169 ScopedTempDir dir; |
| 170 ASSERT_TRUE(dir.CreateUniqueTempDir()); | |
| 171 TestingSpellCheckProfile target(dir.path()); | |
| 172 | |
| 158 target.SetHostToBeCreated(host.get()); | 173 target.SetHostToBeCreated(host.get()); |
| 159 target.ReinitializeHost(false, true, "", NULL); | 174 target.ReinitializeHost(false, true, "", NULL); |
| 160 | 175 |
| 161 scoped_ptr<SpellCheckProfile::CustomWordList> loaded_custom_words | 176 scoped_ptr<SpellCheckProfile::CustomWordList> loaded_custom_words |
| 162 (new SpellCheckProfile::CustomWordList()); | 177 (new SpellCheckProfile::CustomWordList()); |
| 163 loaded_custom_words->push_back("foo"); | 178 loaded_custom_words->push_back("foo"); |
| 164 loaded_custom_words->push_back("bar"); | 179 loaded_custom_words->push_back("bar"); |
| 165 SpellCheckProfile::CustomWordList expected(*loaded_custom_words); | 180 SpellCheckProfile::CustomWordList expected(*loaded_custom_words); |
| 166 target.SpellCheckHostInitialized(loaded_custom_words.release()); | 181 target.SpellCheckHostInitialized(loaded_custom_words.release()); |
| 167 EXPECT_EQ(target.GetCustomWords(), expected); | 182 EXPECT_EQ(target.GetCustomWords(), expected); |
| 168 } | 183 } |
| 169 | 184 |
| 170 TEST_F(SpellCheckProfileTest, CustomWordAddedLocally) { | 185 TEST_F(SpellCheckProfileTest, CustomWordAddedLocally) { |
| 171 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); | 186 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); |
| 172 TestingSpellCheckProfile target; | 187 ScopedTempDir dir; |
| 188 ASSERT_TRUE(dir.CreateUniqueTempDir()); | |
| 189 TestingSpellCheckProfile target(dir.path()); | |
| 190 | |
| 173 target.SetHostToBeCreated(host.get()); | 191 target.SetHostToBeCreated(host.get()); |
| 174 target.ReinitializeHost(false, true, "", NULL); | 192 target.ReinitializeHost(false, true, "", NULL); |
| 175 | 193 |
| 176 scoped_ptr<SpellCheckProfile::CustomWordList> loaded_custom_words | 194 scoped_ptr<SpellCheckProfile::CustomWordList> loaded_custom_words |
| 177 (new SpellCheckProfile::CustomWordList()); | 195 (new SpellCheckProfile::CustomWordList()); |
| 178 target.SpellCheckHostInitialized(NULL); | 196 target.SpellCheckHostInitialized(NULL); |
| 179 SpellCheckProfile::CustomWordList expected; | 197 SpellCheckProfile::CustomWordList expected; |
| 180 EXPECT_EQ(target.GetCustomWords(), expected); | 198 EXPECT_EQ(target.GetCustomWords(), expected); |
| 181 target.CustomWordAddedLocally("foo"); | 199 target.CustomWordAddedLocally("foo"); |
| 182 expected.push_back("foo"); | 200 expected.push_back("foo"); |
| 183 EXPECT_EQ(target.GetCustomWords(), expected); | 201 EXPECT_EQ(target.GetCustomWords(), expected); |
| 184 target.CustomWordAddedLocally("bar"); | 202 target.CustomWordAddedLocally("bar"); |
| 185 expected.push_back("bar"); | 203 expected.push_back("bar"); |
| 186 EXPECT_EQ(target.GetCustomWords(), expected); | 204 EXPECT_EQ(target.GetCustomWords(), expected); |
| 187 } | 205 } |
| 206 | |
| 207 TEST_F(SpellCheckProfileTest, SaveAndLoad) { | |
| 208 scoped_refptr<MockSpellCheckHost> host(new MockSpellCheckHost()); | |
| 209 ScopedTempDir dir; | |
| 210 ASSERT_TRUE(dir.CreateUniqueTempDir()); | |
| 211 TestingSpellCheckProfile target(dir.path()); | |
| 212 | |
| 213 target.SetHostToBeCreated(host.get()); | |
| 214 target.ReinitializeHost(false, true, "", NULL); | |
| 215 | |
| 216 scoped_ptr<SpellCheckProfile::CustomWordList> loaded_custom_words( | |
| 217 new SpellCheckProfile::CustomWordList()); | |
| 218 target.LoadCustomDictionary(loaded_custom_words.get()); | |
| 219 | |
| 220 // The custom word list should be empty now. | |
| 221 SpellCheckProfile::CustomWordList expected; | |
| 222 EXPECT_EQ(*loaded_custom_words, expected); | |
| 223 | |
| 224 target.WriteWordToCustomDictionary("foo"); | |
| 225 expected.push_back("foo"); | |
| 226 | |
| 227 target.WriteWordToCustomDictionary("bar"); | |
| 228 expected.push_back("bar"); | |
| 229 | |
| 230 // The custom word list should include written words. | |
| 231 target.LoadCustomDictionary(loaded_custom_words.get()); | |
| 232 EXPECT_EQ(*loaded_custom_words, expected); | |
|
gmorrita
2011/10/19 05:27:37
Coud you add some more lines,
to verify these newl
shinyak (Google)
2011/10/19 05:55:04
Done.
| |
| 233 } | |
| 234 | |
| 235 TEST_F(SpellCheckProfileTest, MultiProfile) { | |
| 236 scoped_refptr<MockSpellCheckHost> host1(new MockSpellCheckHost()); | |
| 237 scoped_refptr<MockSpellCheckHost> host2(new MockSpellCheckHost()); | |
| 238 | |
| 239 ScopedTempDir dir1; | |
| 240 ScopedTempDir dir2; | |
| 241 ASSERT_TRUE(dir1.CreateUniqueTempDir()); | |
| 242 ASSERT_TRUE(dir2.CreateUniqueTempDir()); | |
| 243 TestingSpellCheckProfile target1(dir1.path()); | |
| 244 TestingSpellCheckProfile target2(dir2.path()); | |
| 245 | |
| 246 target1.SetHostToBeCreated(host1.get()); | |
| 247 target1.ReinitializeHost(false, true, "", NULL); | |
| 248 target2.SetHostToBeCreated(host2.get()); | |
| 249 target2.ReinitializeHost(false, true, "", NULL); | |
| 250 | |
| 251 SpellCheckProfile::CustomWordList expected1; | |
| 252 SpellCheckProfile::CustomWordList expected2; | |
| 253 | |
| 254 target1.WriteWordToCustomDictionary("foo"); | |
| 255 target1.WriteWordToCustomDictionary("bar"); | |
| 256 expected1.push_back("foo"); | |
| 257 expected1.push_back("bar"); | |
| 258 | |
| 259 target2.WriteWordToCustomDictionary("hoge"); | |
| 260 target2.WriteWordToCustomDictionary("fuga"); | |
| 261 expected2.push_back("hoge"); | |
| 262 expected2.push_back("fuga"); | |
| 263 | |
| 264 SpellCheckProfile::CustomWordList actual1; | |
| 265 target1.LoadCustomDictionary(&actual1); | |
| 266 EXPECT_EQ(actual1, expected1); | |
| 267 | |
| 268 SpellCheckProfile::CustomWordList actual2; | |
| 269 target2.LoadCustomDictionary(&actual2); | |
| 270 EXPECT_EQ(actual2, expected2); | |
| 271 } | |
| OLD | NEW |