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 FullBackupLifecycleTest extends BaseBackupCtsTest { 23 24 private static final String BACKUP_APP_NAME = "android.backup.app"; 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, 43 backupSeparator, 44 "onCreate", 45 "Full backup requested", 46 "onDestroy"); 47 48 String restoreSeparator = markLogcat(); 49 50 // Now request restore and wait for it to complete 51 exec("bmgr restore " + BACKUP_APP_NAME); 52 53 waitForLogcat(TIMEOUT_SECONDS, 54 restoreSeparator, 55 "onCreate", 56 "onRestoreFile", 57 "onRestoreFinished", 58 "onDestroy"); 59 } 60 61 } 62