Merge "Added suggestions for gestures." into oc-dr1-dev
This commit is contained in:
@@ -16,29 +16,6 @@
|
||||
|
||||
package com.android.settings.dashboard.suggestions;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.content.pm.PackageManager;
|
||||
|
||||
import com.android.internal.logging.nano.MetricsProto;
|
||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||
import com.android.settings.TestConfig;
|
||||
import com.android.settings.testutils.FakeFeatureFactory;
|
||||
import com.android.settingslib.drawer.Tile;
|
||||
import com.android.settingslib.suggestions.SuggestionParser;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.mockito.Answers;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.MockitoAnnotations;
|
||||
import org.robolectric.RuntimeEnvironment;
|
||||
import org.robolectric.annotation.Config;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
import static org.mockito.Matchers.any;
|
||||
import static org.mockito.Matchers.anyBoolean;
|
||||
@@ -49,10 +26,46 @@ import static org.mockito.Mockito.verify;
|
||||
import static org.mockito.Mockito.verifyZeroInteractions;
|
||||
import static org.mockito.Mockito.when;
|
||||
|
||||
import android.content.ComponentName;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.content.pm.PackageManager;
|
||||
import com.android.internal.logging.nano.MetricsProto;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.Settings.AmbientDisplaySuggestionActivity;
|
||||
import com.android.settings.Settings.AmbientDisplayPickupSuggestionActivity;
|
||||
import com.android.settings.Settings.DoubleTapPowerSuggestionActivity;
|
||||
import com.android.settings.Settings.DoubleTwistSuggestionActivity;
|
||||
import com.android.settings.Settings.SwipeToNotificationSuggestionActivity;
|
||||
import com.android.settings.TestConfig;
|
||||
import com.android.settings.gestures.DoubleTapPowerSettings;
|
||||
import com.android.settings.gestures.DoubleTapScreenSettings;
|
||||
import com.android.settings.gestures.PickupGestureSettings;
|
||||
import com.android.settings.gestures.SwipeToNotificationSettings;
|
||||
import com.android.settings.testutils.FakeFeatureFactory;
|
||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||
import com.android.settings.testutils.shadow.SettingsShadowResources;
|
||||
import com.android.settingslib.drawer.Tile;
|
||||
import com.android.settingslib.suggestions.SuggestionParser;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.mockito.Answers;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.MockitoAnnotations;
|
||||
import org.robolectric.RuntimeEnvironment;
|
||||
import org.robolectric.annotation.Config;
|
||||
|
||||
@RunWith(SettingsRobolectricTestRunner.class)
|
||||
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
|
||||
public class SuggestionFeatureProviderImplTest {
|
||||
|
||||
private static final String DOUBLE_TWIST_SENSOR_NAME = "double_twist_sensor_name";
|
||||
private static final String DOUBLE_TWIST_SENSOR_VENDOR = "double_twist_sensor_vendor";
|
||||
|
||||
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
||||
private Context mContext;
|
||||
@Mock
|
||||
@@ -75,6 +88,149 @@ public class SuggestionFeatureProviderImplTest {
|
||||
mProvider = new SuggestionFeatureProviderImpl(mContext);
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_doubleTapPower_trueWhenNotAvailable() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.bool.config_cameraDoubleTapPowerGestureEnabled, false);
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
DoubleTapPowerSuggestionActivity.class))).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_doubleTapPower_falseWhenNotVisited() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.bool.config_cameraDoubleTapPowerGestureEnabled, true);
|
||||
// No stored value in shared preferences if not visited yet.
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
DoubleTapPowerSuggestionActivity.class))).isFalse();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_doubleTapPower_trueWhenVisited() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.bool.config_cameraDoubleTapPowerGestureEnabled, true);
|
||||
mProvider.getSharedPrefs(RuntimeEnvironment.application).edit().putBoolean(
|
||||
DoubleTapPowerSettings.PREF_KEY_SUGGESTION_COMPLETE, true).commit();
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
DoubleTapPowerSuggestionActivity.class))).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_doubleTwist_trueWhenNotAvailable() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
R.string.gesture_double_twist_sensor_name, "nonexistant name");
|
||||
SettingsShadowResources.overrideResource(
|
||||
R.string.gesture_double_twist_sensor_vendor, "nonexistant vendor");
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
DoubleTwistSuggestionActivity.class))).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_ambientDisplay_falseWhenNotVisited() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.string.config_dozeComponent, "foo");
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.string.config_dozeDoubleTapSensorType, "bar");
|
||||
// No stored value in shared preferences if not visited yet.
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
AmbientDisplaySuggestionActivity.class))).isFalse();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_ambientDisplay_trueWhenVisited() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.string.config_dozeComponent, "foo");
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.string.config_dozeDoubleTapSensorType, "bar");
|
||||
mProvider.getSharedPrefs(RuntimeEnvironment.application).edit().putBoolean(
|
||||
DoubleTapScreenSettings.PREF_KEY_SUGGESTION_COMPLETE, true).commit();
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
AmbientDisplaySuggestionActivity.class))).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_ambientDisplayPickup_falseWhenNotVisited() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.string.config_dozeComponent, "foo");
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.bool.config_dozePulsePickup, true);
|
||||
// No stored value in shared preferences if not visited yet.
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
AmbientDisplaySuggestionActivity.class))).isFalse();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_ambientDisplayPickup_trueWhenVisited() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.string.config_dozeComponent, "foo");
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.bool.config_dozePulsePickup, true);
|
||||
mProvider.getSharedPrefs(RuntimeEnvironment.application).edit().putBoolean(
|
||||
PickupGestureSettings.PREF_KEY_SUGGESTION_COMPLETE, true).commit();
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
AmbientDisplayPickupSuggestionActivity.class))).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_swipeToNotification_trueWhenNotAvailable() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.bool.config_supportSystemNavigationKeys, false);
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
SwipeToNotificationSuggestionActivity.class))).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_swipeToNotification_falseWhenNotVisited() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.bool.config_supportSystemNavigationKeys, true);
|
||||
// No stored value in shared preferences if not visited yet.
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
SwipeToNotificationSuggestionActivity.class))).isFalse();
|
||||
}
|
||||
|
||||
@Test
|
||||
@Config(shadows = SettingsShadowResources.class)
|
||||
public void isSuggestionCompleted_swipeToNotification_trueWhenVisited() {
|
||||
SettingsShadowResources.overrideResource(
|
||||
com.android.internal.R.bool.config_supportSystemNavigationKeys, true);
|
||||
mProvider.getSharedPrefs(RuntimeEnvironment.application).edit().putBoolean(
|
||||
SwipeToNotificationSettings.PREF_KEY_SUGGESTION_COMPLETE, true).commit();
|
||||
|
||||
assertThat(mProvider.isSuggestionCompleted(RuntimeEnvironment.application,
|
||||
new ComponentName(RuntimeEnvironment.application,
|
||||
SwipeToNotificationSuggestionActivity.class))).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void dismissSuggestion_noParserOrSuggestion_noop() {
|
||||
mProvider.dismissSuggestion(mContext, null, null);
|
||||
|
Reference in New Issue
Block a user