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;
|
||||||
@@ -129,7 +131,7 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
suggestions = savedInstanceState.getParcelableArrayList(STATE_SUGGESTION_LIST);
|
suggestions = savedInstanceState.getParcelableArrayList(STATE_SUGGESTION_LIST);
|
||||||
category = savedInstanceState.getParcelable(STATE_CATEGORY_LIST);
|
category = savedInstanceState.getParcelable(STATE_CATEGORY_LIST);
|
||||||
suggestionConditionMode = savedInstanceState.getInt(
|
suggestionConditionMode = savedInstanceState.getInt(
|
||||||
STATE_SUGGESTION_CONDITION_MODE, suggestionConditionMode);
|
STATE_SUGGESTION_CONDITION_MODE, suggestionConditionMode);
|
||||||
mSuggestionsShownLogged = savedInstanceState.getStringArrayList(
|
mSuggestionsShownLogged = savedInstanceState.getStringArrayList(
|
||||||
STATE_SUGGESTIONS_SHOWN_LOGGED);
|
STATE_SUGGESTIONS_SHOWN_LOGGED);
|
||||||
} else {
|
} else {
|
||||||
@@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -249,7 +252,7 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
break;
|
break;
|
||||||
case R.layout.suggestion_condition_container:
|
case R.layout.suggestion_condition_container:
|
||||||
onBindConditionAndSuggestion(
|
onBindConditionAndSuggestion(
|
||||||
(SuggestionAndConditionContainerHolder) holder, position);
|
(SuggestionAndConditionContainerHolder) holder, position);
|
||||||
break;
|
break;
|
||||||
case R.layout.suggestion_condition_header:
|
case R.layout.suggestion_condition_header:
|
||||||
onBindSuggestionConditionHeader((SuggestionAndConditionHeaderHolder) holder,
|
onBindSuggestionConditionHeader((SuggestionAndConditionHeaderHolder) holder,
|
||||||
@@ -262,7 +265,7 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND, false);
|
MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND, false);
|
||||||
DashboardData prevData = mDashboardData;
|
DashboardData prevData = mDashboardData;
|
||||||
mDashboardData = new DashboardData.Builder(prevData).setSuggestionConditionMode(
|
mDashboardData = new DashboardData.Builder(prevData).setSuggestionConditionMode(
|
||||||
DashboardData.HEADER_MODE_COLLAPSED).build();
|
DashboardData.HEADER_MODE_COLLAPSED).build();
|
||||||
notifyDashboardDataChanged(prevData);
|
notifyDashboardDataChanged(prevData);
|
||||||
mRecyclerView.scrollToPosition(SUGGESTION_CONDITION_HEADER_POSITION);
|
mRecyclerView.scrollToPosition(SUGGESTION_CONDITION_HEADER_POSITION);
|
||||||
});
|
});
|
||||||
@@ -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();
|
||||||
@@ -335,11 +339,11 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
}
|
}
|
||||||
for (Tile suggestion : suggestions) {
|
for (Tile suggestion : suggestions) {
|
||||||
final String suggestionId = mSuggestionFeatureProvider.getSuggestionIdentifier(
|
final String suggestionId = mSuggestionFeatureProvider.getSuggestionIdentifier(
|
||||||
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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -350,9 +354,9 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
SuggestionConditionHeaderData data) {
|
SuggestionConditionHeaderData data) {
|
||||||
final int curMode = mDashboardData.getSuggestionConditionMode();
|
final int curMode = mDashboardData.getSuggestionConditionMode();
|
||||||
final int nextMode = data.hiddenSuggestionCount > 0 && data.conditionCount > 0
|
final int nextMode = data.hiddenSuggestionCount > 0 && data.conditionCount > 0
|
||||||
&& curMode != DashboardData.HEADER_MODE_SUGGESTION_EXPANDED
|
&& curMode != DashboardData.HEADER_MODE_SUGGESTION_EXPANDED
|
||||||
? DashboardData.HEADER_MODE_SUGGESTION_EXPANDED
|
? DashboardData.HEADER_MODE_SUGGESTION_EXPANDED
|
||||||
: DashboardData.HEADER_MODE_FULLY_EXPANDED;
|
: DashboardData.HEADER_MODE_FULLY_EXPANDED;
|
||||||
final boolean moreSuggestions = data.hiddenSuggestionCount > 0;
|
final boolean moreSuggestions = data.hiddenSuggestionCount > 0;
|
||||||
final boolean hasConditions = data.conditionCount > 0;
|
final boolean hasConditions = data.conditionCount > 0;
|
||||||
if (data.conditionCount > 0) {
|
if (data.conditionCount > 0) {
|
||||||
@@ -377,22 +381,22 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
if (curMode == DashboardData.HEADER_MODE_COLLAPSED) {
|
if (curMode == DashboardData.HEADER_MODE_COLLAPSED) {
|
||||||
if (data.conditionCount > 0) {
|
if (data.conditionCount > 0) {
|
||||||
holder.summary.setText(mContext.getResources().getQuantityString(
|
holder.summary.setText(mContext.getResources().getQuantityString(
|
||||||
R.plurals.suggestions_collapsed_summary,
|
R.plurals.suggestions_collapsed_summary,
|
||||||
data.hiddenSuggestionCount, data.hiddenSuggestionCount));
|
data.hiddenSuggestionCount, data.hiddenSuggestionCount));
|
||||||
} else {
|
} else {
|
||||||
holder.title.setText(mContext.getResources().getQuantityString(
|
holder.title.setText(mContext.getResources().getQuantityString(
|
||||||
R.plurals.suggestions_collapsed_title,
|
R.plurals.suggestions_collapsed_title,
|
||||||
data.hiddenSuggestionCount, data.hiddenSuggestionCount));
|
data.hiddenSuggestionCount, data.hiddenSuggestionCount));
|
||||||
holder.title.setTextColor(Color.BLACK);
|
holder.title.setTextColor(Color.BLACK);
|
||||||
holder.summary.setText(null);
|
holder.summary.setText(null);
|
||||||
}
|
}
|
||||||
} else if (curMode == DashboardData.HEADER_MODE_DEFAULT) {
|
} else if (curMode == DashboardData.HEADER_MODE_DEFAULT) {
|
||||||
if (data.conditionCount > 0) {
|
if (data.conditionCount > 0) {
|
||||||
holder.summary.setText(mContext.getString(
|
holder.summary.setText(mContext.getString(
|
||||||
R.string.suggestions_summary, data.hiddenSuggestionCount));
|
R.string.suggestions_summary, data.hiddenSuggestionCount));
|
||||||
} else {
|
} else {
|
||||||
holder.title.setText(mContext.getString(
|
holder.title.setText(mContext.getString(
|
||||||
R.string.suggestions_more_title, data.hiddenSuggestionCount));
|
R.string.suggestions_more_title, data.hiddenSuggestionCount));
|
||||||
holder.title.setTextColor(Color.BLACK);
|
holder.title.setTextColor(Color.BLACK);
|
||||||
holder.summary.setText(null);
|
holder.summary.setText(null);
|
||||||
}
|
}
|
||||||
@@ -400,7 +404,7 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
} else if (data.conditionCount > 1) {
|
} else if (data.conditionCount > 1) {
|
||||||
holder.summary.setTextColor(Utils.getColorAccent(mContext));
|
holder.summary.setTextColor(Utils.getColorAccent(mContext));
|
||||||
holder.summary.setText(
|
holder.summary.setText(
|
||||||
mContext.getString(R.string.condition_summary, data.conditionCount));
|
mContext.getString(R.string.condition_summary, data.conditionCount));
|
||||||
} else {
|
} else {
|
||||||
holder.summary.setText(null);
|
holder.summary.setText(null);
|
||||||
}
|
}
|
||||||
@@ -413,16 +417,16 @@ 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,
|
||||||
MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND, true);
|
MetricsEvent.ACTION_SETTINGS_CONDITION_EXPAND, true);
|
||||||
}
|
}
|
||||||
DashboardData prevData = mDashboardData;
|
DashboardData prevData = mDashboardData;
|
||||||
final boolean wasCollapsed = curMode == DashboardData.HEADER_MODE_COLLAPSED;
|
final boolean wasCollapsed = curMode == DashboardData.HEADER_MODE_COLLAPSED;
|
||||||
mDashboardData = new DashboardData.Builder(prevData)
|
mDashboardData = new DashboardData.Builder(prevData)
|
||||||
.setSuggestionConditionMode(nextMode).build();
|
.setSuggestionConditionMode(nextMode).build();
|
||||||
notifyDashboardDataChanged(prevData);
|
notifyDashboardDataChanged(prevData);
|
||||||
if (wasCollapsed) {
|
if (wasCollapsed) {
|
||||||
mRecyclerView.scrollToPosition(SUGGESTION_CONDITION_HEADER_POSITION);
|
mRecyclerView.scrollToPosition(SUGGESTION_CONDITION_HEADER_POSITION);
|
||||||
@@ -439,13 +443,13 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
if (position == SUGGESTION_CONDITION_HEADER_POSITION
|
if (position == SUGGESTION_CONDITION_HEADER_POSITION
|
||||||
&& suggestions != null && suggestions.size() > 0) {
|
&& suggestions != null && suggestions.size() > 0) {
|
||||||
mSuggestionAdapter = new SuggestionAdapter(mContext, (List<Tile>)
|
mSuggestionAdapter = new SuggestionAdapter(mContext, (List<Tile>)
|
||||||
mDashboardData.getItemEntityByPosition(position), mSuggestionsShownLogged);
|
mDashboardData.getItemEntityByPosition(position), mSuggestionsShownLogged);
|
||||||
mSuggestionDismissHandler = new SuggestionDismissController(mContext,
|
mSuggestionDismissHandler = new SuggestionDismissController(mContext,
|
||||||
holder.data, mSuggestionParser, mCallback);
|
holder.data, mSuggestionParser, mCallback);
|
||||||
holder.data.setAdapter(mSuggestionAdapter);
|
holder.data.setAdapter(mSuggestionAdapter);
|
||||||
} else {
|
} else {
|
||||||
ConditionAdapter adapter = new ConditionAdapter(mContext,
|
ConditionAdapter adapter = new ConditionAdapter(mContext,
|
||||||
(List<Condition>) mDashboardData.getItemEntityByPosition(position),
|
(List<Condition>) mDashboardData.getItemEntityByPosition(position),
|
||||||
mDashboardData.getSuggestionConditionMode());
|
mDashboardData.getSuggestionConditionMode());
|
||||||
adapter.addDismissHandling(holder.data);
|
adapter.addDismissHandling(holder.data);
|
||||||
holder.data.setAdapter(adapter);
|
holder.data.setAdapter(adapter);
|
||||||
@@ -507,7 +511,7 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
}
|
}
|
||||||
outState.putStringArrayList(STATE_SUGGESTIONS_SHOWN_LOGGED, mSuggestionsShownLogged);
|
outState.putStringArrayList(STATE_SUGGESTIONS_SHOWN_LOGGED, mSuggestionsShownLogged);
|
||||||
outState.putInt(STATE_SUGGESTION_CONDITION_MODE,
|
outState.putInt(STATE_SUGGESTION_CONDITION_MODE,
|
||||||
mDashboardData.getSuggestionConditionMode());
|
mDashboardData.getSuggestionConditionMode());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateConditionIcons(List<Icon> icons, ViewGroup parent) {
|
private void updateConditionIcons(List<Icon> icons, ViewGroup parent) {
|
||||||
@@ -519,13 +523,18 @@ public class DashboardAdapter extends RecyclerView.Adapter<DashboardAdapter.Dash
|
|||||||
parent.removeAllViews();
|
parent.removeAllViews();
|
||||||
for (int i = 1, size = icons.size(); i < size; i++) {
|
for (int i = 1, size = icons.size(); i < size; i++) {
|
||||||
ImageView icon = (ImageView) inflater.inflate(
|
ImageView icon = (ImageView) inflater.inflate(
|
||||||
R.layout.condition_header_icon, parent, false);
|
R.layout.condition_header_icon, parent, false);
|
||||||
icon.setImageIcon(icons.get(i));
|
icon.setImageIcon(icons.get(i));
|
||||||
parent.addView(icon);
|
parent.addView(icon);
|
||||||
}
|
}
|
||||||
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;
|
||||||
@@ -67,11 +68,12 @@ public class SuggestionAdapter extends RecyclerView.Adapter<DashboardItemHolder>
|
|||||||
public void onBindViewHolder(DashboardItemHolder holder, int position) {
|
public void onBindViewHolder(DashboardItemHolder holder, int position) {
|
||||||
final Tile suggestion = (Tile) mSuggestions.get(position);
|
final Tile suggestion = (Tile) mSuggestions.get(position);
|
||||||
final String suggestionId = mSuggestionFeatureProvider.getSuggestionIdentifier(
|
final String suggestionId = mSuggestionFeatureProvider.getSuggestionIdentifier(
|
||||||
mContext, suggestion);
|
mContext, suggestion);
|
||||||
// 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