Loading packages/Shell/src/com/android/shell/BugreportProgressService.java +48 −30 Original line number Diff line number Diff line Loading @@ -82,11 +82,14 @@ import android.os.Parcelable; import android.os.RemoteException; import android.os.ServiceManager; import android.os.SystemProperties; import android.os.UserHandle; import android.os.UserManager; import android.os.Vibrator; import android.support.v4.content.FileProvider; import android.text.TextUtils; import android.text.format.DateUtils; import android.util.Log; import android.util.Pair; import android.util.Patterns; import android.util.SparseArray; import android.view.View; Loading Loading @@ -861,9 +864,16 @@ public class BugreportProgressService extends Service { intent.setClipData(clipData); intent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, attachments); final Account sendToAccount = findSendToAccount(context); final Pair<UserHandle, Account> sendToAccount = findSendToAccount(context, SystemProperties.get("sendbug.preferred.domain")); if (sendToAccount != null) { intent.putExtra(Intent.EXTRA_EMAIL, new String[] { sendToAccount.name }); intent.putExtra(Intent.EXTRA_EMAIL, new String[] { sendToAccount.second.name }); // TODO Open the chooser activity on work profile by default. // If we just use startActivityAsUser(), then the launched app couldn't read // attachments. // We probably need to change ChooserActivity to take an extra argument for the // default profile. } return intent; Loading Loading @@ -1109,44 +1119,52 @@ public class BugreportProgressService extends Service { } /** * Find the best matching {@link Account} based on build properties. * Find the best matching {@link Account} based on build properties. If none found, returns * the first account that looks like an email address. */ private static Account findSendToAccount(Context context) { final AccountManager am = (AccountManager) context.getSystemService( Context.ACCOUNT_SERVICE); @VisibleForTesting static Pair<UserHandle, Account> findSendToAccount(Context context, String preferredDomain) { final UserManager um = context.getSystemService(UserManager.class); final AccountManager am = context.getSystemService(AccountManager.class); String preferredDomain = SystemProperties.get("sendbug.preferred.domain"); if (!preferredDomain.startsWith("@")) { if (preferredDomain != null && !preferredDomain.startsWith("@")) { preferredDomain = "@" + preferredDomain; } Pair<UserHandle, Account> first = null; for (UserHandle user : um.getUserProfiles()) { final Account[] accounts; try { accounts = am.getAccounts(); accounts = am.getAccountsAsUser(user.getIdentifier()); } catch (RuntimeException e) { Log.e(TAG, "Could not get accounts for preferred domain " + preferredDomain, e); return null; Log.e(TAG, "Could not get accounts for preferred domain " + preferredDomain + " for user " + user, e); continue; } if (DEBUG) Log.d(TAG, "Number of accounts: " + accounts.length); Account foundAccount = null; if (DEBUG) Log.d(TAG, "User: " + user + " Number of accounts: " + accounts.length); for (Account account : accounts) { if (Patterns.EMAIL_ADDRESS.matcher(account.name).matches()) { if (!preferredDomain.isEmpty()) { final Pair<UserHandle, Account> candidate = Pair.create(user, account); if (!TextUtils.isEmpty(preferredDomain)) { // if we have a preferred domain and it matches, return; otherwise keep // looking if (account.name.endsWith(preferredDomain)) { return account; } else { foundAccount = account; return candidate; } // if we don't have a preferred domain, just return since it looks like // an email address } else { return account; return candidate; } if (first == null) { first = candidate; } } } } return foundAccount; return first; } static Uri getUri(Context context, File file) { Loading packages/Shell/tests/Android.mk +1 −0 Original line number Diff line number Diff line Loading @@ -10,6 +10,7 @@ LOCAL_JAVA_LIBRARIES := android.test.runner LOCAL_STATIC_JAVA_LIBRARIES := \ android-support-test \ mockito-target-minus-junit4 \ ub-uiautomator \ LOCAL_PACKAGE_NAME := ShellTests Loading packages/Shell/tests/src/com/android/shell/BugreportProgressServiceTest.java 0 → 100644 +351 −0 Original line number Diff line number Diff line /* * Copyright (C) 2016 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.shell; import static com.android.shell.BugreportProgressService.findSendToAccount; import static junit.framework.Assert.assertEquals; import static junit.framework.Assert.assertNull; import static org.mockito.Matchers.anyInt; import static org.mockito.Matchers.eq; import static org.mockito.Mockito.when; import android.accounts.Account; import android.accounts.AccountManager; import android.content.Context; import android.os.UserHandle; import android.os.UserManager; import android.support.test.filters.SmallTest; import android.support.test.runner.AndroidJUnit4; import android.test.mock.MockContext; import android.util.Pair; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import org.mockito.Mock; import org.mockito.MockitoAnnotations; import java.util.Arrays; import java.util.List; /** * Test for {@link BugreportProgressServiceTest}. * * Usage: adb shell am instrument -w \ -e class com.android.shell.BugreportProgressServiceTest \ com.android.shell.tests */ @SmallTest @RunWith(AndroidJUnit4.class) public class BugreportProgressServiceTest { private static class MyContext extends MockContext { @Mock public UserManager userManager; @Mock public AccountManager accountManager; public MyContext() { MockitoAnnotations.initMocks(this); } @Override public Object getSystemService(String name) { switch (name) { case Context.USER_SERVICE: return userManager; case Context.ACCOUNT_SERVICE: return accountManager; default: return super.getSystemService(name); } } @Override public String getSystemServiceName(Class<?> serviceClass) { if (UserManager.class.equals(serviceClass)) { return Context.USER_SERVICE; } if (AccountManager.class.equals(serviceClass)) { return Context.ACCOUNT_SERVICE; } return super.getSystemServiceName(serviceClass); } } private final MyContext mTestContext = new MyContext(); private static <T> List<T> list(T... array) { return Arrays.asList(array); } private static <T> T[] array(T... array) { return array; } private Account account(String email) { return new Account(email, "test.com"); } private void checkFindSendToAccount( int expectedUserId, String expectedEmail, String preferredDomain) { final Pair<UserHandle, Account> actual = findSendToAccount(mTestContext, preferredDomain); assertEquals(UserHandle.of(expectedUserId), actual.first); assertEquals(account(expectedEmail), actual.second); } @Test public void findSendToAccount_noWorkProfile() { when(mTestContext.userManager.getUserProfiles()).thenReturn( list(UserHandle.of(UserHandle.USER_SYSTEM))); // No accounts. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array()); assertNull(findSendToAccount(mTestContext, null)); assertNull(findSendToAccount(mTestContext, "")); assertNull(findSendToAccount(mTestContext, "android.com")); assertNull(findSendToAccount(mTestContext, "@android.com")); // 1 account when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, same domain when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, different domains when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // Plut an account that doesn't look like an email address. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("notemail"), account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); } /** * Same as {@link #findSendToAccount_noWorkProfile()}, but with work profile, which has no * accounts. The expected results are the same as the original. */ @Test public void findSendToAccount_withWorkProfile_noAccounts() { when(mTestContext.userManager.getUserProfiles()).thenReturn( list(UserHandle.of(UserHandle.USER_SYSTEM), UserHandle.of(10))); // Work profile has no accounts when(mTestContext.accountManager.getAccountsAsUser(eq(10))).thenReturn( array()); // No accounts. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array()); assertNull(findSendToAccount(mTestContext, null)); assertNull(findSendToAccount(mTestContext, "")); assertNull(findSendToAccount(mTestContext, "android.com")); assertNull(findSendToAccount(mTestContext, "@android.com")); // 1 account when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, same domain when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, different domains when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // Plut an account that doesn't look like an email address. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("notemail"), account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); } /** * Same as {@link #findSendToAccount_noWorkProfile()}, but with work profile, which has * 1 account. The expected results are the same as the original, expect for the "no accounts * on the primary profile" case. */ @Test public void findSendToAccount_withWorkProfile_1account() { when(mTestContext.userManager.getUserProfiles()).thenReturn( list(UserHandle.of(UserHandle.USER_SYSTEM), UserHandle.of(10))); // Work profile has no accounts when(mTestContext.accountManager.getAccountsAsUser(eq(10))).thenReturn( array(account("xyz@gmail.com"))); // No accounts. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array()); checkFindSendToAccount(10, "xyz@gmail.com", null); checkFindSendToAccount(10, "xyz@gmail.com", ""); checkFindSendToAccount(10, "xyz@gmail.com", "android.com"); checkFindSendToAccount(10, "xyz@gmail.com", "@android.com"); // 1 account when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, same domain when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, different domains when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // Plut an account that doesn't look like an email address. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("notemail"), account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); } /** * Same as {@link #findSendToAccount_noWorkProfile()}, but with work profile, with mixed * domains. */ @Test public void findSendToAccount_withWorkProfile_mixedDomains() { when(mTestContext.userManager.getUserProfiles()).thenReturn( list(UserHandle.of(UserHandle.USER_SYSTEM), UserHandle.of(10))); // Work profile has no accounts when(mTestContext.accountManager.getAccountsAsUser(eq(10))).thenReturn( array(account("xyz@android.com"))); // No accounts. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array()); checkFindSendToAccount(10, "xyz@android.com", null); checkFindSendToAccount(10, "xyz@android.com", ""); checkFindSendToAccount(10, "xyz@android.com", "android.com"); checkFindSendToAccount(10, "xyz@android.com", "@android.com"); // 1 account when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(10, "xyz@android.com", "android.com"); checkFindSendToAccount(10, "xyz@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // more accounts. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(10, "xyz@android.com", "android.com"); checkFindSendToAccount(10, "xyz@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); } } Loading
packages/Shell/src/com/android/shell/BugreportProgressService.java +48 −30 Original line number Diff line number Diff line Loading @@ -82,11 +82,14 @@ import android.os.Parcelable; import android.os.RemoteException; import android.os.ServiceManager; import android.os.SystemProperties; import android.os.UserHandle; import android.os.UserManager; import android.os.Vibrator; import android.support.v4.content.FileProvider; import android.text.TextUtils; import android.text.format.DateUtils; import android.util.Log; import android.util.Pair; import android.util.Patterns; import android.util.SparseArray; import android.view.View; Loading Loading @@ -861,9 +864,16 @@ public class BugreportProgressService extends Service { intent.setClipData(clipData); intent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, attachments); final Account sendToAccount = findSendToAccount(context); final Pair<UserHandle, Account> sendToAccount = findSendToAccount(context, SystemProperties.get("sendbug.preferred.domain")); if (sendToAccount != null) { intent.putExtra(Intent.EXTRA_EMAIL, new String[] { sendToAccount.name }); intent.putExtra(Intent.EXTRA_EMAIL, new String[] { sendToAccount.second.name }); // TODO Open the chooser activity on work profile by default. // If we just use startActivityAsUser(), then the launched app couldn't read // attachments. // We probably need to change ChooserActivity to take an extra argument for the // default profile. } return intent; Loading Loading @@ -1109,44 +1119,52 @@ public class BugreportProgressService extends Service { } /** * Find the best matching {@link Account} based on build properties. * Find the best matching {@link Account} based on build properties. If none found, returns * the first account that looks like an email address. */ private static Account findSendToAccount(Context context) { final AccountManager am = (AccountManager) context.getSystemService( Context.ACCOUNT_SERVICE); @VisibleForTesting static Pair<UserHandle, Account> findSendToAccount(Context context, String preferredDomain) { final UserManager um = context.getSystemService(UserManager.class); final AccountManager am = context.getSystemService(AccountManager.class); String preferredDomain = SystemProperties.get("sendbug.preferred.domain"); if (!preferredDomain.startsWith("@")) { if (preferredDomain != null && !preferredDomain.startsWith("@")) { preferredDomain = "@" + preferredDomain; } Pair<UserHandle, Account> first = null; for (UserHandle user : um.getUserProfiles()) { final Account[] accounts; try { accounts = am.getAccounts(); accounts = am.getAccountsAsUser(user.getIdentifier()); } catch (RuntimeException e) { Log.e(TAG, "Could not get accounts for preferred domain " + preferredDomain, e); return null; Log.e(TAG, "Could not get accounts for preferred domain " + preferredDomain + " for user " + user, e); continue; } if (DEBUG) Log.d(TAG, "Number of accounts: " + accounts.length); Account foundAccount = null; if (DEBUG) Log.d(TAG, "User: " + user + " Number of accounts: " + accounts.length); for (Account account : accounts) { if (Patterns.EMAIL_ADDRESS.matcher(account.name).matches()) { if (!preferredDomain.isEmpty()) { final Pair<UserHandle, Account> candidate = Pair.create(user, account); if (!TextUtils.isEmpty(preferredDomain)) { // if we have a preferred domain and it matches, return; otherwise keep // looking if (account.name.endsWith(preferredDomain)) { return account; } else { foundAccount = account; return candidate; } // if we don't have a preferred domain, just return since it looks like // an email address } else { return account; return candidate; } if (first == null) { first = candidate; } } } } return foundAccount; return first; } static Uri getUri(Context context, File file) { Loading
packages/Shell/tests/Android.mk +1 −0 Original line number Diff line number Diff line Loading @@ -10,6 +10,7 @@ LOCAL_JAVA_LIBRARIES := android.test.runner LOCAL_STATIC_JAVA_LIBRARIES := \ android-support-test \ mockito-target-minus-junit4 \ ub-uiautomator \ LOCAL_PACKAGE_NAME := ShellTests Loading
packages/Shell/tests/src/com/android/shell/BugreportProgressServiceTest.java 0 → 100644 +351 −0 Original line number Diff line number Diff line /* * Copyright (C) 2016 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.shell; import static com.android.shell.BugreportProgressService.findSendToAccount; import static junit.framework.Assert.assertEquals; import static junit.framework.Assert.assertNull; import static org.mockito.Matchers.anyInt; import static org.mockito.Matchers.eq; import static org.mockito.Mockito.when; import android.accounts.Account; import android.accounts.AccountManager; import android.content.Context; import android.os.UserHandle; import android.os.UserManager; import android.support.test.filters.SmallTest; import android.support.test.runner.AndroidJUnit4; import android.test.mock.MockContext; import android.util.Pair; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import org.mockito.Mock; import org.mockito.MockitoAnnotations; import java.util.Arrays; import java.util.List; /** * Test for {@link BugreportProgressServiceTest}. * * Usage: adb shell am instrument -w \ -e class com.android.shell.BugreportProgressServiceTest \ com.android.shell.tests */ @SmallTest @RunWith(AndroidJUnit4.class) public class BugreportProgressServiceTest { private static class MyContext extends MockContext { @Mock public UserManager userManager; @Mock public AccountManager accountManager; public MyContext() { MockitoAnnotations.initMocks(this); } @Override public Object getSystemService(String name) { switch (name) { case Context.USER_SERVICE: return userManager; case Context.ACCOUNT_SERVICE: return accountManager; default: return super.getSystemService(name); } } @Override public String getSystemServiceName(Class<?> serviceClass) { if (UserManager.class.equals(serviceClass)) { return Context.USER_SERVICE; } if (AccountManager.class.equals(serviceClass)) { return Context.ACCOUNT_SERVICE; } return super.getSystemServiceName(serviceClass); } } private final MyContext mTestContext = new MyContext(); private static <T> List<T> list(T... array) { return Arrays.asList(array); } private static <T> T[] array(T... array) { return array; } private Account account(String email) { return new Account(email, "test.com"); } private void checkFindSendToAccount( int expectedUserId, String expectedEmail, String preferredDomain) { final Pair<UserHandle, Account> actual = findSendToAccount(mTestContext, preferredDomain); assertEquals(UserHandle.of(expectedUserId), actual.first); assertEquals(account(expectedEmail), actual.second); } @Test public void findSendToAccount_noWorkProfile() { when(mTestContext.userManager.getUserProfiles()).thenReturn( list(UserHandle.of(UserHandle.USER_SYSTEM))); // No accounts. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array()); assertNull(findSendToAccount(mTestContext, null)); assertNull(findSendToAccount(mTestContext, "")); assertNull(findSendToAccount(mTestContext, "android.com")); assertNull(findSendToAccount(mTestContext, "@android.com")); // 1 account when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, same domain when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, different domains when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // Plut an account that doesn't look like an email address. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("notemail"), account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); } /** * Same as {@link #findSendToAccount_noWorkProfile()}, but with work profile, which has no * accounts. The expected results are the same as the original. */ @Test public void findSendToAccount_withWorkProfile_noAccounts() { when(mTestContext.userManager.getUserProfiles()).thenReturn( list(UserHandle.of(UserHandle.USER_SYSTEM), UserHandle.of(10))); // Work profile has no accounts when(mTestContext.accountManager.getAccountsAsUser(eq(10))).thenReturn( array()); // No accounts. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array()); assertNull(findSendToAccount(mTestContext, null)); assertNull(findSendToAccount(mTestContext, "")); assertNull(findSendToAccount(mTestContext, "android.com")); assertNull(findSendToAccount(mTestContext, "@android.com")); // 1 account when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, same domain when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, different domains when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // Plut an account that doesn't look like an email address. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("notemail"), account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); } /** * Same as {@link #findSendToAccount_noWorkProfile()}, but with work profile, which has * 1 account. The expected results are the same as the original, expect for the "no accounts * on the primary profile" case. */ @Test public void findSendToAccount_withWorkProfile_1account() { when(mTestContext.userManager.getUserProfiles()).thenReturn( list(UserHandle.of(UserHandle.USER_SYSTEM), UserHandle.of(10))); // Work profile has no accounts when(mTestContext.accountManager.getAccountsAsUser(eq(10))).thenReturn( array(account("xyz@gmail.com"))); // No accounts. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array()); checkFindSendToAccount(10, "xyz@gmail.com", null); checkFindSendToAccount(10, "xyz@gmail.com", ""); checkFindSendToAccount(10, "xyz@gmail.com", "android.com"); checkFindSendToAccount(10, "xyz@gmail.com", "@android.com"); // 1 account when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, same domain when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "abc@gmail.com", "android.com"); checkFindSendToAccount(0, "abc@gmail.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // 2 accounts, different domains when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // Plut an account that doesn't look like an email address. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("notemail"), account("abc@gmail.com"), account("def@android.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(0, "def@android.com", "android.com"); checkFindSendToAccount(0, "def@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); } /** * Same as {@link #findSendToAccount_noWorkProfile()}, but with work profile, with mixed * domains. */ @Test public void findSendToAccount_withWorkProfile_mixedDomains() { when(mTestContext.userManager.getUserProfiles()).thenReturn( list(UserHandle.of(UserHandle.USER_SYSTEM), UserHandle.of(10))); // Work profile has no accounts when(mTestContext.accountManager.getAccountsAsUser(eq(10))).thenReturn( array(account("xyz@android.com"))); // No accounts. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array()); checkFindSendToAccount(10, "xyz@android.com", null); checkFindSendToAccount(10, "xyz@android.com", ""); checkFindSendToAccount(10, "xyz@android.com", "android.com"); checkFindSendToAccount(10, "xyz@android.com", "@android.com"); // 1 account when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(10, "xyz@android.com", "android.com"); checkFindSendToAccount(10, "xyz@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); // more accounts. when(mTestContext.accountManager.getAccountsAsUser(eq(UserHandle.USER_SYSTEM))).thenReturn( array(account("abc@gmail.com"), account("def@gmail.com"))); checkFindSendToAccount(0, "abc@gmail.com", null); checkFindSendToAccount(0, "abc@gmail.com", ""); checkFindSendToAccount(10, "xyz@android.com", "android.com"); checkFindSendToAccount(10, "xyz@android.com", "@android.com"); checkFindSendToAccount(0, "abc@gmail.com", "gmail.com"); checkFindSendToAccount(0, "abc@gmail.com", "@gmail.com"); } }