Merge "Log smart settings suggestion enabled/disabled state for A/B experiments" into oc-mr1-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
339fd95209
@@ -30,6 +30,7 @@ import android.support.v7.widget.RecyclerView;
|
|||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.ArrayMap;
|
import android.util.ArrayMap;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
import android.util.Pair;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
@@ -47,6 +48,7 @@ import com.android.settings.dashboard.conditional.ConditionAdapter;
|
|||||||
import com.android.settings.dashboard.suggestions.SuggestionAdapter;
|
import com.android.settings.dashboard.suggestions.SuggestionAdapter;
|
||||||
import com.android.settings.dashboard.suggestions.SuggestionDismissController;
|
import com.android.settings.dashboard.suggestions.SuggestionDismissController;
|
||||||
import com.android.settings.dashboard.suggestions.SuggestionFeatureProvider;
|
import com.android.settings.dashboard.suggestions.SuggestionFeatureProvider;
|
||||||
|
import com.android.settings.dashboard.suggestions.SuggestionLogHelper;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settingslib.Utils;
|
import com.android.settingslib.Utils;
|
||||||
import com.android.settingslib.drawer.DashboardCategory;
|
import com.android.settingslib.drawer.DashboardCategory;
|
||||||
@@ -172,7 +174,8 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
final String identifier = mSuggestionFeatureProvider.getSuggestionIdentifier(
|
final String identifier = mSuggestionFeatureProvider.getSuggestionIdentifier(
|
||||||
mContext, suggestion);
|
mContext, suggestion);
|
||||||
mMetricsFeatureProvider.action(
|
mMetricsFeatureProvider.action(
|
||||||
mContext, MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION, identifier);
|
mContext, MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION, identifier,
|
||||||
|
getSuggestionTaggedData());
|
||||||
mSuggestionsShownLogged.add(identifier);
|
mSuggestionsShownLogged.add(identifier);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -302,7 +305,8 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
mContext, suggestion);
|
mContext, suggestion);
|
||||||
if (mSuggestionsShownLogged.contains(suggestionId)) {
|
if (mSuggestionsShownLogged.contains(suggestionId)) {
|
||||||
mMetricsFeatureProvider.action(
|
mMetricsFeatureProvider.action(
|
||||||
mContext, MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION, suggestionId);
|
mContext, MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION, suggestionId,
|
||||||
|
getSuggestionTaggedData());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mSuggestionsShownLogged.clear();
|
mSuggestionsShownLogged.clear();
|
||||||
@@ -338,8 +342,8 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
mContext, suggestion);
|
mContext, suggestion);
|
||||||
if (!mSuggestionsShownLogged.contains(suggestionId)) {
|
if (!mSuggestionsShownLogged.contains(suggestionId)) {
|
||||||
mMetricsFeatureProvider.action(
|
mMetricsFeatureProvider.action(
|
||||||
mContext, MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
mContext, MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION, suggestionId,
|
||||||
suggestionId);
|
getSuggestionTaggedData());
|
||||||
mSuggestionsShownLogged.add(suggestionId);
|
mSuggestionsShownLogged.add(suggestionId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -413,7 +417,7 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
holder.itemView.setPadding(0, padding, 0, padding);
|
holder.itemView.setPadding(0, padding, 0, padding);
|
||||||
|
|
||||||
holder.itemView.setOnClickListener(v -> {
|
holder.itemView.setOnClickListener(v -> {
|
||||||
if (moreSuggestions ) {
|
if (moreSuggestions) {
|
||||||
logSuggestions();
|
logSuggestions();
|
||||||
} else if (hasConditions) {
|
} else if (hasConditions) {
|
||||||
mMetricsFeatureProvider.action(mContext,
|
mMetricsFeatureProvider.action(mContext,
|
||||||
@@ -526,6 +530,11 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
parent.setVisibility(View.VISIBLE);
|
parent.setVisibility(View.VISIBLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Pair<Integer, Object>[] getSuggestionTaggedData() {
|
||||||
|
return SuggestionLogHelper.getSuggestionTaggedData(
|
||||||
|
mSuggestionFeatureProvider.isSmartSuggestionEnabled(mContext));
|
||||||
|
}
|
||||||
|
|
||||||
public static class IconCache {
|
public static class IconCache {
|
||||||
private final Context mContext;
|
private final Context mContext;
|
||||||
private final ArrayMap<Icon, Drawable> mMap = new ArrayMap<>();
|
private final ArrayMap<Icon, Drawable> mMap = new ArrayMap<>();
|
||||||
|
@@ -18,6 +18,7 @@ package com.android.settings.dashboard.suggestions;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.support.v7.widget.RecyclerView;
|
import android.support.v7.widget.RecyclerView;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
|
import android.util.Pair;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
@@ -71,7 +72,8 @@ public class SuggestionAdapter extends RecyclerView.Adapter<DashboardItemHolder>
|
|||||||
// This is for cases when a suggestion is dismissed and the next one comes to view
|
// This is for cases when a suggestion is dismissed and the next one comes to view
|
||||||
if (!mSuggestionsShownLogged.contains(suggestionId)) {
|
if (!mSuggestionsShownLogged.contains(suggestionId)) {
|
||||||
mMetricsFeatureProvider.action(
|
mMetricsFeatureProvider.action(
|
||||||
mContext, MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION, suggestionId);
|
mContext, MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION, suggestionId,
|
||||||
|
getSuggestionTaggedData());
|
||||||
mSuggestionsShownLogged.add(suggestionId);
|
mSuggestionsShownLogged.add(suggestionId);
|
||||||
}
|
}
|
||||||
if (suggestion.remoteViews != null) {
|
if (suggestion.remoteViews != null) {
|
||||||
@@ -102,9 +104,11 @@ public class SuggestionAdapter extends RecyclerView.Adapter<DashboardItemHolder>
|
|||||||
// set the item view to disabled to remove any touch effects
|
// set the item view to disabled to remove any touch effects
|
||||||
holder.itemView.setEnabled(false);
|
holder.itemView.setEnabled(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
clickHandler.setOnClickListener(v -> {
|
clickHandler.setOnClickListener(v -> {
|
||||||
mMetricsFeatureProvider.action(mContext,
|
mMetricsFeatureProvider.action(mContext,
|
||||||
MetricsEvent.ACTION_SETTINGS_SUGGESTION, suggestionId);
|
MetricsEvent.ACTION_SETTINGS_SUGGESTION, suggestionId,
|
||||||
|
getSuggestionTaggedData());
|
||||||
((SettingsActivity) mContext).startSuggestion(suggestion.intent);
|
((SettingsActivity) mContext).startSuggestion(suggestion.intent);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -129,7 +133,7 @@ public class SuggestionAdapter extends RecyclerView.Adapter<DashboardItemHolder>
|
|||||||
|
|
||||||
public Tile getSuggestion(int position) {
|
public Tile getSuggestion(int position) {
|
||||||
final long itemId = getItemId(position);
|
final long itemId = getItemId(position);
|
||||||
for (Tile tile: mSuggestions) {
|
for (Tile tile : mSuggestions) {
|
||||||
if (Objects.hash(tile.title) == itemId) {
|
if (Objects.hash(tile.title) == itemId) {
|
||||||
return tile;
|
return tile;
|
||||||
}
|
}
|
||||||
@@ -141,4 +145,10 @@ public class SuggestionAdapter extends RecyclerView.Adapter<DashboardItemHolder>
|
|||||||
mSuggestions.remove(suggestion);
|
mSuggestions.remove(suggestion);
|
||||||
notifyDataSetChanged();
|
notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Pair<Integer, Object>[] getSuggestionTaggedData() {
|
||||||
|
return SuggestionLogHelper.getSuggestionTaggedData(
|
||||||
|
mSuggestionFeatureProvider.isSmartSuggestionEnabled(mContext));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -26,8 +26,9 @@ import android.provider.Settings.Secure;
|
|||||||
import android.support.annotation.NonNull;
|
import android.support.annotation.NonNull;
|
||||||
import android.support.annotation.VisibleForTesting;
|
import android.support.annotation.VisibleForTesting;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
import android.util.Pair;
|
||||||
|
|
||||||
import com.android.internal.logging.nano.MetricsProto;
|
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
||||||
import com.android.settings.Settings.AmbientDisplayPickupSuggestionActivity;
|
import com.android.settings.Settings.AmbientDisplayPickupSuggestionActivity;
|
||||||
import com.android.settings.Settings.AmbientDisplaySuggestionActivity;
|
import com.android.settings.Settings.AmbientDisplaySuggestionActivity;
|
||||||
import com.android.settings.Settings.DoubleTapPowerSuggestionActivity;
|
import com.android.settings.Settings.DoubleTapPowerSuggestionActivity;
|
||||||
@@ -45,6 +46,7 @@ import com.android.settings.support.NewDeviceIntroSuggestionActivity;
|
|||||||
import com.android.settingslib.drawer.Tile;
|
import com.android.settingslib.drawer.Tile;
|
||||||
import com.android.settingslib.suggestions.SuggestionParser;
|
import com.android.settingslib.suggestions.SuggestionParser;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class SuggestionFeatureProviderImpl implements SuggestionFeatureProvider {
|
public class SuggestionFeatureProviderImpl implements SuggestionFeatureProvider {
|
||||||
@@ -130,10 +132,13 @@ public class SuggestionFeatureProviderImpl implements SuggestionFeatureProvider
|
|||||||
if (parser == null || suggestion == null || context == null) {
|
if (parser == null || suggestion == null || context == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
mMetricsFeatureProvider.action(
|
final Pair<Integer, Object>[] taggedData =
|
||||||
context, MetricsProto.MetricsEvent.ACTION_SETTINGS_DISMISS_SUGGESTION,
|
SuggestionLogHelper.getSuggestionTaggedData(isSmartSuggestionEnabled(context));
|
||||||
getSuggestionIdentifier(context, suggestion));
|
|
||||||
|
|
||||||
|
mMetricsFeatureProvider.action(
|
||||||
|
context, MetricsEvent.ACTION_SETTINGS_DISMISS_SUGGESTION,
|
||||||
|
getSuggestionIdentifier(context, suggestion),
|
||||||
|
taggedData);
|
||||||
if (!parser.dismissSuggestion(suggestion)) {
|
if (!parser.dismissSuggestion(suggestion)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@@ -0,0 +1,29 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2017 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.settings.dashboard.suggestions;
|
||||||
|
|
||||||
|
import android.util.Pair;
|
||||||
|
|
||||||
|
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
||||||
|
|
||||||
|
public class SuggestionLogHelper {
|
||||||
|
|
||||||
|
public static Pair<Integer, Object>[] getSuggestionTaggedData(boolean enabled) {
|
||||||
|
return new Pair[]{
|
||||||
|
Pair.create(
|
||||||
|
MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, enabled ? 1 : 0)};
|
||||||
|
}
|
||||||
|
}
|
@@ -37,6 +37,7 @@ import android.graphics.drawable.Icon;
|
|||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.support.v7.widget.RecyclerView;
|
import android.support.v7.widget.RecyclerView;
|
||||||
import android.util.DisplayMetrics;
|
import android.util.DisplayMetrics;
|
||||||
|
import android.util.Pair;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.widget.RelativeLayout;
|
import android.widget.RelativeLayout;
|
||||||
@@ -89,6 +90,8 @@ public class DashboardAdapterTest {
|
|||||||
private ArgumentCaptor<Integer> mActionCategoryCaptor = ArgumentCaptor.forClass(Integer.class);
|
private ArgumentCaptor<Integer> mActionCategoryCaptor = ArgumentCaptor.forClass(Integer.class);
|
||||||
@Captor
|
@Captor
|
||||||
private ArgumentCaptor<String> mActionPackageCaptor = ArgumentCaptor.forClass(String.class);
|
private ArgumentCaptor<String> mActionPackageCaptor = ArgumentCaptor.forClass(String.class);
|
||||||
|
@Captor
|
||||||
|
private ArgumentCaptor<Pair> mTaggedDataCaptor = ArgumentCaptor.forClass(Pair.class);
|
||||||
private FakeFeatureFactory mFactory;
|
private FakeFeatureFactory mFactory;
|
||||||
private DashboardAdapter mDashboardAdapter;
|
private DashboardAdapter mDashboardAdapter;
|
||||||
private DashboardAdapter.SuggestionAndConditionHeaderHolder mSuggestionHolder;
|
private DashboardAdapter.SuggestionAndConditionHeaderHolder mSuggestionHolder;
|
||||||
@@ -123,112 +126,143 @@ public class DashboardAdapterTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testSuggestionsLogs_NotExpanded() {
|
public void testSuggestionsLogs_NotExpanded() {
|
||||||
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
||||||
|
|
||||||
verify(mFactory.metricsFeatureProvider, times(2)).action(
|
verify(mFactory.metricsFeatureProvider, times(2)).action(
|
||||||
any(Context.class), mActionCategoryCaptor.capture(),
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
mActionPackageCaptor.capture());
|
mActionPackageCaptor.capture(),
|
||||||
String[] expectedPackages = new String[]{"pkg1", "pkg2"};
|
mTaggedDataCaptor.capture());
|
||||||
Integer[] expectedActions = new Integer[]{
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION);
|
||||||
};
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly("pkg1", "pkg2");
|
||||||
assertThat(mActionCategoryCaptor.getAllValues().toArray()).isEqualTo(expectedActions);
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
assertThat(mActionPackageCaptor.getAllValues().toArray()).isEqualTo(expectedPackages);
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSuggestionsLogs_NotExpandedAndPaused() {
|
public void testSuggestionsLogs_NotExpandedAndPaused() {
|
||||||
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
||||||
|
|
||||||
mDashboardAdapter.onPause();
|
mDashboardAdapter.onPause();
|
||||||
|
|
||||||
verify(mFactory.metricsFeatureProvider, times(4)).action(
|
verify(mFactory.metricsFeatureProvider, times(4)).action(
|
||||||
any(Context.class), mActionCategoryCaptor.capture(),
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
mActionPackageCaptor.capture());
|
mActionPackageCaptor.capture(),
|
||||||
String[] expectedPackages = new String[]{"pkg1", "pkg2", "pkg1", "pkg2"};
|
mTaggedDataCaptor.capture());
|
||||||
Integer[] expectedActions = new Integer[]{
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION};
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION);
|
||||||
assertThat(mActionCategoryCaptor.getAllValues().toArray()).isEqualTo(expectedActions);
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly(
|
||||||
assertThat(mActionPackageCaptor.getAllValues().toArray()).isEqualTo(expectedPackages);
|
"pkg1", "pkg2", "pkg1", "pkg2");
|
||||||
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSuggestionsLogs_Expanded() {
|
public void testSuggestionsLogs_Expanded() {
|
||||||
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
||||||
|
|
||||||
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
||||||
mSuggestionHolder.itemView.callOnClick();
|
mSuggestionHolder.itemView.callOnClick();
|
||||||
|
|
||||||
verify(mFactory.metricsFeatureProvider, times(3)).action(
|
verify(mFactory.metricsFeatureProvider, times(3)).action(
|
||||||
any(Context.class), mActionCategoryCaptor.capture(),
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
mActionPackageCaptor.capture());
|
mActionPackageCaptor.capture(),
|
||||||
String[] expectedPackages = new String[]{"pkg1", "pkg2", "pkg3"};
|
mTaggedDataCaptor.capture());
|
||||||
Integer[] expectedActions = new Integer[]{
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION);
|
||||||
};
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly(
|
||||||
assertThat(mActionPackageCaptor.getAllValues().toArray()).isEqualTo(expectedPackages);
|
"pkg1", "pkg2", "pkg3");
|
||||||
assertThat(mActionCategoryCaptor.getAllValues().toArray()).isEqualTo(expectedActions);
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSuggestionsLogs_ExpandedAndPaused() {
|
public void testSuggestionsLogs_ExpandedAndPaused() {
|
||||||
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
||||||
|
|
||||||
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
||||||
mSuggestionHolder.itemView.callOnClick();
|
mSuggestionHolder.itemView.callOnClick();
|
||||||
mDashboardAdapter.onPause();
|
mDashboardAdapter.onPause();
|
||||||
|
|
||||||
verify(mFactory.metricsFeatureProvider, times(6)).action(
|
verify(mFactory.metricsFeatureProvider, times(6)).action(
|
||||||
any(Context.class), mActionCategoryCaptor.capture(),
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
mActionPackageCaptor.capture());
|
mActionPackageCaptor.capture(),
|
||||||
String[] expectedPackages = new String[]{"pkg1", "pkg2", "pkg3", "pkg1", "pkg2", "pkg3"};
|
mTaggedDataCaptor.capture());
|
||||||
Integer[] expectedActions = new Integer[]{
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION);
|
||||||
};
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly(
|
||||||
assertThat(mActionPackageCaptor.getAllValues().toArray()).isEqualTo(expectedPackages);
|
"pkg1", "pkg2", "pkg3", "pkg1", "pkg2", "pkg3");
|
||||||
assertThat(mActionCategoryCaptor.getAllValues().toArray()).isEqualTo(expectedActions);
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSuggestionsLogs_ExpandedAfterPause() {
|
public void testSuggestionsLogs_ExpandedAfterPause() {
|
||||||
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
||||||
|
|
||||||
mDashboardAdapter.onPause();
|
mDashboardAdapter.onPause();
|
||||||
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
||||||
mSuggestionHolder.itemView.callOnClick();
|
mSuggestionHolder.itemView.callOnClick();
|
||||||
|
|
||||||
verify(mFactory.metricsFeatureProvider, times(7)).action(
|
verify(mFactory.metricsFeatureProvider, times(7)).action(
|
||||||
any(Context.class), mActionCategoryCaptor.capture(),
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
mActionPackageCaptor.capture());
|
mActionPackageCaptor.capture(),
|
||||||
String[] expectedPackages = new String[]{
|
mTaggedDataCaptor.capture());
|
||||||
"pkg1", "pkg2", "pkg1", "pkg2", "pkg1", "pkg2", "pkg3"};
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
Integer[] expectedActions = new Integer[]{
|
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION);
|
||||||
};
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly(
|
||||||
assertThat(mActionPackageCaptor.getAllValues().toArray()).isEqualTo(expectedPackages);
|
"pkg1", "pkg2", "pkg1", "pkg2", "pkg1", "pkg2", "pkg3");
|
||||||
assertThat(mActionCategoryCaptor.getAllValues().toArray()).isEqualTo(expectedActions);
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSuggestionsLogs_ExpandedAfterPauseAndPausedAgain() {
|
public void testSuggestionsLogs_ExpandedAfterPauseAndPausedAgain() {
|
||||||
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
setupSuggestions(makeSuggestions("pkg1", "pkg2", "pkg3"));
|
||||||
|
|
||||||
mDashboardAdapter.onPause();
|
mDashboardAdapter.onPause();
|
||||||
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
||||||
mSuggestionHolder.itemView.callOnClick();
|
mSuggestionHolder.itemView.callOnClick();
|
||||||
mDashboardAdapter.onPause();
|
mDashboardAdapter.onPause();
|
||||||
|
|
||||||
verify(mFactory.metricsFeatureProvider, times(10)).action(
|
verify(mFactory.metricsFeatureProvider, times(10)).action(
|
||||||
any(Context.class), mActionCategoryCaptor.capture(),
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
mActionPackageCaptor.capture());
|
mActionPackageCaptor.capture(),
|
||||||
String[] expectedPackages = new String[]{
|
mTaggedDataCaptor.capture());
|
||||||
"pkg1", "pkg2", "pkg1", "pkg2", "pkg1", "pkg2", "pkg3", "pkg1", "pkg2", "pkg3"};
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
Integer[] expectedActions = new Integer[]{
|
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
||||||
@@ -238,63 +272,82 @@ public class DashboardAdapterTest {
|
|||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION);
|
||||||
};
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly(
|
||||||
assertThat(mActionPackageCaptor.getAllValues().toArray()).isEqualTo(expectedPackages);
|
"pkg1", "pkg2", "pkg1", "pkg2", "pkg1", "pkg2", "pkg3", "pkg1", "pkg2", "pkg3");
|
||||||
assertThat(mActionCategoryCaptor.getAllValues().toArray()).isEqualTo(expectedActions);
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSuggestionsLogs_ExpandedWithLessThanDefaultShown() {
|
public void testSuggestionsLogs_ExpandedWithLessThanDefaultShown() {
|
||||||
setupSuggestions(makeSuggestions("pkg1"));
|
setupSuggestions(makeSuggestions("pkg1"));
|
||||||
|
|
||||||
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
||||||
mSuggestionHolder.itemView.callOnClick();
|
mSuggestionHolder.itemView.callOnClick();
|
||||||
|
|
||||||
verify(mFactory.metricsFeatureProvider, times(1)).action(
|
verify(mFactory.metricsFeatureProvider, times(1)).action(
|
||||||
any(Context.class), mActionCategoryCaptor.capture(),
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
mActionPackageCaptor.capture());
|
mActionPackageCaptor.capture(),
|
||||||
String[] expectedPackages = new String[]{"pkg1"};
|
mTaggedDataCaptor.capture());
|
||||||
Integer[] expectedActions = new Integer[]{
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION);
|
||||||
};
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly("pkg1");
|
||||||
assertThat(mActionPackageCaptor.getAllValues().toArray()).isEqualTo(expectedPackages);
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
assertThat(mActionCategoryCaptor.getAllValues().toArray()).isEqualTo(expectedActions);
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSuggestionsLogs_ExpandedWithLessThanDefaultShownAndPaused() {
|
public void testSuggestionsLogs_ExpandedWithLessThanDefaultShownAndPaused() {
|
||||||
setupSuggestions(makeSuggestions("pkg1"));
|
setupSuggestions(makeSuggestions("pkg1"));
|
||||||
|
|
||||||
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
||||||
mSuggestionHolder.itemView.callOnClick();
|
mSuggestionHolder.itemView.callOnClick();
|
||||||
mDashboardAdapter.onPause();
|
mDashboardAdapter.onPause();
|
||||||
|
|
||||||
verify(mFactory.metricsFeatureProvider, times(2)).action(
|
verify(mFactory.metricsFeatureProvider, times(2)).action(
|
||||||
any(Context.class), mActionCategoryCaptor.capture(),
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
mActionPackageCaptor.capture());
|
mActionPackageCaptor.capture(),
|
||||||
String[] expectedPackages = new String[]{"pkg1", "pkg1"};
|
mTaggedDataCaptor.capture());
|
||||||
Integer[] expectedActions = new Integer[]{
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION);
|
||||||
};
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly("pkg1", "pkg1");
|
||||||
assertThat(mActionPackageCaptor.getAllValues().toArray()).isEqualTo(expectedPackages);
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
assertThat(mActionCategoryCaptor.getAllValues().toArray()).isEqualTo(expectedActions);
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSuggestionsLogs_ExpandedWithLessThanDefaultShownAfterPause() {
|
public void testSuggestionsLogs_ExpandedWithLessThanDefaultShownAfterPause() {
|
||||||
setupSuggestions(makeSuggestions("pkg1"));
|
setupSuggestions(makeSuggestions("pkg1"));
|
||||||
|
|
||||||
mDashboardAdapter.onPause();
|
mDashboardAdapter.onPause();
|
||||||
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
||||||
mSuggestionHolder.itemView.callOnClick();
|
mSuggestionHolder.itemView.callOnClick();
|
||||||
|
|
||||||
verify(mFactory.metricsFeatureProvider, times(3)).action(
|
verify(mFactory.metricsFeatureProvider, times(3)).action(
|
||||||
any(Context.class), mActionCategoryCaptor.capture(),
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
mActionPackageCaptor.capture());
|
mActionPackageCaptor.capture(),
|
||||||
String[] expectedPackages = new String[]{"pkg1", "pkg1", "pkg1"};
|
mTaggedDataCaptor.capture());
|
||||||
Integer[] expectedActions = new Integer[]{
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION);
|
||||||
};
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly("pkg1", "pkg1", "pkg1");
|
||||||
assertThat(mActionPackageCaptor.getAllValues().toArray()).isEqualTo(expectedPackages);
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
assertThat(mActionCategoryCaptor.getAllValues().toArray()).isEqualTo(expectedActions);
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -304,18 +357,46 @@ public class DashboardAdapterTest {
|
|||||||
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
||||||
mSuggestionHolder.itemView.callOnClick();
|
mSuggestionHolder.itemView.callOnClick();
|
||||||
mDashboardAdapter.onPause();
|
mDashboardAdapter.onPause();
|
||||||
|
|
||||||
verify(mFactory.metricsFeatureProvider, times(4)).action(
|
verify(mFactory.metricsFeatureProvider, times(4)).action(
|
||||||
any(Context.class), mActionCategoryCaptor.capture(),
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
mActionPackageCaptor.capture());
|
mActionPackageCaptor.capture(),
|
||||||
String[] expectedPackages = new String[]{"pkg1", "pkg1", "pkg1", "pkg1"};
|
mTaggedDataCaptor.capture());
|
||||||
Integer[] expectedActions = new Integer[]{
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION);
|
||||||
};
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly(
|
||||||
assertThat(mActionPackageCaptor.getAllValues().toArray()).isEqualTo(expectedPackages);
|
"pkg1", "pkg1", "pkg1", "pkg1");
|
||||||
assertThat(mActionCategoryCaptor.getAllValues().toArray()).isEqualTo(expectedActions);
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testSuggestionsLogs_SmartSuggestionEnabled() {
|
||||||
|
when(mFactory.suggestionsFeatureProvider
|
||||||
|
.isSmartSuggestionEnabled(any(Context.class))).thenReturn(true);
|
||||||
|
setupSuggestions(makeSuggestions("pkg1"));
|
||||||
|
|
||||||
|
mDashboardAdapter.onBindSuggestionConditionHeader(mSuggestionHolder, mSuggestionHeaderData);
|
||||||
|
mSuggestionHolder.itemView.callOnClick();
|
||||||
|
mDashboardAdapter.onPause();
|
||||||
|
|
||||||
|
verify(mFactory.metricsFeatureProvider, times(2)).action(
|
||||||
|
any(Context.class), mActionCategoryCaptor.capture(),
|
||||||
|
mActionPackageCaptor.capture(),
|
||||||
|
mTaggedDataCaptor.capture());
|
||||||
|
assertThat(mActionCategoryCaptor.getAllValues()).containsExactly(
|
||||||
|
MetricsEvent.ACTION_SHOW_SETTINGS_SUGGESTION,
|
||||||
|
MetricsEvent.ACTION_HIDE_SETTINGS_SUGGESTION);
|
||||||
|
assertThat(mActionPackageCaptor.getAllValues()).containsExactly("pkg1", "pkg1");
|
||||||
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 1),
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@@ -35,7 +35,9 @@ import android.content.SharedPreferences;
|
|||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.hardware.fingerprint.FingerprintManager;
|
import android.hardware.fingerprint.FingerprintManager;
|
||||||
import android.provider.Settings.Secure;
|
import android.provider.Settings.Secure;
|
||||||
|
import android.util.Pair;
|
||||||
|
|
||||||
|
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
||||||
import com.android.internal.logging.nano.MetricsProto;
|
import com.android.internal.logging.nano.MetricsProto;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.Settings.AmbientDisplayPickupSuggestionActivity;
|
import com.android.settings.Settings.AmbientDisplayPickupSuggestionActivity;
|
||||||
@@ -60,6 +62,8 @@ import org.junit.Before;
|
|||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Answers;
|
import org.mockito.Answers;
|
||||||
|
import org.mockito.ArgumentCaptor;
|
||||||
|
import org.mockito.Captor;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
@@ -93,6 +97,8 @@ public class SuggestionFeatureProviderImplTest {
|
|||||||
private FingerprintManager mFingerprintManager;
|
private FingerprintManager mFingerprintManager;
|
||||||
@Mock
|
@Mock
|
||||||
private SharedPreferences mSharedPreferences;
|
private SharedPreferences mSharedPreferences;
|
||||||
|
@Captor
|
||||||
|
private ArgumentCaptor<Pair> mTaggedDataCaptor = ArgumentCaptor.forClass(Pair.class);
|
||||||
|
|
||||||
private FakeFeatureFactory mFactory;
|
private FakeFeatureFactory mFactory;
|
||||||
private SuggestionFeatureProviderImpl mProvider;
|
private SuggestionFeatureProviderImpl mProvider;
|
||||||
@@ -335,7 +341,10 @@ public class SuggestionFeatureProviderImplTest {
|
|||||||
verify(mFactory.metricsFeatureProvider).action(
|
verify(mFactory.metricsFeatureProvider).action(
|
||||||
eq(mContext),
|
eq(mContext),
|
||||||
eq(MetricsProto.MetricsEvent.ACTION_SETTINGS_DISMISS_SUGGESTION),
|
eq(MetricsProto.MetricsEvent.ACTION_SETTINGS_DISMISS_SUGGESTION),
|
||||||
anyString());
|
anyString(),
|
||||||
|
mTaggedDataCaptor.capture());
|
||||||
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
verify(mContext, never()).getPackageManager();
|
verify(mContext, never()).getPackageManager();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -356,8 +365,10 @@ public class SuggestionFeatureProviderImplTest {
|
|||||||
verify(mFactory.metricsFeatureProvider).action(
|
verify(mFactory.metricsFeatureProvider).action(
|
||||||
eq(mContext),
|
eq(mContext),
|
||||||
eq(MetricsProto.MetricsEvent.ACTION_SETTINGS_DISMISS_SUGGESTION),
|
eq(MetricsProto.MetricsEvent.ACTION_SETTINGS_DISMISS_SUGGESTION),
|
||||||
anyString());
|
anyString(),
|
||||||
|
mTaggedDataCaptor.capture());
|
||||||
|
assertThat(mTaggedDataCaptor.getAllValues()).containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
verify(mContext.getPackageManager())
|
verify(mContext.getPackageManager())
|
||||||
.setComponentEnabledSetting(mSuggestion.intent.getComponent(),
|
.setComponentEnabledSetting(mSuggestion.intent.getComponent(),
|
||||||
PackageManager.COMPONENT_ENABLED_STATE_DISABLED,
|
PackageManager.COMPONENT_ENABLED_STATE_DISABLED,
|
||||||
|
@@ -0,0 +1,41 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2017 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.settings.dashboard.suggestions;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import android.util.Pair;
|
||||||
|
|
||||||
|
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
public class SuggestionLogHelperTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetSmartSuggestionEnabledTaggedData_disabled() {
|
||||||
|
assertThat(SuggestionLogHelper.getSuggestionTaggedData(false)).asList().containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 0));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetSmartSuggestionEnabledTaggedData_enabled() {
|
||||||
|
assertThat(SuggestionLogHelper.getSuggestionTaggedData(true)).asList().containsExactly(
|
||||||
|
Pair.create(MetricsEvent.FIELD_SETTINGS_SMART_SUGGESTIONS_ENABLED, 1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Reference in New Issue
Block a user