BaseContactsProvider2Test.java revision 3cfe8d532d509fbbe605454e3a32b2361b7e1501
1d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov/*
2d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov * Copyright (C) 2009 The Android Open Source Project
3d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov *
4d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov * Licensed under the Apache License, Version 2.0 (the "License");
5d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov * you may not use this file except in compliance with the License.
6d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov * You may obtain a copy of the License at
7d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov *
8d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov *      http://www.apache.org/licenses/LICENSE-2.0
9d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov *
10d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov * Unless required by applicable law or agreed to in writing, software
11d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov * distributed under the License is distributed on an "AS IS" BASIS,
12d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov * See the License for the specific language governing permissions and
14d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov * limitations under the License.
15d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov */
1628f8857b1b46bde18b85c6d3c2a63ac44c3c2e1cEvan Millarpackage com.android.providers.contacts;
17d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
1828f8857b1b46bde18b85c6d3c2a63ac44c3c2e1cEvan Millarimport static com.android.providers.contacts.ContactsActor.PACKAGE_GREY;
19d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
20e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikovimport android.accounts.Account;
21bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikovimport android.content.ContentProvider;
22d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikovimport android.content.ContentUris;
23d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikovimport android.content.ContentValues;
24e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikovimport android.content.Context;
259261b2141aa90a4fed632fd6da03026d4c216280Fred Quintanaimport android.content.Entity;
26a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikovimport android.content.res.Resources;
27d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikovimport android.database.Cursor;
28d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikovimport android.net.Uri;
29bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikovimport android.provider.ContactsContract;
30d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikovimport android.provider.ContactsContract.AggregationExceptions;
31e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikovimport android.provider.ContactsContract.Contacts;
32d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikovimport android.provider.ContactsContract.Data;
339261b2141aa90a4fed632fd6da03026d4c216280Fred Quintanaimport android.provider.ContactsContract.Groups;
34bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millarimport android.provider.ContactsContract.Presence;
35e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikovimport android.provider.ContactsContract.RawContacts;
36a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikovimport android.provider.ContactsContract.CommonDataKinds.Email;
379261b2141aa90a4fed632fd6da03026d4c216280Fred Quintanaimport android.provider.ContactsContract.CommonDataKinds.GroupMembership;
38e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikovimport android.provider.ContactsContract.CommonDataKinds.Im;
39a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikovimport android.provider.ContactsContract.CommonDataKinds.Nickname;
40bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikovimport android.provider.ContactsContract.CommonDataKinds.Phone;
41ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millarimport android.provider.ContactsContract.CommonDataKinds.Photo;
42e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikovimport android.provider.ContactsContract.CommonDataKinds.StructuredName;
43d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikovimport android.test.AndroidTestCase;
44d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikovimport android.test.mock.MockContentResolver;
45d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikovimport android.test.suitebuilder.annotation.LargeTest;
46bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov
47a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikovimport java.io.ByteArrayOutputStream;
48a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikovimport java.io.IOException;
49a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikovimport java.io.InputStream;
509261b2141aa90a4fed632fd6da03026d4c216280Fred Quintanaimport java.util.ArrayList;
519261b2141aa90a4fed632fd6da03026d4c216280Fred Quintanaimport java.util.Arrays;
52e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikovimport java.util.Comparator;
5320a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikovimport java.util.Map;
5420a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikovimport java.util.Set;
55d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
56d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov/**
57d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov * A common superclass for {@link ContactsProvider2}-related tests.
58d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov */
59d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov@LargeTest
60d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikovpublic abstract class BaseContactsProvider2Test extends AndroidTestCase {
61d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
62d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    protected static final String PACKAGE = "ContactsProvider2Test";
63d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
64bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov    protected ContactsActor mActor;
65d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    protected MockContentResolver mResolver;
669261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected Account mAccount = new Account("account1", "account type1");
679261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
689261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected final static Long NO_LONG = new Long(0);
699261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected final static String NO_STRING = new String("");
709261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected final static Account NO_ACCOUNT = new Account("a", "b");
71d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
72bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov    protected Class<? extends ContentProvider> getProviderClass() {
73bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov        return SynchronousContactsProvider2.class;
74bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov    }
75bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov
76bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov    protected String getAuthority() {
77bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov        return ContactsContract.AUTHORITY;
78bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov    }
79bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov
80d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    @Override
81d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    protected void setUp() throws Exception {
82d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        super.setUp();
83d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
84bee1a6b2e7cbea778195890e442c9e50f2a4e6d9Dmitri Plotnikov        mActor = new ContactsActor(getContext(), PACKAGE_GREY, getProviderClass(), getAuthority());
85d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        mResolver = mActor.resolver;
86445ca81effbb0d61c7bc0033acf2d3dfd228fd4eDmitri Plotnikov        if (mActor.provider instanceof SynchronousContactsProvider2) {
87445ca81effbb0d61c7bc0033acf2d3dfd228fd4eDmitri Plotnikov            ((SynchronousContactsProvider2) mActor.provider)
88445ca81effbb0d61c7bc0033acf2d3dfd228fd4eDmitri Plotnikov                    .getOpenHelper(mActor.context).wipeData();
89445ca81effbb0d61c7bc0033acf2d3dfd228fd4eDmitri Plotnikov        }
909261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
919261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
92e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov    public Context getMockContext() {
93e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov        return mActor.context;
94e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov    }
95e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov
96e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov    public void addAuthority(String authority) {
97e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov        mActor.addAuthority(authority);
98e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov    }
99e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov
100e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov    public ContentProvider addProvider(Class<? extends ContentProvider> providerClass,
101e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov            String authority) throws Exception {
102e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov        return mActor.addProvider(providerClass, authority);
103e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov    }
104e99988b266dd1263162583e81e2b408e7329b1c8Dmitri Plotnikov
1059261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected Uri maybeAddAccountQueryParameters(Uri uri, Account account) {
1069261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        if (account == null) {
1079261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            return uri;
1089261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        }
1099261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        return uri.buildUpon()
1106cffee46a1334d2b3ed19f436b27638451541044Dmitri Plotnikov                .appendQueryParameter(RawContacts.ACCOUNT_NAME, account.mName)
1116cffee46a1334d2b3ed19f436b27638451541044Dmitri Plotnikov                .appendQueryParameter(RawContacts.ACCOUNT_TYPE, account.mType)
1129261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana                .build();
113d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    }
114d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
115d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected long createRawContact() {
116226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana        return createRawContact(null);
117d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    }
118d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
119c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov    protected long createRawContactWithName() {
1203cfe8d532d509fbbe605454e3a32b2361b7e1501Dmitri Plotnikov        return createRawContactWithName("John", "Doe");
1213cfe8d532d509fbbe605454e3a32b2361b7e1501Dmitri Plotnikov    }
1223cfe8d532d509fbbe605454e3a32b2361b7e1501Dmitri Plotnikov
1233cfe8d532d509fbbe605454e3a32b2361b7e1501Dmitri Plotnikov    protected long createRawContactWithName(String firstName, String lastName) {
124c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov        long rawContactId = createRawContact(null);
1253cfe8d532d509fbbe605454e3a32b2361b7e1501Dmitri Plotnikov        insertStructuredName(rawContactId, firstName, lastName);
126c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov        return rawContactId;
127c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov    }
128c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov
129226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana    protected long createRawContact(Account account, String... extras) {
1309261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        ContentValues values = new ContentValues();
131226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana        for (int i = 0; i < extras.length; ) {
132226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana            values.put(extras[i], extras[i + 1]);
133226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana            i += 2;
134226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana        }
1356cffee46a1334d2b3ed19f436b27638451541044Dmitri Plotnikov        final Uri uri = maybeAddAccountQueryParameters(RawContacts.CONTENT_URI, account);
1369261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        Uri contactUri = mResolver.insert(uri, values);
1379261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        return ContentUris.parseId(contactUri);
1389261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
1399261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
1409261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected long createGroup(Account account, String sourceId, String title) {
1419261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        ContentValues values = new ContentValues();
1429261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        values.put(Groups.SOURCE_ID, sourceId);
1439261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        values.put(Groups.TITLE, title);
144a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov        values.put(Groups.GROUP_VISIBLE, 1);
1459261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        final Uri uri = maybeAddAccountQueryParameters(Groups.CONTENT_URI, account);
1469261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        return ContentUris.parseId(mResolver.insert(uri, values));
1479261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
1489261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
1495ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected Uri insertStructuredName(long rawContactId, String givenName, String familyName) {
150d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        ContentValues values = new ContentValues();
151d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        StringBuilder sb = new StringBuilder();
152d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        if (givenName != null) {
153d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov            sb.append(givenName);
154d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        }
155d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        if (givenName != null && familyName != null) {
156d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov            sb.append(" ");
157d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        }
158d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        if (familyName != null) {
159d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov            sb.append(familyName);
160d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        }
161d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        values.put(StructuredName.DISPLAY_NAME, sb.toString());
162d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        values.put(StructuredName.GIVEN_NAME, givenName);
163d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        values.put(StructuredName.FAMILY_NAME, familyName);
164d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
1655ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        return insertStructuredName(rawContactId, values);
1664097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov    }
1674097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov
1685ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected Uri insertStructuredName(long rawContactId, ContentValues values) {
1695ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        values.put(Data.RAW_CONTACT_ID, rawContactId);
1704097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        values.put(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE);
171d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        Uri resultUri = mResolver.insert(Data.CONTENT_URI, values);
172d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        return resultUri;
173d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    }
174d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
1755ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected Uri insertPhoneNumber(long rawContactId, String phoneNumber) {
176bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikov        ContentValues values = new ContentValues();
1775ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        values.put(Data.RAW_CONTACT_ID, rawContactId);
178bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikov        values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
179bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikov        values.put(Phone.NUMBER, phoneNumber);
1803cebbf7141252768d3e272e049e9c5b0cb9d710eDmitri Plotnikov        values.put(Phone.TYPE, Phone.TYPE_HOME);
181bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikov
182bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikov        Uri resultUri = mResolver.insert(Data.CONTENT_URI, values);
183bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikov        return resultUri;
184bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikov    }
185bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikov
1865ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected Uri insertEmail(long rawContactId, String email) {
187a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov        ContentValues values = new ContentValues();
1885ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        values.put(Data.RAW_CONTACT_ID, rawContactId);
189a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov        values.put(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE);
190a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov        values.put(Email.DATA, email);
1913cebbf7141252768d3e272e049e9c5b0cb9d710eDmitri Plotnikov        values.put(Email.TYPE, Email.TYPE_HOME);
192a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov
193a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov        Uri resultUri = mResolver.insert(Data.CONTENT_URI, values);
194a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov        return resultUri;
195a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov    }
196a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov
1975ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected Uri insertNickname(long rawContactId, String nickname) {
198a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov        ContentValues values = new ContentValues();
1995ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        values.put(Data.RAW_CONTACT_ID, rawContactId);
200a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov        values.put(Data.MIMETYPE, Nickname.CONTENT_ITEM_TYPE);
201a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov        values.put(Nickname.NAME, nickname);
2023cebbf7141252768d3e272e049e9c5b0cb9d710eDmitri Plotnikov        values.put(Nickname.TYPE, Nickname.TYPE_OTHER_NAME);
203a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov
204a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov        Uri resultUri = mResolver.insert(Data.CONTENT_URI, values);
205a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov        return resultUri;
206a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov    }
207a5ad551e1753086825499f1aeb6415bb986f3588Dmitri Plotnikov
2085ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected Uri insertPhoto(long rawContactId) {
209ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar        ContentValues values = new ContentValues();
2105ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        values.put(Data.RAW_CONTACT_ID, rawContactId);
211ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar        values.put(Data.MIMETYPE, Photo.CONTENT_ITEM_TYPE);
212ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar
213ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar        Uri resultUri = mResolver.insert(Data.CONTENT_URI, values);
214ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar        return resultUri;
215ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar    }
216ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar
2175ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected Uri insertGroupMembership(long rawContactId, String sourceId) {
2189261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        ContentValues values = new ContentValues();
2195ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        values.put(Data.RAW_CONTACT_ID, rawContactId);
2209261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        values.put(Data.MIMETYPE, GroupMembership.CONTENT_ITEM_TYPE);
2219261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        values.put(GroupMembership.GROUP_SOURCE_ID, sourceId);
2229261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        return mResolver.insert(Data.CONTENT_URI, values);
2239261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
2249261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
2255ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected Uri insertGroupMembership(long rawContactId, Long groupId) {
2269261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        ContentValues values = new ContentValues();
2275ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        values.put(Data.RAW_CONTACT_ID, rawContactId);
2289261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        values.put(Data.MIMETYPE, GroupMembership.CONTENT_ITEM_TYPE);
2299261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        values.put(GroupMembership.GROUP_ROW_ID, groupId);
2309261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        return mResolver.insert(Data.CONTENT_URI, values);
2319261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
2329261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
233bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar    protected Uri insertPresence(int protocol, String handle, int presence) {
234bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        ContentValues values = new ContentValues();
235bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        values.put(Presence.IM_PROTOCOL, protocol);
236bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        values.put(Presence.IM_HANDLE, handle);
237bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        values.put(Presence.PRESENCE_STATUS, presence);
238bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar
239bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        Uri resultUri = mResolver.insert(Presence.CONTENT_URI, values);
240bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        return resultUri;
241bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar    }
242bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar
2435ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected Uri insertImHandle(long rawContactId, int protocol, String handle) {
244bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        ContentValues values = new ContentValues();
2455ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        values.put(Data.RAW_CONTACT_ID, rawContactId);
246bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        values.put(Data.MIMETYPE, Im.CONTENT_ITEM_TYPE);
247bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        values.put(Im.PROTOCOL, protocol);
248bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        values.put(Im.DATA, handle);
2493cebbf7141252768d3e272e049e9c5b0cb9d710eDmitri Plotnikov        values.put(Im.TYPE, Im.TYPE_HOME);
250bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar
251bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        Uri resultUri = mResolver.insert(Data.CONTENT_URI, values);
252bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar        return resultUri;
253bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar    }
254bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar
2555ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected void setContactAccountName(long rawContactId, String accountName) {
256ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar        ContentValues values = new ContentValues();
2576cffee46a1334d2b3ed19f436b27638451541044Dmitri Plotnikov        values.put(RawContacts.ACCOUNT_NAME, accountName);
258ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar
259ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar        mResolver.update(ContentUris.withAppendedId(
2605ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov                RawContacts.CONTENT_URI, rawContactId), values, null, null);
261ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar    }
262ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar
263d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected void setAggregationException(int type, long contactId, long rawContactId) {
264d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        ContentValues values = new ContentValues();
265d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        values.put(AggregationExceptions.CONTACT_ID, contactId);
2665ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        values.put(AggregationExceptions.RAW_CONTACT_ID, rawContactId);
267d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        values.put(AggregationExceptions.TYPE, type);
268d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        mResolver.update(AggregationExceptions.CONTENT_URI, values, null, null);
269d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    }
270d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
271d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected Cursor queryRawContact(long rawContactId) {
2725ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        return mResolver.query(ContentUris.withAppendedId(RawContacts.CONTENT_URI, rawContactId), null,
273d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov                null, null, null);
274d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    }
275d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
276d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected Cursor queryContact(long contactId) {
277d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        return mResolver.query(ContentUris.withAppendedId(Contacts.CONTENT_URI, contactId),
278d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov                null, null, null, null);
279d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    }
280d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
281d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected Cursor queryContactSummary(long contactId, String[] projection) {
282d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        return mResolver.query(ContentUris.withAppendedId(Contacts.CONTENT_SUMMARY_URI,
283d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov                contactId), projection, null, null, null);
284bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar    }
285bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar
286d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected Cursor queryContactSummary() {
287d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        return mResolver.query(Contacts.CONTENT_SUMMARY_URI, null, null, null, null);
288bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar    }
289bc5c799a52b5bde2f273efd118ebe2228c3d8f15Evan Millar
290d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected long queryContactId(long rawContactId) {
291d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        Cursor c = queryRawContact(rawContactId);
292d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        assertTrue(c.moveToFirst());
293d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        long contactId = c.getLong(c.getColumnIndex(RawContacts.CONTACT_ID));
294d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        c.close();
295d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        return contactId;
296d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    }
297d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
298d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected long queryPhotoId(long contactId) {
299d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        Cursor c = queryContact(contactId);
300ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar        assertTrue(c.moveToFirst());
301d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        long photoId = c.getInt(c.getColumnIndex(Contacts.PHOTO_ID));
302ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar        c.close();
303ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar        return photoId;
304ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar    }
305ae6ca1f34cf5458d79ec803411d4308879a91e92Evan Millar
306d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected String queryDisplayName(long contactId) {
307d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        Cursor c = queryContact(contactId);
308d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        assertTrue(c.moveToFirst());
309d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        String displayName = c.getString(c.getColumnIndex(Contacts.DISPLAY_NAME));
310d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        c.close();
311d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        return displayName;
312d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    }
313d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
314d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected void assertAggregated(long rawContactId1, long rawContactId2) {
315d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        long contactId1 = queryContactId(rawContactId1);
316d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        long contactId2 = queryContactId(rawContactId2);
317d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        assertTrue(contactId1 == contactId2);
318bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikov    }
319bf659107617a6291ba8bfeebc3f2e50138075ab5Dmitri Plotnikov
320d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected void assertAggregated(long rawContactId1, long rawContactId2,
321d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov            String expectedDisplayName) {
322d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        long contactId1 = queryContactId(rawContactId1);
323d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        long contactId2 = queryContactId(rawContactId2);
324d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        assertTrue(contactId1 == contactId2);
325d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
326d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        String displayName = queryDisplayName(contactId1);
327d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov        assertEquals(expectedDisplayName, displayName);
328d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    }
329d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov
330d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov    protected void assertNotAggregated(long rawContactId1, long rawContactId2) {
331d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        long contactId1 = queryContactId(rawContactId1);
332d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        long contactId2 = queryContactId(rawContactId2);
333d3fde755e73cd3912a488e7cb7d412d3c5f6ca94Dmitri Plotnikov        assertTrue(contactId1 != contactId2);
334d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov    }
3354097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov
3365ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected void assertStructuredName(long rawContactId, String prefix, String givenName,
3374097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov            String middleName, String familyName, String suffix) {
3386cffee46a1334d2b3ed19f436b27638451541044Dmitri Plotnikov        Uri uri =
3395ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov                Uri.withAppendedPath(ContentUris.withAppendedId(RawContacts.CONTENT_URI, rawContactId),
3406cffee46a1334d2b3ed19f436b27638451541044Dmitri Plotnikov                RawContacts.Data.CONTENT_DIRECTORY);
3414097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov
3424097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        final String[] projection = new String[] {
3434097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov                StructuredName.PREFIX, StructuredName.GIVEN_NAME, StructuredName.MIDDLE_NAME,
3444097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov                StructuredName.FAMILY_NAME, StructuredName.SUFFIX
3454097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        };
3464097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov
3474097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        Cursor c = mResolver.query(uri, projection, Data.MIMETYPE + "='"
3484097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov                + StructuredName.CONTENT_ITEM_TYPE + "'", null, null);
3494097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov
3504097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        assertTrue(c.moveToFirst());
3514097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        assertEquals(prefix, c.getString(0));
3524097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        assertEquals(givenName, c.getString(1));
3534097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        assertEquals(middleName, c.getString(2));
3544097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        assertEquals(familyName, c.getString(3));
3554097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        assertEquals(suffix, c.getString(4));
3564097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov        c.close();
3574097855e2d672b3f8e1c5c8a169efb80203bf53eDmitri Plotnikov    }
3589261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
3599261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected long assertSingleGroup(Long rowId, Account account, String sourceId, String title) {
3609261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        Cursor c = mResolver.query(Groups.CONTENT_URI, null, null, null, null);
3619261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        try {
3629261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            assertTrue(c.moveToNext());
3639261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            long actualRowId = assertGroup(c, rowId, account, sourceId, title);
3649261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            assertFalse(c.moveToNext());
3659261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            return actualRowId;
3669261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        } finally {
3679261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            c.close();
3689261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        }
3699261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
3709261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
3715ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected long assertSingleGroupMembership(Long rowId, Long rawContactId, Long groupRowId,
3729261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            String sourceId) {
3739261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        Cursor c = mResolver.query(ContactsContract.Data.CONTENT_URI, null, null, null, null);
3749261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        try {
3759261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            assertTrue(c.moveToNext());
3765ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov            long actualRowId = assertGroupMembership(c, rowId, rawContactId, groupRowId, sourceId);
3779261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            assertFalse(c.moveToNext());
3789261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            return actualRowId;
3799261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        } finally {
3809261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            c.close();
3819261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        }
3829261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
3839261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
3845ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov    protected long assertGroupMembership(Cursor c, Long rowId, Long rawContactId, Long groupRowId,
3859261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            String sourceId) {
3869261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertNullOrEquals(c, rowId, Data._ID);
3875ef0401c311c62e53bde415b99cbb0ff83b0a9a2Dmitri Plotnikov        assertNullOrEquals(c, rawContactId, GroupMembership.RAW_CONTACT_ID);
3889261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertNullOrEquals(c, groupRowId, GroupMembership.GROUP_ROW_ID);
3899261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertNullOrEquals(c, sourceId, GroupMembership.GROUP_SOURCE_ID);
3909261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        return c.getLong(c.getColumnIndexOrThrow("_id"));
3919261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
3929261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
3939261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected long assertGroup(Cursor c, Long rowId, Account account, String sourceId, String title) {
3949261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertNullOrEquals(c, rowId, Groups._ID);
3959261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertNullOrEquals(c, account);
3969261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertNullOrEquals(c, sourceId, Groups.SOURCE_ID);
3979261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertNullOrEquals(c, title, Groups.TITLE);
3989261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        return c.getLong(c.getColumnIndexOrThrow("_id"));
3999261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
4009261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
4019261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    private void assertNullOrEquals(Cursor c, Account account) {
4029261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        if (account == NO_ACCOUNT) {
4039261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            return;
4049261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        }
4059261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        if (account == null) {
4069261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            assertTrue(c.isNull(c.getColumnIndexOrThrow(Groups.ACCOUNT_NAME)));
4079261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            assertTrue(c.isNull(c.getColumnIndexOrThrow(Groups.ACCOUNT_TYPE)));
4089261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        } else {
4099261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            assertEquals(account.mName, c.getString(c.getColumnIndexOrThrow(Groups.ACCOUNT_NAME)));
4109261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            assertEquals(account.mType, c.getString(c.getColumnIndexOrThrow(Groups.ACCOUNT_TYPE)));
4119261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        }
4129261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
4139261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
4149261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    private void assertNullOrEquals(Cursor c, Long value, String columnName) {
4159261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        if (value != NO_LONG) {
4169261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            if (value == null) assertTrue(c.isNull(c.getColumnIndexOrThrow(columnName)));
4179261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            else assertEquals((long) value, c.getLong(c.getColumnIndexOrThrow(columnName)));
4189261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        }
4199261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
4209261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
4219261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    private void assertNullOrEquals(Cursor c, String value, String columnName) {
4229261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        if (value != NO_STRING) {
4239261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            if (value == null) assertTrue(c.isNull(c.getColumnIndexOrThrow(columnName)));
4249261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            else assertEquals(value, c.getString(c.getColumnIndexOrThrow(columnName)));
4259261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        }
4269261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
4279261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
4289261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected void assertDataRow(ContentValues actual, String expectedMimetype,
4299261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            Object... expectedArguments) {
4309261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertEquals(actual.toString(), expectedMimetype, actual.getAsString(Data.MIMETYPE));
4319261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        for (int i = 0; i < expectedArguments.length; i += 2) {
4329261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            String columnName = (String) expectedArguments[i];
4339261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            Object expectedValue = expectedArguments[i + 1];
4349261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            if (expectedValue instanceof Uri) {
4359261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana                expectedValue = ContentUris.parseId((Uri) expectedValue);
4369261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            }
4379261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            if (expectedValue == null) {
4389261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana                assertNull(actual.toString(), actual.get(columnName));
4399261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            }
4409261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            if (expectedValue instanceof Long) {
441226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana                assertEquals("mismatch at " + columnName + " from " + actual.toString(),
442226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana                        expectedValue, actual.getAsLong(columnName));
4439261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            } else if (expectedValue instanceof Integer) {
444226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana                assertEquals("mismatch at " + columnName + " from " + actual.toString(),
445226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana                        expectedValue, actual.getAsInteger(columnName));
4469261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            } else if (expectedValue instanceof String) {
447226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana                assertEquals("mismatch at " + columnName + " from " + actual.toString(),
448226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana                        expectedValue, actual.getAsString(columnName));
4499261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            } else {
450226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana                assertEquals("mismatch at " + columnName + " from " + actual.toString(),
451226c3dc6e93ca76a84c99100caa31045cba06cf6Fred Quintana                        expectedValue, actual.get(columnName));
4529261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            }
4539261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        }
4549261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
4559261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
4569261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected static class IdComparator implements Comparator<ContentValues> {
4579261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        public int compare(ContentValues o1, ContentValues o2) {
4589261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            long id1 = o1.getAsLong(ContactsContract.Data._ID);
4599261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            long id2 = o2.getAsLong(ContactsContract.Data._ID);
4609261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            if (id1 == id2) return 0;
4619261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            return (id1 < id2) ? -1 : 1;
4629261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        }
4639261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
4649261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
4659261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected ContentValues[] asSortedContentValuesArray(
4669261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            ArrayList<Entity.NamedContentValues> subValues) {
4679261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        ContentValues[] result = new ContentValues[subValues.size()];
4689261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        int i = 0;
4699261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        for (Entity.NamedContentValues subValue : subValues) {
4709261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            result[i] = subValue.values;
4719261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana            i++;
4729261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        }
4739261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        Arrays.sort(result, new IdComparator());
4749261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        return result;
4759261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
4769261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
4779261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected void assertDirty(Uri uri, boolean state) {
4789261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        Cursor c = mResolver.query(uri, new String[]{"dirty"}, null, null, null);
4799261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertTrue(c.moveToNext());
4809261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertEquals(state, c.getLong(0) != 0);
4819261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertFalse(c.moveToNext());
4823cfe8d532d509fbbe605454e3a32b2361b7e1501Dmitri Plotnikov        c.close();
4839261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
4849261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
4859261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected long getVersion(Uri uri) {
4869261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        Cursor c = mResolver.query(uri, new String[]{"version"}, null, null, null);
4879261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertTrue(c.moveToNext());
4889261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        long version = c.getLong(0);
4899261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        assertFalse(c.moveToNext());
4903cfe8d532d509fbbe605454e3a32b2361b7e1501Dmitri Plotnikov        c.close();
4919261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        return version;
4929261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
4939261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana
4949261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    protected void clearDirty(Uri uri) {
4959261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        ContentValues values = new ContentValues();
4969261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        values.put("dirty", 0);
4979261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana        mResolver.update(uri, values, null, null);
4989261b2141aa90a4fed632fd6da03026d4c216280Fred Quintana    }
49920a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov
50020a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    protected void assertStoredValues(Uri rowUri, String column, String expectedValue) {
50120a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        String value = getStoredValue(rowUri, column);
50220a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        assertEquals("Column value " + column, expectedValue, value);
50320a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    }
50420a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov
50520a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    protected String getStoredValue(Uri rowUri, String column) {
50620a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        String value;
50720a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        Cursor c = mResolver.query(rowUri, new String[] { column }, null, null, null);
50820a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        try {
50920a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            c.moveToFirst();
51020a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            value = c.getString(c.getColumnIndex(column));
51120a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        } finally {
51220a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            c.close();
51320a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        }
51420a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        return value;
51520a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    }
51620a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov
51720a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    protected void assertStoredValues(Uri rowUri, ContentValues expectedValues) {
51820a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        Cursor c = mResolver.query(rowUri, null, null, null, null);
51920a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        try {
52020a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            assertEquals("Record count", 1, c.getCount());
52120a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            c.moveToFirst();
52220a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            assertCursorValues(c, expectedValues);
52320a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        } finally {
52420a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            c.close();
52520a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        }
52620a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    }
52720a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov
52820a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    /**
52920a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov     * Constructs a selection (where clause) out of all supplied values, uses it
53020a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov     * to query the provider and verifies that a single row is returned and it
53120a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov     * has the same values as requested.
53220a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov     */
53320a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    protected void assertSelection(Uri uri, ContentValues values, String idColumn, long id) {
53420a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        StringBuilder sb = new StringBuilder();
53520a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        ArrayList<String> selectionArgs = new ArrayList<String>(values.size());
536c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov        if (idColumn != null) {
537c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov            sb.append(idColumn).append("=").append(id);
538c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov        }
53920a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        Set<Map.Entry<String, Object>> entries = values.valueSet();
54020a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        for (Map.Entry<String, Object> entry : entries) {
54120a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            String column = entry.getKey();
54220a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            Object value = entry.getValue();
543c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov            if (sb.length() != 0) {
544c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov                sb.append(" AND ");
545c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov            }
546c70dc0e38ff82c6e6d6b7458637c54fbdf446aacDmitri Plotnikov            sb.append(column);
54720a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            if (value == null) {
54820a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov                sb.append(" IS NULL");
54920a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            } else {
55020a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov                sb.append("=?");
55120a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov                selectionArgs.add(String.valueOf(value));
55220a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            }
55320a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        }
55420a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov
55520a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        Cursor c = mResolver.query(uri, null, sb.toString(), selectionArgs.toArray(new String[0]),
55620a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov                null);
55720a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        try {
55820a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            assertEquals("Record count", 1, c.getCount());
55920a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            c.moveToFirst();
56020a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            assertCursorValues(c, values);
56120a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        } finally {
56220a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            c.close();
56320a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        }
56420a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    }
56520a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov
56620a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    protected void assertCursorValues(Cursor cursor, ContentValues expectedValues) {
56720a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        Set<Map.Entry<String, Object>> entries = expectedValues.valueSet();
56820a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        for (Map.Entry<String, Object> entry : entries) {
56920a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            String column = entry.getKey();
57020a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            int index = cursor.getColumnIndex(column);
57120a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            assertTrue("No such column: " + column, index != -1);
57220a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            Object expectedValue = expectedValues.get(column);
57320a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            String value;
57420a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            if (expectedValue instanceof byte[]) {
57520a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov                expectedValue = Hex.encodeHex((byte[])expectedValue, false);
57620a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov                value = Hex.encodeHex(cursor.getBlob(index), false);
57720a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            } else {
57820a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov                expectedValue = expectedValues.getAsString(column);
57920a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov                value = cursor.getString(index);
58020a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            }
58120a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov            assertEquals("Column value " + column, expectedValue, value);
58220a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov        }
58320a94c86ede7380c8dd8df2f6a72b3c00ac1bed8Dmitri Plotnikov    }
58433b41fdb8d7c3c654cb070799c9d6e2b4ab16078Dmitri Plotnikov
58533b41fdb8d7c3c654cb070799c9d6e2b4ab16078Dmitri Plotnikov    protected int getCount(Uri uri, String selection, String[] selectionArgs) {
58633b41fdb8d7c3c654cb070799c9d6e2b4ab16078Dmitri Plotnikov        Cursor c = mResolver.query(uri, null, selection, selectionArgs, null);
58733b41fdb8d7c3c654cb070799c9d6e2b4ab16078Dmitri Plotnikov        try {
58833b41fdb8d7c3c654cb070799c9d6e2b4ab16078Dmitri Plotnikov            return c.getCount();
58933b41fdb8d7c3c654cb070799c9d6e2b4ab16078Dmitri Plotnikov        } finally {
59033b41fdb8d7c3c654cb070799c9d6e2b4ab16078Dmitri Plotnikov            c.close();
59133b41fdb8d7c3c654cb070799c9d6e2b4ab16078Dmitri Plotnikov        }
59233b41fdb8d7c3c654cb070799c9d6e2b4ab16078Dmitri Plotnikov    }
593a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov
594a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov    protected byte[] loadTestPhoto() throws IOException {
595a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov        final Resources resources = getContext().getResources();
596a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov        InputStream is =
597a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov                resources.openRawResource(com.android.internal.R.drawable.ic_contact_picture);
598a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov        ByteArrayOutputStream os = new ByteArrayOutputStream();
599a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov        byte[] buffer = new byte[1000];
600a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov        int count;
601a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov        while((count = is.read(buffer)) != -1) {
602a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov            os.write(buffer, 0, count);
603a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov        }
604a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov        return os.toByteArray();
605a908fb5f39aa2021662a6cc317cc7e4db2d8bfb0Dmitri Plotnikov    }
606d35d9c748af4c3182679c4c546137acfc11eb7a8Dmitri Plotnikov}
607