Commit bafe73f1 authored by Alice Wang's avatar Alice Wang Committed by Commit Bot

[Android][Signin] Fix BookmarkPersonalizedSigninPromoTests on tablet

This CL fixes tests of BookmarkPersonalizedSigninPromoTests on tablet.

TBR=twellington@chromium.org

Bug: 789531
Change-Id: I04a49042104bcbdf1b0add9a6a9bd88d819cb8a6
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/1893259
Commit-Queue: Alice Wang <aliceywang@chromium.org>
Reviewed-by: default avatarTheresa  <twellington@chromium.org>
Reviewed-by: default avatarBoris Sazonov <bsazonov@chromium.org>
Cr-Commit-Position: refs/heads/master@{#711262}
parent b550fe5b
...@@ -21,6 +21,7 @@ import static org.mockito.Mockito.mock; ...@@ -21,6 +21,7 @@ import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify; import static org.mockito.Mockito.verify;
import android.accounts.Account; import android.accounts.Account;
import android.app.Activity;
import android.content.Context; import android.content.Context;
import android.support.test.filters.LargeTest; import android.support.test.filters.LargeTest;
import android.support.test.filters.MediumTest; import android.support.test.filters.MediumTest;
...@@ -48,7 +49,6 @@ import org.chromium.components.signin.metrics.SigninAccessPoint; ...@@ -48,7 +49,6 @@ import org.chromium.components.signin.metrics.SigninAccessPoint;
import org.chromium.components.signin.test.util.AccountHolder; import org.chromium.components.signin.test.util.AccountHolder;
import org.chromium.components.signin.test.util.AccountManagerTestRule; import org.chromium.components.signin.test.util.AccountManagerTestRule;
import org.chromium.components.signin.test.util.FakeAccountManagerDelegate; import org.chromium.components.signin.test.util.FakeAccountManagerDelegate;
import org.chromium.content_public.browser.test.util.TestThreadUtils;
import org.chromium.ui.test.util.UiDisableIf; import org.chromium.ui.test.util.UiDisableIf;
/** /**
...@@ -89,7 +89,7 @@ public class BookmarkPersonalizedSigninPromoTest { ...@@ -89,7 +89,7 @@ public class BookmarkPersonalizedSigninPromoTest {
@MediumTest @MediumTest
@DisabledTest(message = "crbug.com/789531") @DisabledTest(message = "crbug.com/789531")
public void testManualDismissPromo() { public void testManualDismissPromo() {
openBookmarkManager(); BookmarkTestUtil.showBookmarkManager(mActivityTestRule.getActivity());
onView(withId(R.id.signin_promo_view_container)).check(matches(isDisplayed())); onView(withId(R.id.signin_promo_view_container)).check(matches(isDisplayed()));
onView(withId(R.id.signin_promo_close_button)).perform(click()); onView(withId(R.id.signin_promo_close_button)).perform(click());
onView(withId(R.id.signin_promo_view_container)).check(doesNotExist()); onView(withId(R.id.signin_promo_view_container)).check(doesNotExist());
...@@ -102,11 +102,11 @@ public class BookmarkPersonalizedSigninPromoTest { ...@@ -102,11 +102,11 @@ public class BookmarkPersonalizedSigninPromoTest {
public void testAutoDismissPromo() { public void testAutoDismissPromo() {
int impressionCap = SigninPromoController.getMaxImpressionsBookmarksForTests(); int impressionCap = SigninPromoController.getMaxImpressionsBookmarksForTests();
for (int impression = 0; impression < impressionCap; impression++) { for (int impression = 0; impression < impressionCap; impression++) {
openBookmarkManager(); BookmarkTestUtil.showBookmarkManager(mActivityTestRule.getActivity());
onView(withId(R.id.signin_promo_view_container)).check(matches(isDisplayed())); onView(withId(R.id.signin_promo_view_container)).check(matches(isDisplayed()));
pressBack(); pressBack();
} }
openBookmarkManager(); BookmarkTestUtil.showBookmarkManager(mActivityTestRule.getActivity());
onView(withId(R.id.signin_promo_view_container)).check(doesNotExist()); onView(withId(R.id.signin_promo_view_container)).check(doesNotExist());
} }
...@@ -117,10 +117,10 @@ public class BookmarkPersonalizedSigninPromoTest { ...@@ -117,10 +117,10 @@ public class BookmarkPersonalizedSigninPromoTest {
.when(SigninActivityLauncher.get()) .when(SigninActivityLauncher.get())
.launchActivityForPromoDefaultFlow(any(Context.class), anyInt(), anyString()); .launchActivityForPromoDefaultFlow(any(Context.class), anyInt(), anyString());
addTestAccount(); addTestAccount();
openBookmarkManagerAndCheckSigninPromoIsDisplayed(); showBookmarkManagerAndCheckSigninPromoIsDisplayed();
onView(withId(R.id.signin_promo_signin_button)).perform(click()); onView(withId(R.id.signin_promo_signin_button)).perform(click());
verify(mMockSigninActivityLauncher) verify(mMockSigninActivityLauncher)
.launchActivityForPromoDefaultFlow(any(BookmarkActivity.class), .launchActivityForPromoDefaultFlow(any(Activity.class),
eq(SigninAccessPoint.BOOKMARK_MANAGER), eq(TEST_ACCOUNT_NAME)); eq(SigninAccessPoint.BOOKMARK_MANAGER), eq(TEST_ACCOUNT_NAME));
} }
...@@ -131,10 +131,10 @@ public class BookmarkPersonalizedSigninPromoTest { ...@@ -131,10 +131,10 @@ public class BookmarkPersonalizedSigninPromoTest {
.when(SigninActivityLauncher.get()) .when(SigninActivityLauncher.get())
.launchActivityForPromoChooseAccountFlow(any(Context.class), anyInt(), anyString()); .launchActivityForPromoChooseAccountFlow(any(Context.class), anyInt(), anyString());
addTestAccount(); addTestAccount();
openBookmarkManagerAndCheckSigninPromoIsDisplayed(); showBookmarkManagerAndCheckSigninPromoIsDisplayed();
onView(withId(R.id.signin_promo_choose_account_button)).perform(click()); onView(withId(R.id.signin_promo_choose_account_button)).perform(click());
verify(mMockSigninActivityLauncher) verify(mMockSigninActivityLauncher)
.launchActivityForPromoChooseAccountFlow(any(BookmarkActivity.class), .launchActivityForPromoChooseAccountFlow(any(Activity.class),
eq(SigninAccessPoint.BOOKMARK_MANAGER), eq(TEST_ACCOUNT_NAME)); eq(SigninAccessPoint.BOOKMARK_MANAGER), eq(TEST_ACCOUNT_NAME));
} }
...@@ -144,24 +144,18 @@ public class BookmarkPersonalizedSigninPromoTest { ...@@ -144,24 +144,18 @@ public class BookmarkPersonalizedSigninPromoTest {
doNothing() doNothing()
.when(SigninActivityLauncher.get()) .when(SigninActivityLauncher.get())
.launchActivityForPromoAddAccountFlow(any(Context.class), anyInt()); .launchActivityForPromoAddAccountFlow(any(Context.class), anyInt());
openBookmarkManagerAndCheckSigninPromoIsDisplayed(); showBookmarkManagerAndCheckSigninPromoIsDisplayed();
onView(withId(R.id.signin_promo_signin_button)).perform(click()); onView(withId(R.id.signin_promo_signin_button)).perform(click());
verify(mMockSigninActivityLauncher) verify(mMockSigninActivityLauncher)
.launchActivityForPromoAddAccountFlow( .launchActivityForPromoAddAccountFlow(
any(BookmarkActivity.class), eq(SigninAccessPoint.BOOKMARK_MANAGER)); any(Activity.class), eq(SigninAccessPoint.BOOKMARK_MANAGER));
} }
private void openBookmarkManagerAndCheckSigninPromoIsDisplayed() { private void showBookmarkManagerAndCheckSigninPromoIsDisplayed() {
openBookmarkManager(); BookmarkTestUtil.showBookmarkManager(mActivityTestRule.getActivity());
onView(withId(R.id.signin_promo_view_container)).check(matches(isDisplayed())); onView(withId(R.id.signin_promo_view_container)).check(matches(isDisplayed()));
} }
private void openBookmarkManager() {
TestThreadUtils.runOnUiThreadBlocking(
() -> BookmarkUtils.showBookmarkManager(mActivityTestRule.getActivity()));
BookmarkTestUtil.waitForBookmarkModelLoaded();
}
private void addTestAccount() { private void addTestAccount() {
Account account = AccountManagerFacade.createAccountFromName(TEST_ACCOUNT_NAME); Account account = AccountManagerFacade.createAccountFromName(TEST_ACCOUNT_NAME);
AccountHolder.Builder accountHolder = AccountHolder.builder(account).alwaysAccept(true); AccountHolder.Builder accountHolder = AccountHolder.builder(account).alwaysAccept(true);
......
...@@ -4,7 +4,9 @@ ...@@ -4,7 +4,9 @@
package org.chromium.chrome.test.util; package org.chromium.chrome.test.util;
import org.chromium.chrome.browser.ChromeActivity;
import org.chromium.chrome.browser.bookmarks.BookmarkModel; import org.chromium.chrome.browser.bookmarks.BookmarkModel;
import org.chromium.chrome.browser.bookmarks.BookmarkUtils;
import org.chromium.content_public.browser.test.util.CriteriaHelper; import org.chromium.content_public.browser.test.util.CriteriaHelper;
import org.chromium.content_public.browser.test.util.TestThreadUtils; import org.chromium.content_public.browser.test.util.TestThreadUtils;
...@@ -25,4 +27,12 @@ public class BookmarkTestUtil { ...@@ -25,4 +27,12 @@ public class BookmarkTestUtil {
TestThreadUtils.runOnUiThreadBlocking(bookmarkModel::destroy); TestThreadUtils.runOnUiThreadBlocking(bookmarkModel::destroy);
} }
/**
* Show BookmarkManager and wait till the bookmark model is loaded.
*/
public static void showBookmarkManager(ChromeActivity activity) {
TestThreadUtils.runOnUiThreadBlocking(() -> BookmarkUtils.showBookmarkManager(activity));
waitForBookmarkModelLoaded();
}
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment