blob: 772d75c556a04a2115a345d1822cbd2c45e9149a [file] [log] [blame]
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2007 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
17package android.test;
18
19import android.content.ContentResolver;
20import android.content.Context;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080021import android.os.Bundle;
Dianne Hackborn231cc602009-04-27 17:10:36 -070022import android.os.RemoteException;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080023import android.os.SystemClock;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080024import android.net.Uri;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080025
26/**
27 * If you would like to test sync a single provider with an
28 * {@link InstrumentationTestCase}, this provides some of the boiler plate in {@link #setUp} and
29 * {@link #tearDown}.
30 */
31public class SyncBaseInstrumentation extends InstrumentationTestCase {
32 private Context mTargetContext;
33 ContentResolver mContentResolver;
34 private static final int MAX_TIME_FOR_SYNC_IN_MINS = 20;
35
36 @Override
37 protected void setUp() throws Exception {
38 super.setUp();
39 mTargetContext = getInstrumentation().getTargetContext();
40 mContentResolver = mTargetContext.getContentResolver();
41 }
42
43 /**
44 * Syncs the specified provider.
45 * @throws Exception
46 */
47 protected void syncProvider(Uri uri, String account, String authority) throws Exception {
48 Bundle extras = new Bundle();
49 extras.putBoolean(ContentResolver.SYNC_EXTRAS_FORCE, true);
50 extras.putString(ContentResolver.SYNC_EXTRAS_ACCOUNT, account);
51
52 mContentResolver.startSync(uri, extras);
53 long startTimeInMillis = SystemClock.elapsedRealtime();
54 long endTimeInMillis = startTimeInMillis + MAX_TIME_FOR_SYNC_IN_MINS * 60000;
55
56 int counter = 0;
57 // Making sure race condition does not occur when en entry have been removed from pending
58 // and active tables and loaded in memory (therefore sync might be still in progress)
59 while (counter < 2) {
60 // Sleep for 1 second.
61 Thread.sleep(1000);
62 // Finish test if time to sync has exceeded max time.
63 if (SystemClock.elapsedRealtime() > endTimeInMillis) {
64 break;
65 }
66
67 if (isSyncActive(account, authority)) {
68 counter = 0;
69 continue;
70 }
71 counter++;
72 }
73 }
74
75 protected void cancelSyncsandDisableAutoSync() {
Dianne Hackborn231cc602009-04-27 17:10:36 -070076 try {
77 ContentResolver.getContentService().setListenForNetworkTickles(false);
78 } catch (RemoteException e) {
79 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080080 mContentResolver.cancelSync(null);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080081 }
82
83 /**
84 * This method tests if any sync is active or not. Sync is considered to be active if the
85 * entry is in either the Pending or Active tables.
86 * @return
87 */
88 private boolean isSyncActive(String account, String authority) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080089 try {
Dianne Hackborn231cc602009-04-27 17:10:36 -070090 return ContentResolver.getContentService().isSyncActive(account,
91 authority);
92 } catch (RemoteException e) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080093 return false;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080094 }
95 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080096}