Add support to show first impression type suggestions

- Add FIRST_IMPRESSION type in suggestion order list.
- Make rule changes for a few suggestions.

Bug: 37947647
Test: manual

Change-Id: I2101f5e0f6424723bacc9f5febf2ffaab9398896
This commit is contained in:
Fan Zhang
2017-05-08 09:31:01 -07:00
parent 0498d4e864
commit 7afbf0f3a2
5 changed files with 91 additions and 68 deletions

View File

@@ -766,9 +766,9 @@
android:icon="@drawable/ic_settings_notifications" android:icon="@drawable/ic_settings_notifications"
android:exported="true" android:exported="true"
android:taskAffinity=""> android:taskAffinity="">
<intent-filter android:priority="1"> <intent-filter>
<action android:name="android.intent.action.MAIN" /> <action android:name="android.intent.action.MAIN" />
<category android:name="com.android.settings.suggested.category.SETTINGS_ONLY" /> <category android:name="com.android.settings.suggested.category.FIRST_IMPRESSION" />
</intent-filter> </intent-filter>
<meta-data android:name="com.android.settings.FRAGMENT_CLASS" <meta-data android:name="com.android.settings.FRAGMENT_CLASS"
android:value="com.android.settings.notification.ZenModeSettings" /> android:value="com.android.settings.notification.ZenModeSettings" />
@@ -792,7 +792,7 @@
android:label="@string/wallpaper_settings_title" android:label="@string/wallpaper_settings_title"
android:icon="@drawable/ic_wallpaper" android:icon="@drawable/ic_wallpaper"
android:theme="@android:style/Theme.NoDisplay"> android:theme="@android:style/Theme.NoDisplay">
<intent-filter android:priority="1"> <intent-filter>
<action android:name="android.intent.action.MAIN" /> <action android:name="android.intent.action.MAIN" />
<category android:name="com.android.settings.suggested.category.SETTINGS_ONLY" /> <category android:name="com.android.settings.suggested.category.SETTINGS_ONLY" />
</intent-filter> </intent-filter>
@@ -1561,10 +1561,10 @@
android:icon="@drawable/ic_suggestion_fingerprint"> android:icon="@drawable/ic_suggestion_fingerprint">
<intent-filter> <intent-filter>
<action android:name="android.intent.action.MAIN" /> <action android:name="android.intent.action.MAIN" />
<category android:name="com.android.settings.suggested.category.SETTINGS_ONLY" /> <category android:name="com.android.settings.suggested.category.FIRST_IMPRESSION" />
</intent-filter> </intent-filter>
<meta-data android:name="com.android.settings.dismiss" <meta-data android:name="com.android.settings.dismiss"
android:value="10,30" /> android:value="4,8,30" />
<meta-data android:name="com.android.settings.require_feature" <meta-data android:name="com.android.settings.require_feature"
android:value="android.hardware.fingerprint" /> android:value="android.hardware.fingerprint" />
<meta-data android:name="com.android.settings.title" <meta-data android:name="com.android.settings.title"
@@ -2769,7 +2769,7 @@
android:taskAffinity=""> android:taskAffinity="">
<intent-filter> <intent-filter>
<action android:name="android.intent.action.MAIN" /> <action android:name="android.intent.action.MAIN" />
<category android:name="com.android.settings.suggested.category.SETTINGS_ONLY" /> <category android:name="com.android.settings.suggested.category.FIRST_IMPRESSION" />
</intent-filter> </intent-filter>
<meta-data android:name="com.android.settings.FRAGMENT_CLASS" <meta-data android:name="com.android.settings.FRAGMENT_CLASS"
android:value="com.android.settings.WifiCallingSettings" /> android:value="com.android.settings.WifiCallingSettings" />
@@ -3082,10 +3082,16 @@
android:label="@string/camera_lift_trigger_title" android:label="@string/camera_lift_trigger_title"
android:icon="@drawable/ic_settings_camera" android:icon="@drawable/ic_settings_camera"
android:enabled="@bool/config_cameraLiftTriggerAvailable"> android:enabled="@bool/config_cameraLiftTriggerAvailable">
<intent-filter android:priority="1"> <intent-filter>
<action android:name="android.intent.action.MAIN" /> <action android:name="android.intent.action.MAIN" />
<category android:name="com.android.settings.suggested.category.GESTURE" /> <category android:name="com.android.settings.suggested.category.GESTURE" />
</intent-filter> </intent-filter>
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="com.android.settings.suggested.category.FIRST_IMPRESSION" />
</intent-filter>
<meta-data android:name="com.android.settings.dismiss"
android:value="3,7,30" />
<meta-data android:name="com.android.settings.FRAGMENT_CLASS" <meta-data android:name="com.android.settings.FRAGMENT_CLASS"
android:value="com.android.settings.gestures.CameraLiftTriggerSettings"/> android:value="com.android.settings.gestures.CameraLiftTriggerSettings"/>
<meta-data android:name="com.android.settings.title" <meta-data android:name="com.android.settings.title"

