1 /* 2 * Copyright (C) 2017 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License 15 */ 16 17 package android.backup.cts; 18 19 /** 20 * Verifies that key methods are called in expected order during backup / restore. 21 */ 22 public class KeyValueLifecycleTest extends BaseBackupCtsTest { 23 24 private static final String BACKUP_APP_NAME = "android.backup.kvapp"; 25 26 private static final int LOCAL_TRANSPORT_CONFORMING_FILE_SIZE = 5 * 1024; 27 28 private static final int TIMEOUT_SECONDS = 30; 29 30 public void testExpectedMethodsCalledInOrder() throws Exception { 31 if (!isBackupSupported()) { 32 return; 33 } 34 String backupSeparator = markLogcat(); 35 36 // Make sure there's something to backup 37 createTestFileOfSize(BACKUP_APP_NAME, LOCAL_TRANSPORT_CONFORMING_FILE_SIZE); 38 39 // Request backup and wait for it to complete 40 exec("bmgr backupnow " + BACKUP_APP_NAME); 41 42 waitForLogcat(TIMEOUT_SECONDS,backupSeparator, 43 "onCreate", 44 "Backup requested", 45 "onDestroy"); 46 47 String restoreSeparator = markLogcat(); 48 49 // Now request restore and wait for it to complete 50 exec("bmgr restore " + BACKUP_APP_NAME); 51 52 waitForLogcat(TIMEOUT_SECONDS, restoreSeparator, 53 "onCreate", 54 "Restore requested", 55 "onRestoreFinished", 56 "onDestroy"); 57 } 58 59 } 60