OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 <utility> | 5 #include <utility> |
6 #include <vector> | 6 #include <vector> |
7 | 7 |
8 #include "base/bind.h" | 8 #include "base/bind.h" |
9 #include "base/macros.h" | 9 #include "base/macros.h" |
10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
(...skipping 193 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
204 | 204 |
205 scoped_ptr<password_manager::PasswordFormManager> | 205 scoped_ptr<password_manager::PasswordFormManager> |
206 ManagePasswordsUIControllerTest::CreateFormManagerWithBestMatches( | 206 ManagePasswordsUIControllerTest::CreateFormManagerWithBestMatches( |
207 const autofill::PasswordForm& observed_form, | 207 const autofill::PasswordForm& observed_form, |
208 ScopedVector<autofill::PasswordForm> best_matches) { | 208 ScopedVector<autofill::PasswordForm> best_matches) { |
209 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 209 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
210 new password_manager::PasswordFormManager(&password_manager_, &client_, | 210 new password_manager::PasswordFormManager(&password_manager_, &client_, |
211 driver_.AsWeakPtr(), | 211 driver_.AsWeakPtr(), |
212 observed_form, true)); | 212 observed_form, true)); |
213 test_form_manager->SimulateFetchMatchingLoginsFromPasswordStore(); | 213 test_form_manager->SimulateFetchMatchingLoginsFromPasswordStore(); |
214 test_form_manager->OnGetPasswordStoreResults(best_matches.Pass()); | 214 test_form_manager->OnGetPasswordStoreResults(std::move(best_matches)); |
215 return test_form_manager.Pass(); | 215 return test_form_manager; |
216 } | 216 } |
217 | 217 |
218 scoped_ptr<password_manager::PasswordFormManager> | 218 scoped_ptr<password_manager::PasswordFormManager> |
219 ManagePasswordsUIControllerTest::CreateFormManager() { | 219 ManagePasswordsUIControllerTest::CreateFormManager() { |
220 ScopedVector<autofill::PasswordForm> stored_forms; | 220 ScopedVector<autofill::PasswordForm> stored_forms; |
221 stored_forms.push_back(new autofill::PasswordForm(test_local_form())); | 221 stored_forms.push_back(new autofill::PasswordForm(test_local_form())); |
222 return CreateFormManagerWithBestMatches(test_local_form(), | 222 return CreateFormManagerWithBestMatches(test_local_form(), |
223 stored_forms.Pass()); | 223 std::move(stored_forms)); |
224 } | 224 } |
225 | 225 |
226 TEST_F(ManagePasswordsUIControllerTest, DefaultState) { | 226 TEST_F(ManagePasswordsUIControllerTest, DefaultState) { |
227 EXPECT_EQ(password_manager::ui::INACTIVE_STATE, controller()->GetState()); | 227 EXPECT_EQ(password_manager::ui::INACTIVE_STATE, controller()->GetState()); |
228 EXPECT_EQ(GURL::EmptyGURL(), controller()->GetOrigin()); | 228 EXPECT_EQ(GURL::EmptyGURL(), controller()->GetOrigin()); |
229 | 229 |
230 ExpectIconStateIs(password_manager::ui::INACTIVE_STATE); | 230 ExpectIconStateIs(password_manager::ui::INACTIVE_STATE); |
231 } | 231 } |
232 | 232 |
233 TEST_F(ManagePasswordsUIControllerTest, PasswordAutofilled) { | 233 TEST_F(ManagePasswordsUIControllerTest, PasswordAutofilled) { |
(...skipping 15 matching lines...) Expand all Loading... |
249 | 249 |
250 ExpectIconStateIs(password_manager::ui::MANAGE_STATE); | 250 ExpectIconStateIs(password_manager::ui::MANAGE_STATE); |
251 } | 251 } |
252 | 252 |
253 TEST_F(ManagePasswordsUIControllerTest, PasswordSubmitted) { | 253 TEST_F(ManagePasswordsUIControllerTest, PasswordSubmitted) { |
254 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 254 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
255 CreateFormManager()); | 255 CreateFormManager()); |
256 test_form_manager->ProvisionallySave( | 256 test_form_manager->ProvisionallySave( |
257 test_local_form(), | 257 test_local_form(), |
258 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); | 258 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); |
259 controller()->OnPasswordSubmitted(test_form_manager.Pass()); | 259 controller()->OnPasswordSubmitted(std::move(test_form_manager)); |
260 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_STATE, | 260 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_STATE, |
261 controller()->GetState()); | 261 controller()->GetState()); |
262 EXPECT_TRUE(controller()->opened_bubble()); | 262 EXPECT_TRUE(controller()->opened_bubble()); |
263 EXPECT_EQ(test_local_form().origin, controller()->GetOrigin()); | 263 EXPECT_EQ(test_local_form().origin, controller()->GetOrigin()); |
264 | 264 |
265 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); | 265 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); |
266 } | 266 } |
267 | 267 |
268 TEST_F(ManagePasswordsUIControllerTest, BlacklistedFormPasswordSubmitted) { | 268 TEST_F(ManagePasswordsUIControllerTest, BlacklistedFormPasswordSubmitted) { |
269 autofill::PasswordForm blacklisted; | 269 autofill::PasswordForm blacklisted; |
270 blacklisted.origin = test_local_form().origin; | 270 blacklisted.origin = test_local_form().origin; |
271 blacklisted.signon_realm = blacklisted.origin.spec(); | 271 blacklisted.signon_realm = blacklisted.origin.spec(); |
272 blacklisted.blacklisted_by_user = true; | 272 blacklisted.blacklisted_by_user = true; |
273 ScopedVector<autofill::PasswordForm> stored_forms; | 273 ScopedVector<autofill::PasswordForm> stored_forms; |
274 stored_forms.push_back(new autofill::PasswordForm(blacklisted)); | 274 stored_forms.push_back(new autofill::PasswordForm(blacklisted)); |
275 scoped_ptr<password_manager::PasswordFormManager> test_form_manager = | 275 scoped_ptr<password_manager::PasswordFormManager> test_form_manager = |
276 CreateFormManagerWithBestMatches(test_local_form(), stored_forms.Pass()); | 276 CreateFormManagerWithBestMatches(test_local_form(), |
| 277 std::move(stored_forms)); |
277 | 278 |
278 controller()->OnPasswordSubmitted(test_form_manager.Pass()); | 279 controller()->OnPasswordSubmitted(std::move(test_form_manager)); |
279 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_STATE, | 280 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_STATE, |
280 controller()->GetState()); | 281 controller()->GetState()); |
281 EXPECT_FALSE(controller()->opened_bubble()); | 282 EXPECT_FALSE(controller()->opened_bubble()); |
282 | 283 |
283 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); | 284 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); |
284 } | 285 } |
285 | 286 |
286 TEST_F(ManagePasswordsUIControllerTest, PasswordSubmittedBubbleSuppressed) { | 287 TEST_F(ManagePasswordsUIControllerTest, PasswordSubmittedBubbleSuppressed) { |
287 CreateSmartBubbleFieldTrial(); | 288 CreateSmartBubbleFieldTrial(); |
288 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 289 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
289 CreateFormManager()); | 290 CreateFormManager()); |
290 password_manager::InteractionsStats stats; | 291 password_manager::InteractionsStats stats; |
291 stats.origin_domain = test_local_form().origin.GetOrigin(); | 292 stats.origin_domain = test_local_form().origin.GetOrigin(); |
292 stats.username_value = test_local_form().username_value; | 293 stats.username_value = test_local_form().username_value; |
293 stats.dismissal_count = kGreatDissmisalCount; | 294 stats.dismissal_count = kGreatDissmisalCount; |
294 auto interactions(make_scoped_ptr( | 295 auto interactions(make_scoped_ptr( |
295 new std::vector<scoped_ptr<password_manager::InteractionsStats>>)); | 296 new std::vector<scoped_ptr<password_manager::InteractionsStats>>)); |
296 interactions->push_back( | 297 interactions->push_back( |
297 make_scoped_ptr(new password_manager::InteractionsStats(stats))); | 298 make_scoped_ptr(new password_manager::InteractionsStats(stats))); |
298 test_form_manager->OnGetSiteStatistics(std::move(interactions)); | 299 test_form_manager->OnGetSiteStatistics(std::move(interactions)); |
299 test_form_manager->ProvisionallySave( | 300 test_form_manager->ProvisionallySave( |
300 test_local_form(), | 301 test_local_form(), |
301 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); | 302 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); |
302 controller()->OnPasswordSubmitted(test_form_manager.Pass()); | 303 controller()->OnPasswordSubmitted(std::move(test_form_manager)); |
303 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_STATE, | 304 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_STATE, |
304 controller()->GetState()); | 305 controller()->GetState()); |
305 EXPECT_FALSE(controller()->opened_bubble()); | 306 EXPECT_FALSE(controller()->opened_bubble()); |
306 ASSERT_TRUE(controller()->GetCurrentInteractionStats()); | 307 ASSERT_TRUE(controller()->GetCurrentInteractionStats()); |
307 EXPECT_EQ(stats, *controller()->GetCurrentInteractionStats()); | 308 EXPECT_EQ(stats, *controller()->GetCurrentInteractionStats()); |
308 | 309 |
309 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); | 310 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); |
310 variations::testing::ClearAllVariationParams(); | 311 variations::testing::ClearAllVariationParams(); |
311 } | 312 } |
312 | 313 |
313 TEST_F(ManagePasswordsUIControllerTest, PasswordSubmittedBubbleNotSuppressed) { | 314 TEST_F(ManagePasswordsUIControllerTest, PasswordSubmittedBubbleNotSuppressed) { |
314 CreateSmartBubbleFieldTrial(); | 315 CreateSmartBubbleFieldTrial(); |
315 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 316 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
316 CreateFormManager()); | 317 CreateFormManager()); |
317 password_manager::InteractionsStats stats; | 318 password_manager::InteractionsStats stats; |
318 stats.origin_domain = test_local_form().origin.GetOrigin(); | 319 stats.origin_domain = test_local_form().origin.GetOrigin(); |
319 stats.username_value = base::ASCIIToUTF16("not my username"); | 320 stats.username_value = base::ASCIIToUTF16("not my username"); |
320 stats.dismissal_count = kGreatDissmisalCount; | 321 stats.dismissal_count = kGreatDissmisalCount; |
321 auto interactions(make_scoped_ptr( | 322 auto interactions(make_scoped_ptr( |
322 new std::vector<scoped_ptr<password_manager::InteractionsStats>>)); | 323 new std::vector<scoped_ptr<password_manager::InteractionsStats>>)); |
323 interactions->push_back( | 324 interactions->push_back( |
324 make_scoped_ptr(new password_manager::InteractionsStats(stats))); | 325 make_scoped_ptr(new password_manager::InteractionsStats(stats))); |
325 test_form_manager->OnGetSiteStatistics(std::move(interactions)); | 326 test_form_manager->OnGetSiteStatistics(std::move(interactions)); |
326 test_form_manager->ProvisionallySave( | 327 test_form_manager->ProvisionallySave( |
327 test_local_form(), | 328 test_local_form(), |
328 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); | 329 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); |
329 controller()->OnPasswordSubmitted(test_form_manager.Pass()); | 330 controller()->OnPasswordSubmitted(std::move(test_form_manager)); |
330 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_STATE, | 331 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_STATE, |
331 controller()->GetState()); | 332 controller()->GetState()); |
332 EXPECT_TRUE(controller()->opened_bubble()); | 333 EXPECT_TRUE(controller()->opened_bubble()); |
333 EXPECT_FALSE(controller()->GetCurrentInteractionStats()); | 334 EXPECT_FALSE(controller()->GetCurrentInteractionStats()); |
334 | 335 |
335 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); | 336 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); |
336 variations::testing::ClearAllVariationParams(); | 337 variations::testing::ClearAllVariationParams(); |
337 } | 338 } |
338 | 339 |
339 TEST_F(ManagePasswordsUIControllerTest, PasswordSaved) { | 340 TEST_F(ManagePasswordsUIControllerTest, PasswordSaved) { |
340 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 341 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
341 CreateFormManager()); | 342 CreateFormManager()); |
342 test_form_manager->ProvisionallySave( | 343 test_form_manager->ProvisionallySave( |
343 test_local_form(), | 344 test_local_form(), |
344 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); | 345 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); |
345 controller()->OnPasswordSubmitted(test_form_manager.Pass()); | 346 controller()->OnPasswordSubmitted(std::move(test_form_manager)); |
346 | 347 |
347 controller()->SavePassword(); | 348 controller()->SavePassword(); |
348 ExpectIconStateIs(password_manager::ui::MANAGE_STATE); | 349 ExpectIconStateIs(password_manager::ui::MANAGE_STATE); |
349 } | 350 } |
350 | 351 |
351 TEST_F(ManagePasswordsUIControllerTest, PasswordBlacklisted) { | 352 TEST_F(ManagePasswordsUIControllerTest, PasswordBlacklisted) { |
352 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 353 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
353 CreateFormManager()); | 354 CreateFormManager()); |
354 test_form_manager->ProvisionallySave( | 355 test_form_manager->ProvisionallySave( |
355 test_local_form(), | 356 test_local_form(), |
356 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); | 357 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); |
357 controller()->OnPasswordSubmitted(test_form_manager.Pass()); | 358 controller()->OnPasswordSubmitted(std::move(test_form_manager)); |
358 | 359 |
359 controller()->NeverSavePassword(); | 360 controller()->NeverSavePassword(); |
360 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); | 361 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); |
361 } | 362 } |
362 | 363 |
363 TEST_F(ManagePasswordsUIControllerTest, RedirectNavigations) { | 364 TEST_F(ManagePasswordsUIControllerTest, RedirectNavigations) { |
364 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 365 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
365 CreateFormManager()); | 366 CreateFormManager()); |
366 controller()->OnPasswordSubmitted(test_form_manager.Pass()); | 367 controller()->OnPasswordSubmitted(std::move(test_form_manager)); |
367 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); | 368 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); |
368 | 369 |
369 // Fake-redirect. We expect the bubble's state to persist so a user reasonably | 370 // Fake-redirect. We expect the bubble's state to persist so a user reasonably |
370 // have been able to interact with the bubble. This happens on | 371 // have been able to interact with the bubble. This happens on |
371 // `accounts.google.com`, for instance. | 372 // `accounts.google.com`, for instance. |
372 content::FrameNavigateParams params; | 373 content::FrameNavigateParams params; |
373 params.transition = ui::PAGE_TRANSITION_SERVER_REDIRECT; | 374 params.transition = ui::PAGE_TRANSITION_SERVER_REDIRECT; |
374 controller()->DidNavigateMainFrame(content::LoadCommittedDetails(), params); | 375 controller()->DidNavigateMainFrame(content::LoadCommittedDetails(), params); |
375 | 376 |
376 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); | 377 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); |
377 } | 378 } |
378 | 379 |
379 TEST_F(ManagePasswordsUIControllerTest, NormalNavigations) { | 380 TEST_F(ManagePasswordsUIControllerTest, NormalNavigations) { |
380 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 381 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
381 CreateFormManager()); | 382 CreateFormManager()); |
382 controller()->OnPasswordSubmitted(test_form_manager.Pass()); | 383 controller()->OnPasswordSubmitted(std::move(test_form_manager)); |
383 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); | 384 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_STATE); |
384 | 385 |
385 // Fake-navigate. We expect the bubble's state to be reset. | 386 // Fake-navigate. We expect the bubble's state to be reset. |
386 controller()->DidNavigateMainFrame(content::LoadCommittedDetails(), | 387 controller()->DidNavigateMainFrame(content::LoadCommittedDetails(), |
387 content::FrameNavigateParams()); | 388 content::FrameNavigateParams()); |
388 | 389 |
389 ExpectIconStateIs(password_manager::ui::INACTIVE_STATE); | 390 ExpectIconStateIs(password_manager::ui::INACTIVE_STATE); |
390 } | 391 } |
391 | 392 |
392 TEST_F(ManagePasswordsUIControllerTest, PasswordSubmittedToNonWebbyURL) { | 393 TEST_F(ManagePasswordsUIControllerTest, PasswordSubmittedToNonWebbyURL) { |
393 // Navigate to a non-webby URL, then see what happens! | 394 // Navigate to a non-webby URL, then see what happens! |
394 content::WebContentsTester::For(web_contents()) | 395 content::WebContentsTester::For(web_contents()) |
395 ->NavigateAndCommit(GURL("chrome://sign-in")); | 396 ->NavigateAndCommit(GURL("chrome://sign-in")); |
396 | 397 |
397 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 398 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
398 CreateFormManager()); | 399 CreateFormManager()); |
399 test_form_manager->ProvisionallySave( | 400 test_form_manager->ProvisionallySave( |
400 test_local_form(), | 401 test_local_form(), |
401 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); | 402 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); |
402 controller()->OnPasswordSubmitted(test_form_manager.Pass()); | 403 controller()->OnPasswordSubmitted(std::move(test_form_manager)); |
403 EXPECT_EQ(password_manager::ui::INACTIVE_STATE, controller()->GetState()); | 404 EXPECT_EQ(password_manager::ui::INACTIVE_STATE, controller()->GetState()); |
404 EXPECT_EQ(GURL::EmptyGURL(), controller()->GetOrigin()); | 405 EXPECT_EQ(GURL::EmptyGURL(), controller()->GetOrigin()); |
405 | 406 |
406 ExpectIconStateIs(password_manager::ui::INACTIVE_STATE); | 407 ExpectIconStateIs(password_manager::ui::INACTIVE_STATE); |
407 } | 408 } |
408 | 409 |
409 TEST_F(ManagePasswordsUIControllerTest, BlacklistedElsewhere) { | 410 TEST_F(ManagePasswordsUIControllerTest, BlacklistedElsewhere) { |
410 base::string16 kTestUsername = base::ASCIIToUTF16("test_username"); | 411 base::string16 kTestUsername = base::ASCIIToUTF16("test_username"); |
411 autofill::PasswordFormMap map; | 412 autofill::PasswordFormMap map; |
412 map.insert(std::make_pair( | 413 map.insert(std::make_pair( |
(...skipping 10 matching lines...) Expand all Loading... |
423 EXPECT_EQ(password_manager::ui::MANAGE_STATE, controller()->GetState()); | 424 EXPECT_EQ(password_manager::ui::MANAGE_STATE, controller()->GetState()); |
424 EXPECT_EQ(test_local_form().origin, controller()->GetOrigin()); | 425 EXPECT_EQ(test_local_form().origin, controller()->GetOrigin()); |
425 | 426 |
426 ExpectIconStateIs(password_manager::ui::MANAGE_STATE); | 427 ExpectIconStateIs(password_manager::ui::MANAGE_STATE); |
427 } | 428 } |
428 | 429 |
429 TEST_F(ManagePasswordsUIControllerTest, AutomaticPasswordSave) { | 430 TEST_F(ManagePasswordsUIControllerTest, AutomaticPasswordSave) { |
430 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 431 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
431 CreateFormManager()); | 432 CreateFormManager()); |
432 | 433 |
433 controller()->OnAutomaticPasswordSave(test_form_manager.Pass()); | 434 controller()->OnAutomaticPasswordSave(std::move(test_form_manager)); |
434 EXPECT_EQ(password_manager::ui::CONFIRMATION_STATE, controller()->GetState()); | 435 EXPECT_EQ(password_manager::ui::CONFIRMATION_STATE, controller()->GetState()); |
435 | 436 |
436 controller()->OnBubbleHidden(); | 437 controller()->OnBubbleHidden(); |
437 ExpectIconStateIs(password_manager::ui::MANAGE_STATE); | 438 ExpectIconStateIs(password_manager::ui::MANAGE_STATE); |
438 } | 439 } |
439 | 440 |
440 TEST_F(ManagePasswordsUIControllerTest, ChooseCredentialLocal) { | 441 TEST_F(ManagePasswordsUIControllerTest, ChooseCredentialLocal) { |
441 ScopedVector<autofill::PasswordForm> local_credentials; | 442 ScopedVector<autofill::PasswordForm> local_credentials; |
442 local_credentials.push_back(new autofill::PasswordForm(test_local_form())); | 443 local_credentials.push_back(new autofill::PasswordForm(test_local_form())); |
443 ScopedVector<autofill::PasswordForm> federated_credentials; | 444 ScopedVector<autofill::PasswordForm> federated_credentials; |
444 GURL origin("http://example.com"); | 445 GURL origin("http://example.com"); |
445 EXPECT_TRUE(controller()->OnChooseCredentials( | 446 EXPECT_TRUE(controller()->OnChooseCredentials( |
446 local_credentials.Pass(), federated_credentials.Pass(), origin, | 447 std::move(local_credentials), std::move(federated_credentials), origin, |
447 base::Bind(&ManagePasswordsUIControllerTest::CredentialCallback, | 448 base::Bind(&ManagePasswordsUIControllerTest::CredentialCallback, |
448 base::Unretained(this)))); | 449 base::Unretained(this)))); |
449 EXPECT_EQ(password_manager::ui::CREDENTIAL_REQUEST_STATE, | 450 EXPECT_EQ(password_manager::ui::CREDENTIAL_REQUEST_STATE, |
450 controller()->GetState()); | 451 controller()->GetState()); |
451 EXPECT_EQ(origin, controller()->GetOrigin()); | 452 EXPECT_EQ(origin, controller()->GetOrigin()); |
452 EXPECT_THAT(controller()->GetCurrentForms(), | 453 EXPECT_THAT(controller()->GetCurrentForms(), |
453 ElementsAre(Pointee(test_local_form()))); | 454 ElementsAre(Pointee(test_local_form()))); |
454 | 455 |
455 ExpectIconStateIs(password_manager::ui::CREDENTIAL_REQUEST_STATE); | 456 ExpectIconStateIs(password_manager::ui::CREDENTIAL_REQUEST_STATE); |
456 | 457 |
(...skipping 10 matching lines...) Expand all Loading... |
467 credential_info()->type); | 468 credential_info()->type); |
468 } | 469 } |
469 | 470 |
470 TEST_F(ManagePasswordsUIControllerTest, ChooseCredentialLocalButFederated) { | 471 TEST_F(ManagePasswordsUIControllerTest, ChooseCredentialLocalButFederated) { |
471 ScopedVector<autofill::PasswordForm> local_credentials; | 472 ScopedVector<autofill::PasswordForm> local_credentials; |
472 local_credentials.push_back( | 473 local_credentials.push_back( |
473 new autofill::PasswordForm(test_federated_form())); | 474 new autofill::PasswordForm(test_federated_form())); |
474 ScopedVector<autofill::PasswordForm> federated_credentials; | 475 ScopedVector<autofill::PasswordForm> federated_credentials; |
475 GURL origin("http://example.com"); | 476 GURL origin("http://example.com"); |
476 EXPECT_TRUE(controller()->OnChooseCredentials( | 477 EXPECT_TRUE(controller()->OnChooseCredentials( |
477 local_credentials.Pass(), federated_credentials.Pass(), origin, | 478 std::move(local_credentials), std::move(federated_credentials), origin, |
478 base::Bind(&ManagePasswordsUIControllerTest::CredentialCallback, | 479 base::Bind(&ManagePasswordsUIControllerTest::CredentialCallback, |
479 base::Unretained(this)))); | 480 base::Unretained(this)))); |
480 EXPECT_EQ(password_manager::ui::CREDENTIAL_REQUEST_STATE, | 481 EXPECT_EQ(password_manager::ui::CREDENTIAL_REQUEST_STATE, |
481 controller()->GetState()); | 482 controller()->GetState()); |
482 EXPECT_EQ(origin, controller()->GetOrigin()); | 483 EXPECT_EQ(origin, controller()->GetOrigin()); |
483 EXPECT_THAT(controller()->GetCurrentForms(), | 484 EXPECT_THAT(controller()->GetCurrentForms(), |
484 ElementsAre(Pointee(test_federated_form()))); | 485 ElementsAre(Pointee(test_federated_form()))); |
485 | 486 |
486 ExpectIconStateIs(password_manager::ui::CREDENTIAL_REQUEST_STATE); | 487 ExpectIconStateIs(password_manager::ui::CREDENTIAL_REQUEST_STATE); |
487 | 488 |
(...skipping 11 matching lines...) Expand all Loading... |
499 credential_info()->type); | 500 credential_info()->type); |
500 } | 501 } |
501 | 502 |
502 TEST_F(ManagePasswordsUIControllerTest, ChooseCredentialFederated) { | 503 TEST_F(ManagePasswordsUIControllerTest, ChooseCredentialFederated) { |
503 ScopedVector<autofill::PasswordForm> local_credentials; | 504 ScopedVector<autofill::PasswordForm> local_credentials; |
504 ScopedVector<autofill::PasswordForm> federated_credentials; | 505 ScopedVector<autofill::PasswordForm> federated_credentials; |
505 federated_credentials.push_back( | 506 federated_credentials.push_back( |
506 new autofill::PasswordForm(test_local_form())); | 507 new autofill::PasswordForm(test_local_form())); |
507 GURL origin("http://example.com"); | 508 GURL origin("http://example.com"); |
508 EXPECT_TRUE(controller()->OnChooseCredentials( | 509 EXPECT_TRUE(controller()->OnChooseCredentials( |
509 local_credentials.Pass(), federated_credentials.Pass(), origin, | 510 std::move(local_credentials), std::move(federated_credentials), origin, |
510 base::Bind(&ManagePasswordsUIControllerTest::CredentialCallback, | 511 base::Bind(&ManagePasswordsUIControllerTest::CredentialCallback, |
511 base::Unretained(this)))); | 512 base::Unretained(this)))); |
512 EXPECT_EQ(password_manager::ui::CREDENTIAL_REQUEST_STATE, | 513 EXPECT_EQ(password_manager::ui::CREDENTIAL_REQUEST_STATE, |
513 controller()->GetState()); | 514 controller()->GetState()); |
514 EXPECT_EQ(0u, controller()->GetCurrentForms().size()); | 515 EXPECT_EQ(0u, controller()->GetCurrentForms().size()); |
515 EXPECT_EQ(origin, controller()->GetOrigin()); | 516 EXPECT_EQ(origin, controller()->GetOrigin()); |
516 | 517 |
517 ExpectIconStateIs(password_manager::ui::CREDENTIAL_REQUEST_STATE); | 518 ExpectIconStateIs(password_manager::ui::CREDENTIAL_REQUEST_STATE); |
518 | 519 |
519 controller()->ManagePasswordsUIController::ChooseCredential( | 520 controller()->ManagePasswordsUIController::ChooseCredential( |
520 test_local_form(), | 521 test_local_form(), |
521 password_manager::CredentialType::CREDENTIAL_TYPE_FEDERATED); | 522 password_manager::CredentialType::CREDENTIAL_TYPE_FEDERATED); |
522 controller()->OnBubbleHidden(); | 523 controller()->OnBubbleHidden(); |
523 EXPECT_EQ(password_manager::ui::MANAGE_STATE, controller()->GetState()); | 524 EXPECT_EQ(password_manager::ui::MANAGE_STATE, controller()->GetState()); |
524 ASSERT_TRUE(credential_info()); | 525 ASSERT_TRUE(credential_info()); |
525 EXPECT_EQ(test_local_form().username_value, credential_info()->id); | 526 EXPECT_EQ(test_local_form().username_value, credential_info()->id); |
526 EXPECT_TRUE(credential_info()->password.empty()); | 527 EXPECT_TRUE(credential_info()->password.empty()); |
527 EXPECT_EQ(password_manager::CredentialType::CREDENTIAL_TYPE_FEDERATED, | 528 EXPECT_EQ(password_manager::CredentialType::CREDENTIAL_TYPE_FEDERATED, |
528 credential_info()->type); | 529 credential_info()->type); |
529 } | 530 } |
530 | 531 |
531 TEST_F(ManagePasswordsUIControllerTest, ChooseCredentialCancel) { | 532 TEST_F(ManagePasswordsUIControllerTest, ChooseCredentialCancel) { |
532 ScopedVector<autofill::PasswordForm> local_credentials; | 533 ScopedVector<autofill::PasswordForm> local_credentials; |
533 local_credentials.push_back(new autofill::PasswordForm(test_local_form())); | 534 local_credentials.push_back(new autofill::PasswordForm(test_local_form())); |
534 ScopedVector<autofill::PasswordForm> federated_credentials; | 535 ScopedVector<autofill::PasswordForm> federated_credentials; |
535 GURL origin("http://example.com"); | 536 GURL origin("http://example.com"); |
536 EXPECT_TRUE(controller()->OnChooseCredentials( | 537 EXPECT_TRUE(controller()->OnChooseCredentials( |
537 local_credentials.Pass(), federated_credentials.Pass(), origin, | 538 std::move(local_credentials), std::move(federated_credentials), origin, |
538 base::Bind(&ManagePasswordsUIControllerTest::CredentialCallback, | 539 base::Bind(&ManagePasswordsUIControllerTest::CredentialCallback, |
539 base::Unretained(this)))); | 540 base::Unretained(this)))); |
540 EXPECT_EQ(password_manager::ui::CREDENTIAL_REQUEST_STATE, | 541 EXPECT_EQ(password_manager::ui::CREDENTIAL_REQUEST_STATE, |
541 controller()->GetState()); | 542 controller()->GetState()); |
542 EXPECT_EQ(origin, controller()->GetOrigin()); | 543 EXPECT_EQ(origin, controller()->GetOrigin()); |
543 controller()->ManagePasswordsUIController::ChooseCredential( | 544 controller()->ManagePasswordsUIController::ChooseCredential( |
544 test_local_form(), | 545 test_local_form(), |
545 password_manager::CredentialType::CREDENTIAL_TYPE_EMPTY); | 546 password_manager::CredentialType::CREDENTIAL_TYPE_EMPTY); |
546 controller()->OnBubbleHidden(); | 547 controller()->OnBubbleHidden(); |
547 EXPECT_EQ(password_manager::ui::MANAGE_STATE, controller()->GetState()); | 548 EXPECT_EQ(password_manager::ui::MANAGE_STATE, controller()->GetState()); |
548 ASSERT_TRUE(credential_info()); | 549 ASSERT_TRUE(credential_info()); |
549 EXPECT_TRUE(credential_info()->federation.is_empty()); | 550 EXPECT_TRUE(credential_info()->federation.is_empty()); |
550 EXPECT_TRUE(credential_info()->password.empty()); | 551 EXPECT_TRUE(credential_info()->password.empty()); |
551 EXPECT_EQ(password_manager::CredentialType::CREDENTIAL_TYPE_EMPTY, | 552 EXPECT_EQ(password_manager::CredentialType::CREDENTIAL_TYPE_EMPTY, |
552 credential_info()->type); | 553 credential_info()->type); |
553 } | 554 } |
554 | 555 |
555 TEST_F(ManagePasswordsUIControllerTest, AutoSignin) { | 556 TEST_F(ManagePasswordsUIControllerTest, AutoSignin) { |
556 ScopedVector<autofill::PasswordForm> local_credentials; | 557 ScopedVector<autofill::PasswordForm> local_credentials; |
557 local_credentials.push_back(new autofill::PasswordForm(test_local_form())); | 558 local_credentials.push_back(new autofill::PasswordForm(test_local_form())); |
558 controller()->OnAutoSignin(local_credentials.Pass()); | 559 controller()->OnAutoSignin(std::move(local_credentials)); |
559 EXPECT_EQ(password_manager::ui::AUTO_SIGNIN_STATE, controller()->GetState()); | 560 EXPECT_EQ(password_manager::ui::AUTO_SIGNIN_STATE, controller()->GetState()); |
560 EXPECT_EQ(test_local_form().origin, controller()->GetOrigin()); | 561 EXPECT_EQ(test_local_form().origin, controller()->GetOrigin()); |
561 ASSERT_FALSE(controller()->GetCurrentForms().empty()); | 562 ASSERT_FALSE(controller()->GetCurrentForms().empty()); |
562 EXPECT_EQ(test_local_form(), *controller()->GetCurrentForms()[0]); | 563 EXPECT_EQ(test_local_form(), *controller()->GetCurrentForms()[0]); |
563 ExpectIconStateIs(password_manager::ui::AUTO_SIGNIN_STATE); | 564 ExpectIconStateIs(password_manager::ui::AUTO_SIGNIN_STATE); |
564 controller()->OnBubbleHidden(); | 565 controller()->OnBubbleHidden(); |
565 ExpectIconAndControllerStateIs(password_manager::ui::MANAGE_STATE); | 566 ExpectIconAndControllerStateIs(password_manager::ui::MANAGE_STATE); |
566 } | 567 } |
567 | 568 |
568 TEST_F(ManagePasswordsUIControllerTest, AutofillDuringAutoSignin) { | 569 TEST_F(ManagePasswordsUIControllerTest, AutofillDuringAutoSignin) { |
569 ScopedVector<autofill::PasswordForm> local_credentials; | 570 ScopedVector<autofill::PasswordForm> local_credentials; |
570 local_credentials.push_back(new autofill::PasswordForm(test_local_form())); | 571 local_credentials.push_back(new autofill::PasswordForm(test_local_form())); |
571 controller()->OnAutoSignin(local_credentials.Pass()); | 572 controller()->OnAutoSignin(std::move(local_credentials)); |
572 ExpectIconAndControllerStateIs(password_manager::ui::AUTO_SIGNIN_STATE); | 573 ExpectIconAndControllerStateIs(password_manager::ui::AUTO_SIGNIN_STATE); |
573 scoped_ptr<autofill::PasswordForm> test_form( | 574 scoped_ptr<autofill::PasswordForm> test_form( |
574 new autofill::PasswordForm(test_local_form())); | 575 new autofill::PasswordForm(test_local_form())); |
575 autofill::PasswordFormMap map; | 576 autofill::PasswordFormMap map; |
576 base::string16 kTestUsername = test_form->username_value; | 577 base::string16 kTestUsername = test_form->username_value; |
577 map.insert(std::make_pair(kTestUsername, std::move(test_form))); | 578 map.insert(std::make_pair(kTestUsername, std::move(test_form))); |
578 controller()->OnPasswordAutofilled(map, map.begin()->second->origin); | 579 controller()->OnPasswordAutofilled(map, map.begin()->second->origin); |
579 | 580 |
580 ExpectIconAndControllerStateIs(password_manager::ui::AUTO_SIGNIN_STATE); | 581 ExpectIconAndControllerStateIs(password_manager::ui::AUTO_SIGNIN_STATE); |
581 } | 582 } |
582 | 583 |
583 TEST_F(ManagePasswordsUIControllerTest, InactiveOnPSLMatched) { | 584 TEST_F(ManagePasswordsUIControllerTest, InactiveOnPSLMatched) { |
584 base::string16 kTestUsername = base::ASCIIToUTF16("test_username"); | 585 base::string16 kTestUsername = base::ASCIIToUTF16("test_username"); |
585 autofill::PasswordFormMap map; | 586 autofill::PasswordFormMap map; |
586 scoped_ptr<autofill::PasswordForm> psl_matched_test_form( | 587 scoped_ptr<autofill::PasswordForm> psl_matched_test_form( |
587 new autofill::PasswordForm(test_local_form())); | 588 new autofill::PasswordForm(test_local_form())); |
588 psl_matched_test_form->is_public_suffix_match = true; | 589 psl_matched_test_form->is_public_suffix_match = true; |
589 map.insert(std::make_pair(kTestUsername, std::move(psl_matched_test_form))); | 590 map.insert(std::make_pair(kTestUsername, std::move(psl_matched_test_form))); |
590 controller()->OnPasswordAutofilled(map, map.begin()->second->origin); | 591 controller()->OnPasswordAutofilled(map, map.begin()->second->origin); |
591 | 592 |
592 EXPECT_EQ(password_manager::ui::INACTIVE_STATE, controller()->GetState()); | 593 EXPECT_EQ(password_manager::ui::INACTIVE_STATE, controller()->GetState()); |
593 } | 594 } |
594 | 595 |
595 TEST_F(ManagePasswordsUIControllerTest, UpdatePasswordSubmitted) { | 596 TEST_F(ManagePasswordsUIControllerTest, UpdatePasswordSubmitted) { |
596 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 597 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
597 CreateFormManager()); | 598 CreateFormManager()); |
598 controller()->OnUpdatePasswordSubmitted(test_form_manager.Pass()); | 599 controller()->OnUpdatePasswordSubmitted(std::move(test_form_manager)); |
599 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_UPDATE_STATE, | 600 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_UPDATE_STATE, |
600 controller()->GetState()); | 601 controller()->GetState()); |
601 | 602 |
602 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_UPDATE_STATE); | 603 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_UPDATE_STATE); |
603 } | 604 } |
604 | 605 |
605 TEST_F(ManagePasswordsUIControllerTest, PasswordUpdated) { | 606 TEST_F(ManagePasswordsUIControllerTest, PasswordUpdated) { |
606 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 607 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
607 CreateFormManager()); | 608 CreateFormManager()); |
608 test_form_manager->ProvisionallySave( | 609 test_form_manager->ProvisionallySave( |
609 test_local_form(), | 610 test_local_form(), |
610 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); | 611 password_manager::PasswordFormManager::IGNORE_OTHER_POSSIBLE_USERNAMES); |
611 controller()->OnUpdatePasswordSubmitted(test_form_manager.Pass()); | 612 controller()->OnUpdatePasswordSubmitted(std::move(test_form_manager)); |
612 | 613 |
613 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_UPDATE_STATE); | 614 ExpectIconStateIs(password_manager::ui::PENDING_PASSWORD_UPDATE_STATE); |
614 controller()->UpdatePassword(autofill::PasswordForm()); | 615 controller()->UpdatePassword(autofill::PasswordForm()); |
615 ExpectIconStateIs(password_manager::ui::MANAGE_STATE); | 616 ExpectIconStateIs(password_manager::ui::MANAGE_STATE); |
616 } | 617 } |
617 | 618 |
618 TEST_F(ManagePasswordsUIControllerTest, NavigationWhenUpdateBubbleActive) { | 619 TEST_F(ManagePasswordsUIControllerTest, NavigationWhenUpdateBubbleActive) { |
619 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( | 620 scoped_ptr<password_manager::PasswordFormManager> test_form_manager( |
620 CreateFormManager()); | 621 CreateFormManager()); |
621 controller()->OnUpdatePasswordSubmitted(test_form_manager.Pass()); | 622 controller()->OnUpdatePasswordSubmitted(std::move(test_form_manager)); |
622 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_UPDATE_STATE, | 623 EXPECT_EQ(password_manager::ui::PENDING_PASSWORD_UPDATE_STATE, |
623 controller()->GetState()); | 624 controller()->GetState()); |
624 controller()->DidNavigateMainFrame(content::LoadCommittedDetails(), | 625 controller()->DidNavigateMainFrame(content::LoadCommittedDetails(), |
625 content::FrameNavigateParams()); | 626 content::FrameNavigateParams()); |
626 EXPECT_EQ(password_manager::ui::INACTIVE_STATE, controller()->GetState()); | 627 EXPECT_EQ(password_manager::ui::INACTIVE_STATE, controller()->GetState()); |
627 // The following line shouldn't crash browser. | 628 // The following line shouldn't crash browser. |
628 controller()->OnNoInteractionOnUpdate(); | 629 controller()->OnNoInteractionOnUpdate(); |
629 } | 630 } |
OLD | NEW |