From 2141bb48d626369da6313aac930939b8faa83226 Mon Sep 17 00:00:00 2001 From: Transformer Team Date: Thu, 2 May 2019 17:29:18 +0100 Subject: Import from google3 See google3/third_party/java_src/android_libs/backup/copy.bara.sky. Project import generated by Copybara. Exempt-From-Owner-Approval: Ownership was incorrectly given to the Dialer team (b/131880800), but the team members don't actually have CodeReview+2 access. PiperOrigin-RevId: 246332340 Change-Id: I5488fc9fee9019c69437887f12dda110b85bc9a3 --- build.gradle | 10 ++++ .../backup/shadow/BackupAgentHelperShadow.java | 6 +-- .../shadow/UnsupportedBackupHelperSimulator.java | 58 ++++++++++++++++++++++ 3 files changed, 71 insertions(+), 3 deletions(-) create mode 100644 src/com/google/android/libraries/backup/shadow/UnsupportedBackupHelperSimulator.java diff --git a/build.gradle b/build.gradle index 7a33abd..15071ea 100644 --- a/build.gradle +++ b/build.gradle @@ -1,6 +1,16 @@ apply plugin: 'com.android.library' android { + compileSdkVersion 28 + buildToolsVersion '28.0.0' + + defaultConfig { + // Most backup classes (e.g. SharedPreferencesBackupHelper) were added + // in Froyo. + minSdkVersion 8 + targetSdkVersion 28 + } + publishNonDefault true buildTypes { diff --git a/src/com/google/android/libraries/backup/shadow/BackupAgentHelperShadow.java b/src/com/google/android/libraries/backup/shadow/BackupAgentHelperShadow.java index 18deabf..5615723 100644 --- a/src/com/google/android/libraries/backup/shadow/BackupAgentHelperShadow.java +++ b/src/com/google/android/libraries/backup/shadow/BackupAgentHelperShadow.java @@ -26,7 +26,6 @@ import org.robolectric.RuntimeEnvironment; import org.robolectric.annotation.Implementation; import org.robolectric.annotation.Implements; import org.robolectric.annotation.RealObject; -import org.robolectric.fakes.RoboSharedPreferences; /** * Shadow class for end-to-end testing of {@link BackupAgentHelper} subclasses in unit tests. @@ -141,8 +140,9 @@ public class BackupAgentHelperShadow { } else if (helperClass == FileBackupHelper.class) { simulator = FileBackupHelperSimulator.fromHelper(keyPrefix, (FileBackupHelper) helper); } else { - throw new UnsupportedOperationException( - "Unknown backup helper class for key prefix \"" + keyPrefix + "\": " + helperClass); + Log.w( + TAG, "Unknown backup helper class for key prefix \"" + keyPrefix + "\": " + helperClass); + simulator = new UnsupportedBackupHelperSimulator(keyPrefix, helper); } helperSimulators.put(keyPrefix, simulator); } diff --git a/src/com/google/android/libraries/backup/shadow/UnsupportedBackupHelperSimulator.java b/src/com/google/android/libraries/backup/shadow/UnsupportedBackupHelperSimulator.java new file mode 100644 index 0000000..15ee687 --- /dev/null +++ b/src/com/google/android/libraries/backup/shadow/UnsupportedBackupHelperSimulator.java @@ -0,0 +1,58 @@ +package com.google.android.libraries.backup.shadow; + +import android.app.backup.BackupHelper; +import android.content.Context; +import android.util.Log; + +/** + * No-op backup helper representing all an unsupported backup helpers. + * + *

{@see BackupAgentHelperShadow} + */ +public class UnsupportedBackupHelperSimulator extends BackupHelperSimulator { + private static final String TAG = "UnsupportedBckupHlprSim"; + private final BackupHelper mHelper; + + UnsupportedBackupHelperSimulator(String keyPrefix, BackupHelper helper) { + super(keyPrefix); + mHelper = helper; + } + + @Override + public Object backup(Context context) { + return new UnsupportedBackupHelperOutput(mHelper); + } + + @Override + public void restore(Context context, Object data) { + if (!(data instanceof UnsupportedBackupHelperOutput)) { + throw new IllegalArgumentException( + "Invalid type of data to restore in unsupported helper \"" + + keyPrefix + + "\": " + + (data == null ? null : data.getClass())); + } + Log.w( + TAG, + "Attempt to restore from an unsupported backup helper: " + mHelper.getClass().getName()); + } + + public static class UnsupportedBackupHelperOutput { + public final BackupHelper wrappedHelper; + + public UnsupportedBackupHelperOutput(BackupHelper helper) { + wrappedHelper = helper; + } + + @Override + public boolean equals(Object obj) { + return obj instanceof UnsupportedBackupHelperOutput + && wrappedHelper.equals(((UnsupportedBackupHelperOutput) obj).wrappedHelper); + } + + @Override + public int hashCode() { + return wrappedHelper.hashCode(); + } + } +} -- cgit v1.2.3