View File

@@ -16,16 +16,20 @@
<optional-steps> <optional-steps>
<step category="com.android.settings.suggested.category.DEFERRED_SETUP" <step category="com.android.settings.suggested.category.DEFERRED_SETUP"
exclusive="true" /> exclusive="true" />
<step category="com.android.settings.suggested.category.FIRST_IMPRESSION"
exclusiveExpireDays="7"
exclusive="true"
multiple="true" />
<step category="com.android.settings.suggested.category.LOCK_SCREEN" /> <step category="com.android.settings.suggested.category.LOCK_SCREEN" />
<step category="com.android.settings.suggested.category.TRUST_AGENT" /> <step category="com.android.settings.suggested.category.TRUST_AGENT" />
<step category="com.android.settings.suggested.category.EMAIL" /> <step category="com.android.settings.suggested.category.EMAIL" />
<step category="com.android.settings.suggested.category.PARTNER_ACCOUNT" <step category="com.android.settings.suggested.category.PARTNER_ACCOUNT"
multiple="true" /> multiple="true" />
<step category="com.android.settings.suggested.category.GESTURE" /> <step category="com.android.settings.suggested.category.GESTURE" />
<step category="com.android.settings.suggested.category.HOTWORD" /> <step category="com.android.settings.suggested.category.HOTWORD" />
<step category="com.android.settings.suggested.category.DEFAULT" <step category="com.android.settings.suggested.category.DEFAULT"
multiple="true" /> multiple="true" />
<step category="com.android.settings.suggested.category.SETTINGS_ONLY" <step category="com.android.settings.suggested.category.SETTINGS_ONLY"
multiple="true" /> multiple="true" />
</optional-steps> </optional-steps>

View File

@@ -78,7 +78,6 @@ public class SuggestionFeatureProviderImpl implements SuggestionFeatureProvider
suggestion.intent.getComponent(), suggestion.intent.getComponent(),
PackageManager.COMPONENT_ENABLED_STATE_DISABLED, PackageManager.COMPONENT_ENABLED_STATE_DISABLED,
PackageManager.DONT_KILL_APP); PackageManager.DONT_KILL_APP);
parser.markCategoryDone(suggestion.category);
} }
@Override @Override

View File

@@ -111,9 +111,9 @@ public class SuggestionFeatureProviderImplTest {
public void getSuggestionIdentifier_nullContext_shouldNotCrash() { public void getSuggestionIdentifier_nullContext_shouldNotCrash() {
final Tile suggestion = new Tile(); final Tile suggestion = new Tile();
suggestion.intent = new Intent() suggestion.intent = new Intent()
.setClassName(RuntimeEnvironment.application.getPackageName(), "123"); .setClassName(RuntimeEnvironment.application.getPackageName(), "123");
assertThat(mProvider.getSuggestionIdentifier(null, suggestion)) assertThat(mProvider.getSuggestionIdentifier(null, suggestion))
.isNotEmpty(); .isNotEmpty();
} }
@Test @Test
@@ -152,6 +152,5 @@ public class SuggestionFeatureProviderImplTest {
.setComponentEnabledSetting(mSuggestion.intent.getComponent(), .setComponentEnabledSetting(mSuggestion.intent.getComponent(),
PackageManager.COMPONENT_ENABLED_STATE_DISABLED, PackageManager.COMPONENT_ENABLED_STATE_DISABLED,
PackageManager.DONT_KILL_APP); PackageManager.DONT_KILL_APP);
verify(mSuggestionParser).markCategoryDone(mSuggestion.category);
} }
} }

View File

