Merge "Don't check OverrideAllowedState"
This commit is contained in:
@@ -151,6 +151,15 @@ public final class CompatChange extends CompatibilityChangeInfo {
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks whether a change has an override for a package.
|
||||
* @param packageName name of the package
|
||||
* @return true if there is such override
|
||||
*/
|
||||
boolean hasOverride(String packageName) {
|
||||
return mPackageOverrides != null && mPackageOverrides.containsKey(packageName);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
StringBuilder sb = new StringBuilder("ChangeId(")
|
||||
|
||||
@@ -242,11 +242,13 @@ final class CompatConfig {
|
||||
CompatChange c = mChanges.get(changeId);
|
||||
try {
|
||||
if (c != null) {
|
||||
OverrideAllowedState allowedState =
|
||||
mOverrideValidator.getOverrideAllowedState(changeId, packageName);
|
||||
allowedState.enforce(changeId, packageName);
|
||||
overrideExists = true;
|
||||
c.removePackageOverride(packageName);
|
||||
overrideExists = c.hasOverride(packageName);
|
||||
if (overrideExists) {
|
||||
OverrideAllowedState allowedState =
|
||||
mOverrideValidator.getOverrideAllowedState(changeId, packageName);
|
||||
allowedState.enforce(changeId, packageName);
|
||||
c.removePackageOverride(packageName);
|
||||
}
|
||||
}
|
||||
} catch (RemoteException e) {
|
||||
// Should never occur, since validator is in the same process.
|
||||
@@ -291,12 +293,14 @@ final class CompatConfig {
|
||||
for (int i = 0; i < mChanges.size(); ++i) {
|
||||
try {
|
||||
CompatChange change = mChanges.valueAt(i);
|
||||
OverrideAllowedState allowedState =
|
||||
mOverrideValidator.getOverrideAllowedState(change.getId(),
|
||||
packageName);
|
||||
allowedState.enforce(change.getId(), packageName);
|
||||
if (change != null) {
|
||||
mChanges.valueAt(i).removePackageOverride(packageName);
|
||||
if (change.hasOverride(packageName)) {
|
||||
OverrideAllowedState allowedState =
|
||||
mOverrideValidator.getOverrideAllowedState(change.getId(),
|
||||
packageName);
|
||||
allowedState.enforce(change.getId(), packageName);
|
||||
if (change != null) {
|
||||
mChanges.valueAt(i).removePackageOverride(packageName);
|
||||
}
|
||||
}
|
||||
} catch (RemoteException e) {
|
||||
// Should never occur, since validator is in the same process.
|
||||
|
||||
@@ -248,6 +248,28 @@ public class CompatConfigTest {
|
||||
assertThat(compatConfig.isChangeEnabled(1234L, applicationInfo)).isTrue();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testAllowRemoveOverrideNoOverride() throws Exception {
|
||||
CompatConfig compatConfig = CompatConfigBuilder.create(mBuildClassifier, mContext)
|
||||
.addDisabledChangeWithId(1234L)
|
||||
.addLoggingOnlyChangeWithId(2L)
|
||||
.build();
|
||||
ApplicationInfo applicationInfo = ApplicationInfoBuilder.create()
|
||||
.withPackageName("com.some.package")
|
||||
.build();
|
||||
when(mPackageManager.getApplicationInfo(eq("com.some.package"), anyInt()))
|
||||
.thenReturn(applicationInfo);
|
||||
|
||||
// Reject all override attempts.
|
||||
// Force the validator to prevent overriding the change by using a user build.
|
||||
when(mBuildClassifier.isDebuggableBuild()).thenReturn(false);
|
||||
when(mBuildClassifier.isFinalBuild()).thenReturn(true);
|
||||
// Try to remove a non existing override, and it doesn't fail.
|
||||
assertThat(compatConfig.removeOverride(1234L, "com.some.package")).isFalse();
|
||||
assertThat(compatConfig.removeOverride(2L, "com.some.package")).isFalse();
|
||||
compatConfig.removePackageOverrides("com.some.package");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testRemovePackageOverride() throws Exception {
|
||||
CompatConfig compatConfig = CompatConfigBuilder.create(mBuildClassifier, mContext)
|
||||
|
||||
Reference in New Issue
Block a user