Merge "Add referrer when launching search intent."
This commit is contained in:
committed by
Android (Google) Code Review
commit
d89332b8c8
@@ -18,6 +18,7 @@ package com.android.settings;
|
|||||||
|
|
||||||
import android.app.ActionBar;
|
import android.app.ActionBar;
|
||||||
import android.app.ActivityManager;
|
import android.app.ActivityManager;
|
||||||
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
@@ -286,7 +287,7 @@ public class SettingsActivity extends SettingsBaseActivity
|
|||||||
final Toolbar toolbar = findViewById(R.id.search_action_bar);
|
final Toolbar toolbar = findViewById(R.id.search_action_bar);
|
||||||
setActionBar(toolbar);
|
setActionBar(toolbar);
|
||||||
FeatureFactory.getFactory(this).getSearchFeatureProvider()
|
FeatureFactory.getFactory(this).getSearchFeatureProvider()
|
||||||
.initSearchToolbar(this, toolbar);
|
.initSearchToolbar(this, toolbar, SettingsEnums.SETTINGS_HOMEPAGE);
|
||||||
}
|
}
|
||||||
|
|
||||||
ActionBar actionBar = getActionBar();
|
ActionBar actionBar = getActionBar();
|
||||||
|
@@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
package com.android.settings.homepage;
|
package com.android.settings.homepage;
|
||||||
|
|
||||||
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.util.FeatureFlagUtils;
|
import android.util.FeatureFlagUtils;
|
||||||
@@ -55,7 +56,7 @@ public class SettingsHomepageActivity extends SettingsBaseActivity {
|
|||||||
|
|
||||||
final Toolbar toolbar = findViewById(R.id.search_action_bar);
|
final Toolbar toolbar = findViewById(R.id.search_action_bar);
|
||||||
FeatureFactory.getFactory(this).getSearchFeatureProvider()
|
FeatureFactory.getFactory(this).getSearchFeatureProvider()
|
||||||
.initSearchToolbar(this /* activity */, toolbar);
|
.initSearchToolbar(this /* activity */, toolbar, SettingsEnums.SETTINGS_HOMEPAGE);
|
||||||
|
|
||||||
final ImageView avatarView = findViewById(R.id.account_avatar);
|
final ImageView avatarView = findViewById(R.id.account_avatar);
|
||||||
final AvatarViewMixin avatarViewMixin = new AvatarViewMixin(this, avatarView);
|
final AvatarViewMixin avatarViewMixin = new AvatarViewMixin(this, avatarView);
|
||||||
|
@@ -25,7 +25,6 @@ import android.content.ComponentName;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.provider.Settings;
|
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.widget.Toolbar;
|
import android.widget.Toolbar;
|
||||||
@@ -40,7 +39,6 @@ import com.android.settingslib.search.SearchIndexableResources;
|
|||||||
*/
|
*/
|
||||||
public interface SearchFeatureProvider {
|
public interface SearchFeatureProvider {
|
||||||
|
|
||||||
Intent SEARCH_UI_INTENT = new Intent(Settings.ACTION_APP_SEARCH_SETTINGS);
|
|
||||||
int REQUEST_CODE = 0;
|
int REQUEST_CODE = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -64,7 +62,7 @@ public interface SearchFeatureProvider {
|
|||||||
/**
|
/**
|
||||||
* Initializes the search toolbar.
|
* Initializes the search toolbar.
|
||||||
*/
|
*/
|
||||||
default void initSearchToolbar(Activity activity, Toolbar toolbar) {
|
default void initSearchToolbar(Activity activity, Toolbar toolbar, int pageId) {
|
||||||
if (activity == null || toolbar == null) {
|
if (activity == null || toolbar == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -87,9 +85,8 @@ public interface SearchFeatureProvider {
|
|||||||
navView.setBackground(null);
|
navView.setBackground(null);
|
||||||
|
|
||||||
toolbar.setOnClickListener(tb -> {
|
toolbar.setOnClickListener(tb -> {
|
||||||
final Intent intent = SEARCH_UI_INTENT;
|
|
||||||
intent.setPackage(getSettingsIntelligencePkgName(activity));
|
|
||||||
final Context context = activity.getApplicationContext();
|
final Context context = activity.getApplicationContext();
|
||||||
|
final Intent intent = buildSearchIntent(context, pageId);
|
||||||
|
|
||||||
if (activity.getPackageManager().queryIntentActivities(intent,
|
if (activity.getPackageManager().queryIntentActivities(intent,
|
||||||
PackageManager.MATCH_DEFAULT_ONLY).isEmpty()) {
|
PackageManager.MATCH_DEFAULT_ONLY).isEmpty()) {
|
||||||
@@ -97,10 +94,12 @@ public interface SearchFeatureProvider {
|
|||||||
}
|
}
|
||||||
|
|
||||||
FeatureFactory.getFactory(context).getSlicesFeatureProvider()
|
FeatureFactory.getFactory(context).getSlicesFeatureProvider()
|
||||||
.indexSliceDataAsync(activity.getApplicationContext());
|
.indexSliceDataAsync(context);
|
||||||
FeatureFactory.getFactory(context).getMetricsFeatureProvider()
|
FeatureFactory.getFactory(context).getMetricsFeatureProvider()
|
||||||
.action(context, SettingsEnums.ACTION_SEARCH_RESULTS);
|
.action(context, SettingsEnums.ACTION_SEARCH_RESULTS);
|
||||||
activity.startActivityForResult(intent, REQUEST_CODE);
|
activity.startActivityForResult(intent, REQUEST_CODE);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Intent buildSearchIntent(Context context, int pageId);
|
||||||
}
|
}
|
||||||
|
@@ -19,6 +19,9 @@ package com.android.settings.search;
|
|||||||
|
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.net.Uri;
|
||||||
|
import android.provider.Settings;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
|
|
||||||
import com.android.settingslib.search.SearchIndexableResources;
|
import com.android.settingslib.search.SearchIndexableResources;
|
||||||
@@ -59,7 +62,22 @@ public class SearchFeatureProviderImpl implements SearchFeatureProvider {
|
|||||||
return mSearchIndexableResources;
|
return mSearchIndexableResources;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Intent buildSearchIntent(Context context, int pageId) {
|
||||||
|
return new Intent(Settings.ACTION_APP_SEARCH_SETTINGS)
|
||||||
|
.setPackage(getSettingsIntelligencePkgName(context))
|
||||||
|
.putExtra(Intent.EXTRA_REFERRER, buildReferrer(context, pageId));
|
||||||
|
}
|
||||||
|
|
||||||
protected boolean isSignatureWhitelisted(Context context, String callerPackage) {
|
protected boolean isSignatureWhitelisted(Context context, String callerPackage) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static Uri buildReferrer(Context context, int pageId) {
|
||||||
|
return new Uri.Builder()
|
||||||
|
.scheme("android-app")
|
||||||
|
.authority(context.getPackageName())
|
||||||
|
.path(String.valueOf(pageId))
|
||||||
|
.build();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -30,11 +30,10 @@ import androidx.fragment.app.Fragment;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.Utils;
|
import com.android.settings.Utils;
|
||||||
|
import com.android.settings.core.InstrumentedFragment;
|
||||||
|
import com.android.settings.core.InstrumentedPreferenceFragment;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settings.search.SearchFeatureProvider;
|
|
||||||
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
import com.android.settingslib.core.lifecycle.ObservableFragment;
|
|
||||||
import com.android.settingslib.core.lifecycle.ObservablePreferenceFragment;
|
|
||||||
import com.android.settingslib.core.lifecycle.events.OnCreateOptionsMenu;
|
import com.android.settingslib.core.lifecycle.events.OnCreateOptionsMenu;
|
||||||
|
|
||||||
public class SearchMenuController implements LifecycleObserver, OnCreateOptionsMenu {
|
public class SearchMenuController implements LifecycleObserver, OnCreateOptionsMenu {
|
||||||
@@ -42,17 +41,21 @@ public class SearchMenuController implements LifecycleObserver, OnCreateOptionsM
|
|||||||
public static final String NEED_SEARCH_ICON_IN_ACTION_BAR = "need_search_icon_in_action_bar";
|
public static final String NEED_SEARCH_ICON_IN_ACTION_BAR = "need_search_icon_in_action_bar";
|
||||||
|
|
||||||
private final Fragment mHost;
|
private final Fragment mHost;
|
||||||
|
private final int mPageId;
|
||||||
|
|
||||||
public static void init(@NonNull ObservablePreferenceFragment host) {
|
public static void init(@NonNull InstrumentedPreferenceFragment host) {
|
||||||
host.getSettingsLifecycle().addObserver(new SearchMenuController(host));
|
host.getSettingsLifecycle().addObserver(
|
||||||
|
new SearchMenuController(host, host.getMetricsCategory()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void init(@NonNull ObservableFragment host) {
|
public static void init(@NonNull InstrumentedFragment host) {
|
||||||
host.getSettingsLifecycle().addObserver(new SearchMenuController(host));
|
host.getSettingsLifecycle().addObserver(
|
||||||
|
new SearchMenuController(host, host.getMetricsCategory()));
|
||||||
}
|
}
|
||||||
|
|
||||||
private SearchMenuController(@NonNull Fragment host) {
|
private SearchMenuController(@NonNull Fragment host, int pageId) {
|
||||||
mHost = host;
|
mHost = host;
|
||||||
|
mPageId = pageId;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -79,8 +82,9 @@ public class SearchMenuController implements LifecycleObserver, OnCreateOptionsM
|
|||||||
searchItem.setShowAsAction(MenuItem.SHOW_AS_ACTION_ALWAYS);
|
searchItem.setShowAsAction(MenuItem.SHOW_AS_ACTION_ALWAYS);
|
||||||
|
|
||||||
searchItem.setOnMenuItemClickListener(target -> {
|
searchItem.setOnMenuItemClickListener(target -> {
|
||||||
final Intent intent = SearchFeatureProvider.SEARCH_UI_INTENT;
|
final Intent intent = FeatureFactory.getFactory(context)
|
||||||
intent.setPackage(SettingsIntelligencePkgName);
|
.getSearchFeatureProvider()
|
||||||
|
.buildSearchIntent(context, mPageId);
|
||||||
|
|
||||||
if (context.getPackageManager().queryIntentActivities(intent,
|
if (context.getPackageManager().queryIntentActivities(intent,
|
||||||
PackageManager.MATCH_DEFAULT_ONLY).isEmpty()) {
|
PackageManager.MATCH_DEFAULT_ONLY).isEmpty()) {
|
||||||
|
@@ -20,10 +20,12 @@ package com.android.settings.search;
|
|||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.ActivityInfo;
|
import android.content.pm.ActivityInfo;
|
||||||
import android.content.pm.ResolveInfo;
|
import android.content.pm.ResolveInfo;
|
||||||
|
import android.net.Uri;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.widget.Toolbar;
|
import android.widget.Toolbar;
|
||||||
|
|
||||||
@@ -60,19 +62,19 @@ public class SearchFeatureProviderImplTest {
|
|||||||
@Test
|
@Test
|
||||||
@Config(shadows = ShadowUtils.class)
|
@Config(shadows = ShadowUtils.class)
|
||||||
public void initSearchToolbar_hasResolvedInfo_shouldStartCorrectIntent() {
|
public void initSearchToolbar_hasResolvedInfo_shouldStartCorrectIntent() {
|
||||||
final Intent searchIntent = new Intent(SearchFeatureProvider.SEARCH_UI_INTENT)
|
final Intent searchIntent = new Intent(Settings.ACTION_APP_SEARCH_SETTINGS)
|
||||||
.setPackage(mActivity.getString(R.string.config_settingsintelligence_package_name));
|
.setPackage(mActivity.getString(R.string.config_settingsintelligence_package_name));
|
||||||
final ResolveInfo info = new ResolveInfo();
|
final ResolveInfo info = new ResolveInfo();
|
||||||
info.activityInfo = new ActivityInfo();
|
info.activityInfo = new ActivityInfo();
|
||||||
mPackageManager.addResolveInfoForIntent(searchIntent, info);
|
mPackageManager.addResolveInfoForIntent(searchIntent, info);
|
||||||
|
|
||||||
// Should not crash.
|
// Should not crash.
|
||||||
mProvider.initSearchToolbar(mActivity, null);
|
mProvider.initSearchToolbar(mActivity, null, SettingsEnums.TESTING);
|
||||||
|
|
||||||
final Toolbar toolbar = new Toolbar(mActivity);
|
final Toolbar toolbar = new Toolbar(mActivity);
|
||||||
// This ensures navigationView is created.
|
// This ensures navigationView is created.
|
||||||
toolbar.setNavigationContentDescription("test");
|
toolbar.setNavigationContentDescription("test");
|
||||||
mProvider.initSearchToolbar(mActivity, toolbar);
|
mProvider.initSearchToolbar(mActivity, toolbar, SettingsEnums.TESTING);
|
||||||
|
|
||||||
toolbar.performClick();
|
toolbar.performClick();
|
||||||
|
|
||||||
@@ -87,7 +89,7 @@ public class SearchFeatureProviderImplTest {
|
|||||||
final Toolbar toolbar = new Toolbar(mActivity);
|
final Toolbar toolbar = new Toolbar(mActivity);
|
||||||
// This ensures navigationView is created.
|
// This ensures navigationView is created.
|
||||||
toolbar.setNavigationContentDescription("test");
|
toolbar.setNavigationContentDescription("test");
|
||||||
mProvider.initSearchToolbar(mActivity, toolbar);
|
mProvider.initSearchToolbar(mActivity, toolbar, SettingsEnums.TESTING);
|
||||||
|
|
||||||
toolbar.performClick();
|
toolbar.performClick();
|
||||||
|
|
||||||
@@ -108,6 +110,15 @@ public class SearchFeatureProviderImplTest {
|
|||||||
assertThat(Shadows.shadowOf(mActivity).getNextStartedActivity()).isNull();
|
assertThat(Shadows.shadowOf(mActivity).getNextStartedActivity()).isNull();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void buildSearchIntent_shouldIncludeReferrer() {
|
||||||
|
final Intent searchIntent = mProvider.buildSearchIntent(mActivity, SettingsEnums.TESTING);
|
||||||
|
final Uri referrer = searchIntent.getParcelableExtra(Intent.EXTRA_REFERRER);
|
||||||
|
|
||||||
|
assertThat(referrer.toSafeString()).isEqualTo(
|
||||||
|
"android-app://" + mActivity.getPackageName() + "/" + SettingsEnums.TESTING);
|
||||||
|
}
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
@Test(expected = IllegalArgumentException.class)
|
||||||
public void verifyLaunchSearchResultPageCaller_nullCaller_shouldCrash() {
|
public void verifyLaunchSearchResultPageCaller_nullCaller_shouldCrash() {
|
||||||
mProvider.verifyLaunchSearchResultPageCaller(mActivity, null /* caller */);
|
mProvider.verifyLaunchSearchResultPageCaller(mActivity, null /* caller */);
|
||||||
|
@@ -17,11 +17,11 @@
|
|||||||
package com.android.settings.search.actionbar;
|
package com.android.settings.search.actionbar;
|
||||||
|
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.spy;
|
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.verifyZeroInteractions;
|
import static org.mockito.Mockito.verifyZeroInteractions;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.provider.Settings.Global;
|
import android.provider.Settings.Global;
|
||||||
@@ -29,9 +29,9 @@ import android.view.Menu;
|
|||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.InstrumentedFragment;
|
||||||
|
import com.android.settings.core.InstrumentedPreferenceFragment;
|
||||||
import com.android.settings.testutils.shadow.ShadowUtils;
|
import com.android.settings.testutils.shadow.ShadowUtils;
|
||||||
import com.android.settingslib.core.lifecycle.ObservableFragment;
|
|
||||||
import com.android.settingslib.core.lifecycle.ObservablePreferenceFragment;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -49,15 +49,24 @@ public class SearchMenuControllerTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private Menu mMenu;
|
private Menu mMenu;
|
||||||
private TestPreferenceFragment mPreferenceHost;
|
private TestPreferenceFragment mPreferenceHost;
|
||||||
private ObservableFragment mHost;
|
private InstrumentedFragment mHost;
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
mHost = spy(new ObservableFragment());
|
mHost = new InstrumentedFragment() {
|
||||||
when(mHost.getContext()).thenReturn(mContext);
|
@Override
|
||||||
|
public Context getContext() {
|
||||||
|
return mContext;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMetricsCategory() {
|
||||||
|
return SettingsEnums.TESTING;
|
||||||
|
}
|
||||||
|
};
|
||||||
mPreferenceHost = new TestPreferenceFragment();
|
mPreferenceHost = new TestPreferenceFragment();
|
||||||
Global.putInt(mContext.getContentResolver(), Global.DEVICE_PROVISIONED, 1);
|
Global.putInt(mContext.getContentResolver(), Global.DEVICE_PROVISIONED, 1);
|
||||||
|
|
||||||
@@ -101,7 +110,7 @@ public class SearchMenuControllerTest {
|
|||||||
verifyZeroInteractions(mMenu);
|
verifyZeroInteractions(mMenu);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class TestPreferenceFragment extends ObservablePreferenceFragment {
|
private static class TestPreferenceFragment extends InstrumentedPreferenceFragment {
|
||||||
@Override
|
@Override
|
||||||
public void onCreatePreferences(Bundle savedInstanceState, String rootKey) {
|
public void onCreatePreferences(Bundle savedInstanceState, String rootKey) {
|
||||||
}
|
}
|
||||||
@@ -110,5 +119,10 @@ public class SearchMenuControllerTest {
|
|||||||
public Context getContext() {
|
public Context getContext() {
|
||||||
return RuntimeEnvironment.application;
|
return RuntimeEnvironment.application;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMetricsCategory() {
|
||||||
|
return SettingsEnums.TESTING;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user