@@ -16,17 +16,13 @@
package com.android.settings.suggestions; package com.android.settings.suggestions;
import static com.android.settings.TestConfig.MANIFEST_PATH;
import static com.google.common.truth.Truth.assertThat;
import android.annotation.StringRes; import android.annotation.StringRes;
import android.content.Context; import android.content.Context;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.SettingsRobolectricTestRunner; import com.android.settings.SettingsRobolectricTestRunner;
import com.android.settings.TestConfig; import com.android.settings.TestConfig;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import org.junit.Test; import org.junit.Test;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
import org.robolectric.RuntimeEnvironment; import org.robolectric.RuntimeEnvironment;
@@ -36,59 +32,78 @@ import org.robolectric.manifest.AndroidManifest;
import org.robolectric.manifest.IntentFilterData; import org.robolectric.manifest.IntentFilterData;
import org.robolectric.shadows.ShadowApplication; import org.robolectric.shadows.ShadowApplication;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import static com.android.settings.TestConfig.MANIFEST_PATH;
import static com.google.common.truth.Truth.assertThat;
@RunWith(SettingsRobolectricTestRunner.class) @RunWith(SettingsRobolectricTestRunner.class)
@Config(manifest = MANIFEST_PATH, sdk = TestConfig.SDK_VERSION) @Config(manifest = MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
public class SettingsSuggestionsTest { public class SettingsSuggestionsTest {
@Test private static final String CATEGORY_FIRST_IMPRESSION =
public void zenModeAutomationSuggestion_isValid() { "com.android.settings.suggested.category.FIRST_IMPRESSION";
assertSuggestionEquals("Settings$ZenModeAutomationSuggestionActivity",
R.string.zen_mode_automation_suggestion_title,
R.string.zen_mode_automation_suggestion_summary);
}
@Test private static final String CATEGORY_SETTINGS_ONLY =
public void wallpaperSuggestion_isValid() { "com.android.settings.suggested.category.SETTINGS_ONLY";
assertSuggestionEquals("com.android.settings.wallpaper.WallpaperSuggestionActivity",
R.string.wallpaper_suggestion_title, R.string.wallpaper_suggestion_summary);
}
@Test @Test
public void fingerprintSuggestion_isValid() { public void zenModeAutomationSuggestion_isValid() {
assertSuggestionEquals("com.android.settings.Settings$FingerprintSuggestionActivity", assertSuggestionEquals("Settings$ZenModeAutomationSuggestionActivity",
R.string.suggestion_additional_fingerprints, CATEGORY_FIRST_IMPRESSION,
R.string.suggestion_additional_fingerprints_summary); R.string.zen_mode_automation_suggestion_title,
} R.string.zen_mode_automation_suggestion_summary);
@Test
public void wifiCallingSuggestion_isValid() {
assertSuggestionEquals("Settings$WifiCallingSuggestionActivity",
R.string.wifi_calling_suggestion_title, R.string.wifi_calling_suggestion_summary);
}
private void assertSuggestionEquals(String activityName, @StringRes int title,
@StringRes int summary) {
final AndroidManifest androidManifest = ShadowApplication.getInstance().getAppManifest();
final ActivityData activityData = androidManifest.getActivityData(activityName);
final Map<String, Object> metaData = activityData.getMetaData().getValueMap();
final Context context = RuntimeEnvironment.application;
final String expectedTitle = context.getString(title);
final String expectedSummary = context.getString(summary);
final String pName= context.getPackageName();
final String actualTitle = context.getString(context.getResources().getIdentifier(
((String) metaData.get("com.android.settings.title")).substring(8), "string", pName));
final String actualSummary = context.getString(context.getResources().getIdentifier(
((String) metaData.get("com.android.settings.summary")).substring(8), "string", pName));
assertThat(actualTitle).isEqualTo(expectedTitle);
assertThat(actualSummary).isEqualTo(expectedSummary);
final List<IntentFilterData> intentFilters = activityData.getIntentFilters();
final List<String> categories = new ArrayList<>();
for (IntentFilterData intentFilter : intentFilters) {
categories.addAll(intentFilter.getCategories());
} }
assertThat(categories).contains("com.android.settings.suggested.category.SETTINGS_ONLY"); @Test
} public void wallpaperSuggestion_isValid() {
assertSuggestionEquals("com.android.settings.wallpaper.WallpaperSuggestionActivity",
CATEGORY_SETTINGS_ONLY,
R.string.wallpaper_suggestion_title, R.string.wallpaper_suggestion_summary);
}
@Test
public void fingerprintSuggestion_isValid() {
assertSuggestionEquals("com.android.settings.Settings$FingerprintSuggestionActivity",
CATEGORY_FIRST_IMPRESSION,
R.string.suggestion_additional_fingerprints,
R.string.suggestion_additional_fingerprints_summary);
}
@Test
public void wifiCallingSuggestion_isValid() {
assertSuggestionEquals("Settings$WifiCallingSuggestionActivity",
CATEGORY_FIRST_IMPRESSION,
R.string.wifi_calling_suggestion_title, R.string.wifi_calling_suggestion_summary);
}
private void assertSuggestionEquals(String activityName, String category, @StringRes int title,
@StringRes int summary) {
final AndroidManifest androidManifest = ShadowApplication.getInstance().getAppManifest();
final ActivityData activityData = androidManifest.getActivityData(activityName);
final Map<String, Object> metaData = activityData.getMetaData().getValueMap();
final Context context = RuntimeEnvironment.application;
final String expectedTitle = context.getString(title);
final String expectedSummary = context.getString(summary);
final String pName = context.getPackageName();
final String actualTitle = context.getString(context.getResources().getIdentifier(
((String) metaData.get("com.android.settings.title")).substring(8), "string",
pName));
final String actualSummary = context.getString(context.getResources().getIdentifier(
((String) metaData.get("com.android.settings.summary")).substring(8), "string",
pName));
assertThat(actualTitle).isEqualTo(expectedTitle);
assertThat(actualSummary).isEqualTo(expectedSummary);
final List<IntentFilterData> intentFilters = activityData.getIntentFilters();
final List<String> categories = new ArrayList<>();
for (IntentFilterData intentFilter : intentFilters) {
categories.addAll(intentFilter.getCategories());
}
assertThat(categories).contains(category);
}
} }