Merge "Enable redaction interstitial after setting up pattern" into oc-dev

This commit is contained in:
TreeHugger Robot
2017-04-27 03:40:17 +00:00
committed by Android (Google) Code Review
4 changed files with 139 additions and 1 deletions

View File

@@ -75,7 +75,7 @@ public class SetupChooseLockPattern extends ChooseLockPattern {
protected Intent getRedactionInterstitialIntent(Context context) { protected Intent getRedactionInterstitialIntent(Context context) {
// Setup wizard's redaction interstitial is deferred to optional step. Enable that // Setup wizard's redaction interstitial is deferred to optional step. Enable that
// optional step if the lock screen was set up. // optional step if the lock screen was set up.
SetupRedactionInterstitial.setEnabled(context, false); SetupRedactionInterstitial.setEnabled(context, true);
return null; return null;
} }
} }

View File

@@ -77,6 +77,22 @@ public class SettingsRobolectricTestRunner extends RobolectricTestRunner {
getPackageName(), getPackageName(),
Fs.fileFromPath("./frameworks/base/core/res/res"), Fs.fileFromPath("./frameworks/base/core/res/res"),
null)); null));
paths.add(new ResourcePath(
getPackageName(),
Fs.fileFromPath("./frameworks/opt/setupwizard/library/main/res"),
null));
paths.add(new ResourcePath(
getPackageName(),
Fs.fileFromPath("./frameworks/opt/setupwizard/library/gingerbread/res"),
null));
paths.add(new ResourcePath(
getPackageName(),
Fs.fileFromPath("./frameworks/opt/setupwizard/library/recyclerview/res"),
null));
paths.add(new ResourcePath(
getPackageName(),
Fs.fileFromPath("./frameworks/support/v7/appcompat/res"),
null));
return paths; return paths;
} }
}; };

View File

@@ -0,0 +1,89 @@
/*
* 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;
import static com.google.common.truth.Truth.assertThat;
import static org.robolectric.RuntimeEnvironment.application;
import android.app.Activity;
import android.content.ComponentName;
import android.content.pm.PackageManager;
import android.os.UserHandle;
import com.android.settings.ChooseLockPattern.ChooseLockPatternFragment;
import com.android.settings.testutils.shadow.SettingsShadowResources;
import com.android.settings.testutils.shadow.ShadowDynamicIndexableContentMonitor;
import com.android.settings.testutils.shadow.ShadowEventLogWriter;
import com.android.settings.testutils.shadow.ShadowUtils;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.robolectric.Robolectric;
import org.robolectric.RuntimeEnvironment;
import org.robolectric.annotation.Config;
import org.robolectric.res.builder.RobolectricPackageManager.ComponentState;
@RunWith(SettingsRobolectricTestRunner.class)
@Config(
manifest = TestConfig.MANIFEST_PATH,
sdk = TestConfig.SDK_VERSION,
shadows = {
SettingsShadowResources.class,
SettingsShadowResources.SettingsShadowTheme.class,
ShadowDynamicIndexableContentMonitor.class,
ShadowEventLogWriter.class,
ShadowUtils.class
})
public class SetupChooseLockPatternTest {
private SetupChooseLockPattern mActivity;
@Before
public void setUp() {
RuntimeEnvironment.getRobolectricPackageManager().setComponentEnabledSetting(
new ComponentName(application, SetupRedactionInterstitial.class),
PackageManager.COMPONENT_ENABLED_STATE_DISABLED,
PackageManager.DONT_KILL_APP);
mActivity = Robolectric.buildActivity(
SetupChooseLockPattern.class,
SetupChooseLockPattern.createIntent(
application,
false, /* requirePassword */
false, /* confirmCredentials */
UserHandle.myUserId()))
.setup().get();
}
@Test
public void chooseLockSaved_shouldEnableRedactionInterstitial() {
findFragment(mActivity).onChosenLockSaveFinished(false, null);
ComponentState redactionComponentState =
RuntimeEnvironment.getRobolectricPackageManager().getComponentState(
new ComponentName(application, SetupRedactionInterstitial.class));
assertThat(redactionComponentState.newState).named("Redaction component state")
.isEqualTo(PackageManager.COMPONENT_ENABLED_STATE_ENABLED);
}
private ChooseLockPatternFragment findFragment(Activity activity) {
return (ChooseLockPatternFragment)
activity.getFragmentManager().findFragmentById(R.id.main_content);
}
}

View File

@@ -0,0 +1,33 @@
/*
* 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.testutils.shadow;
import android.content.Context;
import com.android.settings.Utils;
import org.robolectric.annotation.Implementation;
import org.robolectric.annotation.Implements;
@Implements(Utils.class)
public class ShadowUtils {
@Implementation
public static int enforceSameOwner(Context context, int userId) {
return userId;
}
}