Chromium Code Reviews| Index: chrome/android/junit/src/org/chromium/chrome/browser/preferences/password/PasswordReauthenticationTest.java |
| diff --git a/chrome/android/junit/src/org/chromium/chrome/browser/preferences/password/PasswordReauthenticationTest.java b/chrome/android/junit/src/org/chromium/chrome/browser/preferences/password/PasswordReauthenticationTest.java |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..e3a730362f815864e667a7bdfbd58e08079551ce |
| --- /dev/null |
| +++ b/chrome/android/junit/src/org/chromium/chrome/browser/preferences/password/PasswordReauthenticationTest.java |
| @@ -0,0 +1,80 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
|
vabr (Chromium)
2016/08/17 08:57:42
nit: 2016
dozsa
2016/08/17 10:40:27
Done.
|
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +package org.chromium.chrome.browser.preferences.password; |
| + |
| +import static org.junit.Assert.assertEquals; |
| + |
| +import android.app.Activity; |
| +import android.app.Fragment; |
| +import android.app.FragmentManager; |
| +import android.app.FragmentTransaction; |
| +import android.content.Intent; |
| + |
| +import org.chromium.testing.local.LocalRobolectricTestRunner; |
| + |
| +import org.junit.Test; |
| + |
| +import org.junit.runner.RunWith; |
| + |
| +import org.robolectric.Robolectric; |
| + |
| +/** |
| + * Tests for the "Save Passwords" settings screen. |
| + */ |
| +@RunWith(LocalRobolectricTestRunner.class) |
| +public class PasswordReauthenticationTest{ |
| + |
| + private static PasswordReauthentication sMockPasswordReauthentication; |
| + |
| + // Replacement fragment for PasswordEntryEditor, which is the fragment that |
| + // replaces PasswordReauthentication after popBackStack is called. |
| + private static Fragment sMockPasswordEntryEditor; |
| + |
| + private static final int CONFIRM_DEVICE_CREDENTIAL_REQUEST_CODE = 2; |
|
Bernhard Bauer
2016/08/16 23:37:35
Rather than duplicating this value, make it visibl
dozsa
2016/08/17 10:40:27
Done.
|
| + |
| + private Activity mTestActivity; |
| + |
| + protected void setUp() throws Exception { |
| + sMockPasswordReauthentication = new PasswordReauthentication(); |
| + mTestActivity = Robolectric.setupActivity(Activity.class); |
| + } |
| + |
| + /** |
| + * Ensure that the on/off switch in "Save Passwords" settings actually enables and disables |
|
vabr (Chromium)
2016/08/17 08:57:42
nit: This comment seems out of date.
dozsa
2016/08/17 10:40:27
Done.
|
| + * password saving. |
| + */ |
| + @Test |
| + public void testOnActivityResult() { |
| + sMockPasswordEntryEditor = new Fragment(); |
| + sMockPasswordReauthentication = new PasswordReauthentication(); |
| + mTestActivity = Robolectric.setupActivity(Activity.class); |
|
Bernhard Bauer
2016/08/16 23:37:35
These two lines are duplicated in the setUp() meth
dozsa
2016/08/17 10:40:27
Done.
|
| + Intent returnIntent = new Intent(); |
| + returnIntent.putExtra("result", "This is the result"); |
| + sMockPasswordReauthentication.setTesting(true); |
| + |
| + FragmentManager fragmentManager = mTestActivity.getFragmentManager(); |
| + FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction(); |
| + fragmentTransaction.add(sMockPasswordEntryEditor, "password_entry_editor"); |
| + fragmentTransaction.addToBackStack("add_password_entry_editor"); |
| + fragmentTransaction.commit(); |
| + |
| + FragmentTransaction fragmentTransaction2 = fragmentManager.beginTransaction(); |
| + fragmentTransaction2.add(sMockPasswordReauthentication, "password_reauthentication"); |
| + fragmentTransaction2.addToBackStack("add_password_reauthentication"); |
| + fragmentTransaction2.commit(); |
| + |
| + sMockPasswordReauthentication.onActivityResult(CONFIRM_DEVICE_CREDENTIAL_REQUEST_CODE, |
| + mTestActivity.RESULT_OK, returnIntent); |
| + fragmentManager.executePendingTransactions(); |
| + |
| + // Assert that the number of fragments in the Back Stack is equal to 1 after |
| + // reauthentication, as PasswordReauthentication is popped. |
| + assertEquals(1, fragmentManager.getBackStackEntryCount()); |
| + |
| + // Assert that the remaining fragment in the Back Stack is PasswordEntryEditor. |
| + assertEquals("add_password_entry_editor", fragmentManager.getBackStackEntryAt(0) |
| + .getName()); |
| + } |
| +} |