Gesture Settings and Wireless settings were indexing duplicate results that only added complexity to Search. PowerUsageDetail was never supposed to be indexed. Bug:33701673 Test: make RunSettingsRoboTests Change-Id: I45d1fa4bd412c3418acec24f8c98eb4736f220ab
117 lines
4.3 KiB
Java
117 lines
4.3 KiB
Java
/*
|
|
* Copyright (C) 2016 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.gestures;
|
|
|
|
import android.content.Context;
|
|
import android.hardware.Sensor;
|
|
import android.hardware.SensorManager;
|
|
import android.provider.Settings;
|
|
|
|
import com.android.settings.SettingsRobolectricTestRunner;
|
|
import com.android.settings.TestConfig;
|
|
|
|
import com.android.settings.search2.InlineSwitchPayload;
|
|
import com.android.settings.search2.ResultPayload;
|
|
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.annotation.Config;
|
|
import org.robolectric.shadows.ShadowApplication;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
|
|
import static android.provider.Settings.Secure.CAMERA_DOUBLE_TWIST_TO_FLIP_ENABLED;
|
|
import static com.google.common.truth.Truth.assertThat;
|
|
import static org.mockito.Matchers.anyInt;
|
|
import static org.mockito.Mockito.mock;
|
|
import static org.mockito.Mockito.when;
|
|
|
|
@RunWith(SettingsRobolectricTestRunner.class)
|
|
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
|
|
public class DoubleTwistPreferenceControllerTest {
|
|
|
|
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
|
private Context mContext;
|
|
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
|
private SensorManager mSensorManager;
|
|
private DoubleTwistPreferenceController mController;
|
|
|
|
@Before
|
|
public void setUp() {
|
|
MockitoAnnotations.initMocks(this);
|
|
mController = new DoubleTwistPreferenceController(mContext, null);
|
|
}
|
|
|
|
@Test
|
|
public void isAvailable_hasSensor_shouldReturnTrue() {
|
|
// Mock sensors
|
|
final List<Sensor> sensorList = new ArrayList<>();
|
|
sensorList.add(mock(Sensor.class));
|
|
when(mContext.getResources().getString(anyInt())).thenReturn("test");
|
|
when(mContext.getSystemService(Context.SENSOR_SERVICE)).thenReturn(mSensorManager);
|
|
when(mSensorManager.getSensorList(anyInt())).thenReturn(sensorList);
|
|
when(sensorList.get(0).getName()).thenReturn("test");
|
|
when(sensorList.get(0).getVendor()).thenReturn("test");
|
|
|
|
assertThat(mController.isAvailable()).isTrue();
|
|
}
|
|
|
|
@Test
|
|
public void isAvailable_noSensor_shouldReturnFalse() {
|
|
assertThat(mController.isAvailable()).isFalse();
|
|
}
|
|
|
|
@Test
|
|
public void isAvailable_differentSensor_shouldReturnFalse() {
|
|
// Mock sensors
|
|
final List<Sensor> sensorList = new ArrayList<>();
|
|
sensorList.add(mock(Sensor.class));
|
|
when(mContext.getResources().getString(anyInt())).thenReturn("test");
|
|
when(mContext.getSystemService(Context.SENSOR_SERVICE)).thenReturn(mSensorManager);
|
|
when(mSensorManager.getSensorList(anyInt())).thenReturn(sensorList);
|
|
when(sensorList.get(0).getName()).thenReturn("not_test");
|
|
|
|
assertThat(mController.isAvailable()).isFalse();
|
|
}
|
|
|
|
@Test
|
|
public void testSwitchEnabled_configIsSet_shouldReturnTrue() {
|
|
// Set the setting to be enabled.
|
|
final Context context = ShadowApplication.getInstance().getApplicationContext();
|
|
Settings.System.putInt(context.getContentResolver(),
|
|
CAMERA_DOUBLE_TWIST_TO_FLIP_ENABLED, 1);
|
|
mController = new DoubleTwistPreferenceController(context, null);
|
|
|
|
assertThat(mController.isSwitchPrefEnabled()).isTrue();
|
|
}
|
|
|
|
@Test
|
|
public void testSwitchEnabled_configIsNotSet_shouldReturnFalse() {
|
|
// Set the setting to be disabled.
|
|
final Context context = ShadowApplication.getInstance().getApplicationContext();
|
|
Settings.System.putInt(context.getContentResolver(),
|
|
CAMERA_DOUBLE_TWIST_TO_FLIP_ENABLED, 0);
|
|
mController = new DoubleTwistPreferenceController(context, null);
|
|
|
|
assertThat(mController.isSwitchPrefEnabled()).isFalse();
|
|
}
|
|
}
|