ProviderTests.java revision acd985efb4b29da28953308ba3d5c8f43b760379
17143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler/*
27143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * Copyright (C) 2009 The Android Open Source Project
37143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler *
47143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * Licensed under the Apache License, Version 2.0 (the "License");
57143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * you may not use this file except in compliance with the License.
67143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * You may obtain a copy of the License at
77143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler *
87143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler *      http://www.apache.org/licenses/LICENSE-2.0
97143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler *
107143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * Unless required by applicable law or agreed to in writing, software
117143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * distributed under the License is distributed on an "AS IS" BASIS,
127143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
137143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * See the License for the specific language governing permissions and
147143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * limitations under the License.
157143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler */
167143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
177143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerpackage com.android.email.provider;
187143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
196e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.accounts.AccountManager;
206e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.accounts.AuthenticatorException;
216e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.accounts.OperationCanceledException;
226e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.content.ContentResolver;
236e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.content.ContentUris;
246e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.content.ContentValues;
256e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.content.Context;
266e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.database.Cursor;
276e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.database.sqlite.SQLiteDatabase;
286e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.net.Uri;
296e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.os.Bundle;
306e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.os.Environment;
316e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.os.Parcel;
326e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.test.MoreAsserts;
336e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport android.test.ProviderTestCase2;
3452e66110d8934cf0a3dd632101a56d4ef45b549aBen Komaloimport android.test.suitebuilder.annotation.LargeTest;
3552e66110d8934cf0a3dd632101a56d4ef45b549aBen Komaloimport android.test.suitebuilder.annotation.MediumTest;
3652e66110d8934cf0a3dd632101a56d4ef45b549aBen Komaloimport android.test.suitebuilder.annotation.SmallTest;
376e418aa41a17136be0dddb816d843428a0a1e722Marc Blank
38f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blankimport com.android.emailcommon.AccountManagerTypes;
39f5418f1f93b02e7fab9f15eb201800b65510998eMarc Blankimport com.android.emailcommon.provider.Account;
40a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent;
41a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.AccountColumns;
42a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.Attachment;
43a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.AttachmentColumns;
44a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.Body;
45a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.BodyColumns;
46a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.MailboxColumns;
47a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.Message;
48a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.MessageColumns;
492bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blankimport com.android.emailcommon.provider.EmailContent.PolicyColumns;
5012b82d9374947c9268217f45befe8a74bd9b60d7Ben Komaloimport com.android.emailcommon.provider.HostAuth;
5153ea83ebf91f820692e8fa8e781f5cc982dd94dbBen Komaloimport com.android.emailcommon.provider.Mailbox;
526e418aa41a17136be0dddb816d843428a0a1e722Marc Blankimport com.android.emailcommon.provider.Policy;
53f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blankimport com.android.emailcommon.utility.AccountReconciler;
5476f614720db6a282c3e890969a600585122cdcc5Marc Blankimport com.android.emailcommon.utility.TextUtilities;
5531d9acbf0623872f9d4a2b3210b5970854b654c7Marc Blankimport com.android.emailcommon.utility.Utility;
567143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
57758a532fce2f672673d38b2daa5f67eb757b118bMarc Blankimport java.io.File;
58758a532fce2f672673d38b2daa5f67eb757b118bMarc Blankimport java.io.IOException;
59758a532fce2f672673d38b2daa5f67eb757b118bMarc Blankimport java.util.ArrayList;
60758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
617143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler/**
627143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * Tests of the Email provider.
63758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank *
647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * You can run this entire test case with:
657143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler *   runtest -c com.android.email.provider.ProviderTests email
66261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki *
67261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * TODO: Add tests for cursor notification mechanism.  (setNotificationUri and notifyChange)
68261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * We can't test the entire notification mechanism with a mock content resolver, because which URI
69261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * to notify when notifyChange() is called is in the actual content resolver.
70261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * Implementing the same mechanism in a mock one is pointless.  Instead what we could do is check
71261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * what notification URI each cursor has, and with which URI is notified when
72261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * inserting/updating/deleting.  (The former require a new method from AbstractCursor)
737143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler */
7452e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo@LargeTest
757143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerpublic class ProviderTests extends ProviderTestCase2<EmailProvider> {
76758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
779d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    private EmailProvider mProvider;
789d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    private Context mMockContext;
797143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
807143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public ProviderTests() {
8131d9acbf0623872f9d4a2b3210b5970854b654c7Marc Blank        super(EmailProvider.class, EmailContent.AUTHORITY);
827143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
83758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
847143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    @Override
857143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void setUp() throws Exception {
867143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        super.setUp();
877143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext = getMockContext();
889d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        mProvider = getProvider();
89349055aad47184b72cd86de1f37ac1b7557d2e70Marc Blank        // Invalidate all caches, since we reset the database for each test
906e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        ContentCache.invalidateAllCaches();
917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
927143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    @Override
947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void tearDown() throws Exception {
957143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        super.tearDown();
967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
977143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
990d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler     * TODO: Database upgrade tests
1000d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler     */
1010d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler
10222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    //////////////////////////////////////////////////////////
10322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    ////// Utility methods
10422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    //////////////////////////////////////////////////////////
10522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
10622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    /** Sets the message count of all mailboxes to {@code -1}. */
10722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    private void setMinusOneToMessageCounts() {
10822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        ContentValues values = new ContentValues();
10922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        values.put(MailboxColumns.MESSAGE_COUNT, -1);
11022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
11122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // EmailProvider.update() doesn't allow updating messageCount, so directly use the DB.
11222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        SQLiteDatabase db = getProvider().getDatabase(mMockContext);
11322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        db.update(Mailbox.TABLE_NAME, values, null, null);
11422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    }
11522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
11622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    /** Returns the number of messages in a mailbox. */
11722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    private int getMessageCount(long mailboxId) {
11822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        return Utility.getFirstRowInt(mMockContext,
11922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy                ContentUris.withAppendedId(Mailbox.CONTENT_URI, mailboxId),
12022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy                new String[] {MailboxColumns.MESSAGE_COUNT}, null, null, null, 0);
12122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    }
12222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
12322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    /** Creates a new message. */
12422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    private static Message createMessage(Context c, Mailbox b, boolean starred, boolean read,
12522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy            int flagLoaded) {
12622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Message message = ProviderTestUtils.setupMessage(
12722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy                "1", b.mAccountKey, b.mId, true, false, c, starred, read);
12822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        message.mFlagLoaded = flagLoaded;
12922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        message.save(c);
13022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        return message;
13122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    }
13222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
13322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    //////////////////////////////////////////////////////////
13422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    ////// The tests
13522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    //////////////////////////////////////////////////////////
13622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
1370d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler    /**
1387143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test simple account save/retrieve
1397143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
14052e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo    @SmallTest
1417143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testAccountSave() {
14228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-save", true, mMockContext);
1437143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
144758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
145f5418f1f93b02e7fab9f15eb201800b65510998eMarc Blank        Account account2 = Account.restoreAccountWithId(mMockContext, account1Id);
146758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
14728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertAccountEqual("testAccountSave", account1, account2);
1487143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
14941f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
1504a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler    /**
151da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler     * Test simple account save/retrieve with predefined hostauth records
152da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler     */
15352e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo    @SmallTest
154da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler    public void testAccountSaveHostAuth() {
155da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
156da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        // add hostauth data, which should be saved the first time
157da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        account1.mHostAuthRecv = ProviderTestUtils.setupHostAuth("account-hostauth-recv", -1, false,
158da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                mMockContext);
159da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        account1.mHostAuthSend = ProviderTestUtils.setupHostAuth("account-hostauth-send", -1, false,
160da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                mMockContext);
161da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        account1.save(mMockContext);
162da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        long account1Id = account1.mId;
163da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler
164da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        // Confirm account reads back correctly
165f5418f1f93b02e7fab9f15eb201800b65510998eMarc Blank        Account account1get = Account.restoreAccountWithId(mMockContext, account1Id);
166da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        ProviderTestUtils.assertAccountEqual("testAccountSave", account1, account1get);
167da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler
168da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        // Confirm hostauth fields can be accessed & read back correctly
16912b82d9374947c9268217f45befe8a74bd9b60d7Ben Komalo        HostAuth hostAuth1get = HostAuth.restoreHostAuthWithId(mMockContext,
170da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1get.mHostAuthKeyRecv);
171da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        ProviderTestUtils.assertHostAuthEqual("testAccountSaveHostAuth-recv",
172da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1.mHostAuthRecv, hostAuth1get);
17312b82d9374947c9268217f45befe8a74bd9b60d7Ben Komalo        HostAuth hostAuth2get = HostAuth.restoreHostAuthWithId(mMockContext,
174da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1get.mHostAuthKeySend);
175da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        ProviderTestUtils.assertHostAuthEqual("testAccountSaveHostAuth-send",
176da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1.mHostAuthSend, hostAuth2get);
177da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler    }
178da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler
179040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy    public void testAccountGetHostAuthSend() {
180040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        Account account = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
181040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthSend = ProviderTestUtils.setupHostAuth("account-hostauth-send", -1, false,
182040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy                mMockContext);
183040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.save(mMockContext);
184040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        HostAuth authGet;
185040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        HostAuth authTest;
186040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
187040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authTest = account.mHostAuthSend;
188040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authTest);
189040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertTrue(account.mHostAuthKeySend != 0);
190040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
191040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // HostAuth is not changed
192040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthSend(mMockContext);
193040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertTrue(authGet == authTest); // return the same object
194040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
195040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // New HostAuth; based upon mHostAuthKeyRecv
19612b82d9374947c9268217f45befe8a74bd9b60d7Ben Komalo        authTest = HostAuth.restoreHostAuthWithId(mMockContext,
197040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy                account.mHostAuthKeySend);
198040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthSend = null;
199040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthSend(mMockContext);
200040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authGet);
201040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(account.mHostAuthSend);
202040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        ProviderTestUtils.assertHostAuthEqual("testAccountGetHostAuthSend-1", authTest, authGet);
203040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
204040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // New HostAuth; completely empty
20512b82d9374947c9268217f45befe8a74bd9b60d7Ben Komalo        authTest = new HostAuth();
206040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthSend = null;
207040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthKeySend = 0;
208040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthSend(mMockContext);
209040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authGet);
210040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(account.mHostAuthSend);
211040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        ProviderTestUtils.assertHostAuthEqual("testAccountGetHostAuthSendv-2", authTest, authGet);
212040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy    }
213040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
214040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy    public void testAccountGetHostAuthRecv() {
215040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        Account account = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
216040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthRecv = ProviderTestUtils.setupHostAuth("account-hostauth-recv", -1, false,
217040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy                mMockContext);
218040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.save(mMockContext);
219040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        HostAuth authGet;
220040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        HostAuth authTest;
221040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
222040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authTest = account.mHostAuthRecv;
223040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authTest);
224040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertTrue(account.mHostAuthKeyRecv != 0);
225040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
226040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // HostAuth is not changed
227040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthRecv(mMockContext);
228040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertTrue(authGet == authTest); // return the same object
229040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
230040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // New HostAuth; based upon mHostAuthKeyRecv
23112b82d9374947c9268217f45befe8a74bd9b60d7Ben Komalo        authTest = HostAuth.restoreHostAuthWithId(mMockContext,
232040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy                account.mHostAuthKeyRecv);
233040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthRecv = null;
234040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthRecv(mMockContext);
235040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authGet);
236040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(account.mHostAuthRecv);
237040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        ProviderTestUtils.assertHostAuthEqual("testAccountGetHostAuthRecv-1", authTest, authGet);
238040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
239040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // New HostAuth; completely empty
24012b82d9374947c9268217f45befe8a74bd9b60d7Ben Komalo        authTest = new HostAuth();
241040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthRecv = null;
242040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthKeyRecv = 0;
243040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthRecv(mMockContext);
244040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authGet);
245040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(account.mHostAuthRecv);
246040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        ProviderTestUtils.assertHostAuthEqual("testAccountGetHostAuthRecv-2", authTest, authGet);
247040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy    }
248040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
249da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler    /**
250040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy     * Simple test of account parceling.  The rather torturous path is to ensure that the
2514a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler     * account is really flattened all the way down to a parcel and back.
2524a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler     */
2534a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler    public void testAccountParcel() {
2544a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Account account1 = ProviderTestUtils.setupAccount("parcel", false, mMockContext);
2554a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Bundle b = new Bundle();
2564a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        b.putParcelable("account", account1);
2574a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Parcel p = Parcel.obtain();
2584a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        b.writeToParcel(p, 0);
2594a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        p.setDataPosition(0);       // rewind it for reading
2604a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Bundle b2 = new Bundle(Account.class.getClassLoader());
2614a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        b2.readFromParcel(p);
2624a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Account account2 = (Account) b2.getParcelable("account");
2634a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        p.recycle();
2644a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler
2654a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        ProviderTestUtils.assertAccountEqual("testAccountParcel", account1, account2);
2664a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler    }
2674a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler
268e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    /**
269e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki     * Test for {@link Account#getShortcutSafeUri()} and
270040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy     * {@link Account#getAccountIdFromShortcutSafeUri}.
271e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki     */
272e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    public void testAccountShortcutSafeUri() {
273e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Account account1 = ProviderTestUtils.setupAccount("account-1", true, mMockContext);
274e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Account account2 = ProviderTestUtils.setupAccount("account-2", true, mMockContext);
275e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final long account1Id = account1.mId;
276e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final long account2Id = account2.mId;
277e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
278e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Uri uri1 = account1.getShortcutSafeUri();
279e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Uri uri2 = account2.getShortcutSafeUri();
280e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
281e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        // Check the path part of the URIs.
282e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        MoreAsserts.assertEquals(new String[] {"account", account1.mCompatibilityUuid},
283e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                uri1.getPathSegments().toArray());
284e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        MoreAsserts.assertEquals(new String[] {"account", account2.mCompatibilityUuid},
285e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                uri2.getPathSegments().toArray());
286e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
287e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account1Id, Account.getAccountIdFromShortcutSafeUri(mMockContext, uri1));
288e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account2Id, Account.getAccountIdFromShortcutSafeUri(mMockContext, uri2));
289e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
290e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        // Test for the Eclair(2.0-2.1) style URI.
291e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account1Id, Account.getAccountIdFromShortcutSafeUri(mMockContext,
292e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                getEclairStyleShortcutUri(account1)));
293e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account2Id, Account.getAccountIdFromShortcutSafeUri(mMockContext,
294e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                getEclairStyleShortcutUri(account2)));
295e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    }
296e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
297e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    private static Uri getEclairStyleShortcutUri(Account account) {
298e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        // We used _id instead of UUID only on Eclair(2.0-2.1).
299e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        return Account.CONTENT_URI.buildUpon().appendEncodedPath("" + account.mId).build();
300e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    }
301e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
3028d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank    public void testGetProtocol() {
3038d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        Account account1 = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
3048d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // add hostauth data, with protocol
305fe68c0e7c2672e09076038b36ad24f095633d313Todd Kennedy        account1.mHostAuthRecv = ProviderTestUtils.setupHostAuth("eas", "account-hostauth-recv",
3068d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank                false, mMockContext);
3078d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // Note that getProtocol uses the receive host auth, so the protocol here shouldn't matter
3088d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // to the test result
309fe68c0e7c2672e09076038b36ad24f095633d313Todd Kennedy        account1.mHostAuthSend = ProviderTestUtils.setupHostAuth("foo", "account-hostauth-send",
3108d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank                false, mMockContext);
3118d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        account1.save(mMockContext);
31225144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        assertEquals("eas", Account.getProtocol(mMockContext, account1.mId));
31325144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        assertEquals("eas", account1.getProtocol(mMockContext));
3148d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        Account account2 = ProviderTestUtils.setupAccount("account-nohostauth", false,
3158d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank                mMockContext);
3168d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        account2.save(mMockContext);
3178d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // Make sure that we return null when there's no host auth
3188d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        assertNull(Account.getProtocol(mMockContext, account2.mId));
3198d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        assertNull(account2.getProtocol(mMockContext));
3208d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // And when there's no account
3218d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        assertNull(Account.getProtocol(mMockContext, 0));
3228d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank    }
3238d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank
324652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki    public void testAccountIsValidId() {
325652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        final Account account1 = ProviderTestUtils.setupAccount("account-1", true, mMockContext);
326652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        final Account account2 = ProviderTestUtils.setupAccount("account-2", true, mMockContext);
327652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki
328652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        assertTrue(Account.isValidId(mMockContext, account1.mId));
329652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        assertTrue(Account.isValidId(mMockContext, account2.mId));
330652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki
331652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        assertFalse(Account.isValidId(mMockContext, 1234567)); // Some random ID
332c133e6f1858e33fabaa6ffa173c1402bf9a98e31Makoto Onuki        assertFalse(Account.isValidId(mMockContext, -1));
333c133e6f1858e33fabaa6ffa173c1402bf9a98e31Makoto Onuki        assertFalse(Account.isValidId(mMockContext, -500));
334652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki    }
335652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki
33641f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    private final static String[] MAILBOX_UNREAD_COUNT_PROJECTION = new String [] {
33741f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        MailboxColumns.UNREAD_COUNT
33841f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    };
33941f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    private final static int MAILBOX_UNREAD_COUNT_COLMUN = 0;
34041f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
34141f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    /**
34241f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     * Get the value of the unread count in the mailbox of the account.
34341f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     * This can be different from the actual number of unread messages in that mailbox.
34441f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     */
34541f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    private int getUnreadCount(long mailboxId) {
34641f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        String text = null;
34741f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        Cursor c = null;
34841f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        try {
34941f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            c = mMockContext.getContentResolver().query(
35041f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    Mailbox.CONTENT_URI,
35141f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    MAILBOX_UNREAD_COUNT_PROJECTION,
35241f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    EmailContent.RECORD_ID + "=?",
35341f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    new String[] { String.valueOf(mailboxId) },
35441f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    null);
35541f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            c.moveToFirst();
35641f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            text = c.getString(MAILBOX_UNREAD_COUNT_COLMUN);
35741f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        } finally {
35841f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            c.close();
35941f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        }
36041f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        return Integer.valueOf(text);
36141f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    }
36241f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
3634119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    private static String[] expectedAttachmentNames =
364976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        new String[] {"attachment1.doc", "attachment2.xls", "attachment3"};
365976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    // The lengths need to be kept in ascending order
3664119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    private static long[] expectedAttachmentSizes = new long[] {31415L, 97701L, 151213L};
367976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank
368fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    /*
369fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * Returns null if the message has no body.
370fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     */
371fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    private Body loadBodyForMessageId(long messageId) {
372fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Cursor c = null;
373fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        try {
374fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            c = mMockContext.getContentResolver().query(
375fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    EmailContent.Body.CONTENT_URI,
376fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    EmailContent.Body.CONTENT_PROJECTION,
377fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    EmailContent.Body.MESSAGE_KEY + "=?",
378fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    new String[] {String.valueOf(messageId)},
379fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    null);
380fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            int numBodies = c.getCount();
381fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            assertTrue("at most one body", numBodies < 2);
382fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            return c.moveToFirst() ? EmailContent.getContent(c, Body.class) : null;
383fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        } finally {
384fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            c.close();
385fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        }
386fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    }
387fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
3887143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
3897143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test simple message save/retrieve
390758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank     *
3917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: serverId vs. serverIntId
3927143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
39352e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo    @MediumTest
3947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testMessageSave() {
39528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-save", true, mMockContext);
3967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
39728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
3987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
3997143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
4007143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Test a simple message (saved with no body)
40128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
40228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
4037143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message1Id = message1.mId;
4047143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Message message1get = EmailContent.Message.restoreMessageWithId(mMockContext, message1Id);
40528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertMessageEqual("testMessageSave", message1, message1get);
4067143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
4077143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Test a message saved with a body
4087143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Note that it will read back w/o the text & html so we must extract those
40928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
41028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
4117143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message2Id = message2.mId;
4127143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String text2 = message2.mText;
4137143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String html2 = message2.mHtml;
414936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        String textReply2 = message2.mTextReply;
415936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        String htmlReply2 = message2.mHtmlReply;
4166c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long sourceKey2 = message2.mSourceKey;
4175fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        String introText2 = message2.mIntroText;
4187143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        message2.mText = null;
4197143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        message2.mHtml = null;
420936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        message2.mTextReply = null;
421936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        message2.mHtmlReply = null;
422e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        message2.mSourceKey = 0;
4235fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        message2.mIntroText = null;
4247143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Message message2get = EmailContent.Message.restoreMessageWithId(mMockContext, message2Id);
42528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertMessageEqual("testMessageSave", message2, message2get);
426758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
4277143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Now see if there's a body saved with the right stuff
428fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Body body2 = loadBodyForMessageId(message2Id);
429fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertEquals("body text", text2, body2.mTextContent);
430fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertEquals("body html", html2, body2.mHtmlContent);
431936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals("reply text", textReply2, body2.mTextReply);
432936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals("reply html", htmlReply2, body2.mHtmlReply);
4336c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals("source key", sourceKey2, body2.mSourceKey);
4345fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        assertEquals("intro text", introText2, body2.mIntroText);
435976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank
4364119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Message with attachments and body
437976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        Message message3 = ProviderTestUtils.setupMessage("message3", account1Id, box1Id, true,
438976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                false, mMockContext);
439976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        ArrayList<Attachment> atts = new ArrayList<Attachment>();
440976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        for (int i = 0; i < 3; i++) {
4414119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
4424119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
4434119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    false, mMockContext));
444976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        }
445976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        message3.mAttachments = atts;
4469e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        message3.save(mMockContext);
447976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        long message3Id = message3.mId;
448976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank
449976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        // Now check the attachments; there should be three and they should match name and size
450fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Cursor c = null;
451976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        try {
452976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // Note that there is NO guarantee of the order of returned records in the general case,
453976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // so we specifically ask for ordering by size.  The expectedAttachmentSizes array must
454976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // be kept sorted by size (ascending) for this test to work properly
455976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            c = mMockContext.getContentResolver().query(
456976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.CONTENT_URI,
457976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.CONTENT_PROJECTION,
458976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.MESSAGE_KEY + "=?",
459976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    new String[] {
460976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                            String.valueOf(message3Id)
461976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    },
462976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.SIZE);
463976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            int numAtts = c.getCount();
464976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            assertEquals(3, numAtts);
465976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            int i = 0;
466976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            while (c.moveToNext()) {
4674119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                Attachment actual = EmailContent.getContent(c, Attachment.class);
4684119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                ProviderTestUtils.assertAttachmentEqual("save-message3", atts.get(i), actual);
4694119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                i++;
4704119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            }
4714119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        } finally {
4724119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.close();
4734119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        }
4744119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
4754119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Message with attachments but no body
4764119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Message message4 = ProviderTestUtils.setupMessage("message4", account1Id, box1Id, false,
4774119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                false, mMockContext);
4784119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        atts = new ArrayList<Attachment>();
4794119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        for (int i = 0; i < 3; i++) {
4804119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
4814119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
4824119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    false, mMockContext));
4834119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        }
4844119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        message4.mAttachments = atts;
4859e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        message4.save(mMockContext);
4864119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        long message4Id = message4.mId;
4874119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
4884119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Now check the attachments; there should be three and they should match name and size
4894119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        c = null;
49041f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
4914119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        try {
4924119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            // Note that there is NO guarantee of the order of returned records in the general case,
4934119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            // so we specifically ask for ordering by size.  The expectedAttachmentSizes array must
4944119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            // be kept sorted by size (ascending) for this test to work properly
4954119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c = mMockContext.getContentResolver().query(
4964119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.CONTENT_URI,
4974119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.CONTENT_PROJECTION,
4984119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.MESSAGE_KEY + "=?",
4994119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    new String[] {
5004119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                            String.valueOf(message4Id)
5014119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    },
5024119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.SIZE);
5034119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            int numAtts = c.getCount();
5044119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            assertEquals(3, numAtts);
5054119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            int i = 0;
5064119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            while (c.moveToNext()) {
5074119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                Attachment actual = EmailContent.getContent(c, Attachment.class);
5084119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                ProviderTestUtils.assertAttachmentEqual("save-message4", atts.get(i), actual);
509976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                i++;
510976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            }
511976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        } finally {
512976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            c.close();
5137143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        }
51444144d0301213536b02f2080237b63d8271b2d0bMihai Preda
51544144d0301213536b02f2080237b63d8271b2d0bMihai Preda        // test EmailContent.restoreAttachmentsWitdMessageId()
51644144d0301213536b02f2080237b63d8271b2d0bMihai Preda        Attachment[] attachments =
51744144d0301213536b02f2080237b63d8271b2d0bMihai Preda            Attachment.restoreAttachmentsWithMessageId(mMockContext, message4Id);
51844144d0301213536b02f2080237b63d8271b2d0bMihai Preda        int size = attachments.length;
51944144d0301213536b02f2080237b63d8271b2d0bMihai Preda        assertEquals(3, size);
52044144d0301213536b02f2080237b63d8271b2d0bMihai Preda        for (int i = 0; i < size; ++i) {
52144144d0301213536b02f2080237b63d8271b2d0bMihai Preda            ProviderTestUtils.assertAttachmentEqual("save-message4", atts.get(i), attachments[i]);
52244144d0301213536b02f2080237b63d8271b2d0bMihai Preda        }
5237143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
524758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5257143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
526e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank     * Test that saving a message creates the proper snippet for that message
527e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank     */
528e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank    public void testMessageSaveAddsSnippet() {
529e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Account account = ProviderTestUtils.setupAccount("message-snippet", true, mMockContext);
530e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Mailbox box = ProviderTestUtils.setupMailbox("box1", account.mId, true, mMockContext);
531e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank
532e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // Create a message without a body, unsaved
533e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Message message = ProviderTestUtils.setupMessage("message", account.mId, box.mId, false,
534e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank                false, mMockContext);
535e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mText = "This is some text";
536e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mHtml = "<html>This is some text</html>";
537e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.save(mMockContext);
538e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Message restoredMessage = Message.restoreMessageWithId(mMockContext, message.mId);
539e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // We should have the plain text as the snippet
54076f614720db6a282c3e890969a600585122cdcc5Marc Blank        assertEquals(restoredMessage.mSnippet,
54176f614720db6a282c3e890969a600585122cdcc5Marc Blank                TextUtilities.makeSnippetFromPlainText(message.mText));
542e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank
543e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // Start again
544e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message = ProviderTestUtils.setupMessage("message", account.mId, box.mId, false,
545e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank                false, mMockContext);
546e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mText = null;
547e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mHtml = "<html>This is some text</html>";
548e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.save(mMockContext);
549e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        restoredMessage = Message.restoreMessageWithId(mMockContext, message.mId);
550e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // We should have the plain text as the snippet
55176f614720db6a282c3e890969a600585122cdcc5Marc Blank        assertEquals(restoredMessage.mSnippet,
55276f614720db6a282c3e890969a600585122cdcc5Marc Blank                TextUtilities.makeSnippetFromHtmlText(message.mHtml));
553e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank    }
554e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank
555e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank    /**
5567143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: update account
5577143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
558758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5597143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5607143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: update mailbox
5617143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
562758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5637143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: update message
5657143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
566758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5677143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5687143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test delete account
5697143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: hostauth
5707143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
5717143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testAccountDelete() {
57228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-delete-1", true, mMockContext);
5737143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
57428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account2 = ProviderTestUtils.setupAccount("account-delete-2", true, mMockContext);
5757143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account2Id = account2.mId;
5767143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5777143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are two accounts
5787143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numBoxes = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
5797143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numBoxes);
5807143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5817143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete one of them
5827143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Account.CONTENT_URI, account1Id);
5837143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
5847143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5857143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there's only one account now
5867143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
5877143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numBoxes);
5887143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5897143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the other one
5907143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        uri = ContentUris.withAppendedId(Account.CONTENT_URI, account2Id);
5917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
5927143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no accounts now
5947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
5957143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numBoxes);
5967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
597758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5999627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Test for Body.lookupBodyIdWithMessageId()
6009627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Verifies that:
6019627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * - for a message without body, -1 is returned.
6029627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * - for a mesage with body, the id matches the one from loadBodyForMessageId.
6039627d014e16235eadf981b9165807dc72a14a383Mihai Preda     */
6049627d014e16235eadf981b9165807dc72a14a383Mihai Preda    public void testLookupBodyIdWithMessageId() {
6059627d014e16235eadf981b9165807dc72a14a383Mihai Preda        final ContentResolver resolver = mMockContext.getContentResolver();
6069627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
6079627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long account1Id = account1.mId;
6089627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
6099627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long box1Id = box1.mId;
6109627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6119627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 1. create message with no body, check that returned bodyId is -1
6129627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
6139627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
6149627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message1Id = message1.mId;
615bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        long bodyId1 = Body.lookupBodyIdWithMessageId(mMockContext, message1Id);
6169627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(bodyId1, -1);
6179627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6189627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 2. create message with body, check that returned bodyId is correct
6199627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
6209627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
6219627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message2Id = message2.mId;
622bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        long bodyId2 = Body.lookupBodyIdWithMessageId(mMockContext, message2Id);
6239627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body body = loadBodyForMessageId(message2Id);
6249627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body);
6259627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(body.mId, bodyId2);
6269627d014e16235eadf981b9165807dc72a14a383Mihai Preda    }
6279627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6289627d014e16235eadf981b9165807dc72a14a383Mihai Preda    /**
6299627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Test for Body.updateBodyWithMessageId().
6309627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * 1. - create message without body,
6319627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - update its body (set TEXT_CONTENT)
6329627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - check correct updated body is read back
6339627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *
6349627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * 2. - create message with body,
6359627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - update body (set TEXT_CONTENT)
6369627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - check correct updated body is read back
6379627d014e16235eadf981b9165807dc72a14a383Mihai Preda     */
6389627d014e16235eadf981b9165807dc72a14a383Mihai Preda    public void testUpdateBodyWithMessageId() {
6399627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
6409627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long account1Id = account1.mId;
6419627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
6429627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long box1Id = box1.mId;
6439627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6449627d014e16235eadf981b9165807dc72a14a383Mihai Preda        final String textContent = "foobar some odd text";
645936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        final String htmlContent = "and some html";
646936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        final String textReply = "plain text reply";
647936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        final String htmlReply = "or the html reply";
6485fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        final String introText = "fred wrote:";
6499627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6509627d014e16235eadf981b9165807dc72a14a383Mihai Preda        ContentValues values = new ContentValues();
6519627d014e16235eadf981b9165807dc72a14a383Mihai Preda        values.put(BodyColumns.TEXT_CONTENT, textContent);
652936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        values.put(BodyColumns.HTML_CONTENT, htmlContent);
653936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        values.put(BodyColumns.TEXT_REPLY, textReply);
654936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        values.put(BodyColumns.HTML_REPLY, htmlReply);
655e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        values.put(BodyColumns.SOURCE_MESSAGE_KEY, 17);
6565fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        values.put(BodyColumns.INTRO_TEXT, introText);
6579627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6589627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 1
6599627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
6609627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
6619627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message1Id = message1.mId;
6629627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body body1 = loadBodyForMessageId(message1Id);
6639627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNull(body1);
6649627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body.updateBodyWithMessageId(mMockContext, message1Id, values);
6659627d014e16235eadf981b9165807dc72a14a383Mihai Preda        body1 = loadBodyForMessageId(message1Id);
6669627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body1);
6679627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(body1.mTextContent, textContent);
668936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body1.mHtmlContent, htmlContent);
669936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body1.mTextReply, textReply);
670936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body1.mHtmlReply, htmlReply);
671e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        assertEquals(body1.mSourceKey, 17);
6725fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        assertEquals(body1.mIntroText, introText);
6739627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6749627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 2
6759627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
6769627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
6779627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message2Id = message2.mId;
6789627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body body2 = loadBodyForMessageId(message2Id);
6799627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body2);
6809627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertTrue(!body2.mTextContent.equals(textContent));
6819627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body.updateBodyWithMessageId(mMockContext, message2Id, values);
6829627d014e16235eadf981b9165807dc72a14a383Mihai Preda        body2 = loadBodyForMessageId(message1Id);
6839627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body2);
6849627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(body2.mTextContent, textContent);
685936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body2.mHtmlContent, htmlContent);
686936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body2.mTextReply, textReply);
687936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body2.mHtmlReply, htmlReply);
688e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        assertEquals(body2.mSourceKey, 17);
6895fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        assertEquals(body2.mIntroText, introText);
6909627d014e16235eadf981b9165807dc72a14a383Mihai Preda    }
6919627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6929627d014e16235eadf981b9165807dc72a14a383Mihai Preda    /**
693c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler     * Test body retrieve methods
694c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler     */
695c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler    public void testBodyRetrieve() {
696c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        // No account needed
697c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        // No mailbox needed
698c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        Message message1 = ProviderTestUtils.setupMessage("bodyretrieve", 1, 1, true,
699c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                true, mMockContext);
700c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        long messageId = message1.mId;
701c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler
702c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mText,
703c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreBodyTextWithMessageId(mMockContext, messageId));
704c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mHtml,
705c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreBodyHtmlWithMessageId(mMockContext, messageId));
706c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mTextReply,
707c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreReplyTextWithMessageId(mMockContext, messageId));
708c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mHtmlReply,
709c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreReplyHtmlWithMessageId(mMockContext, messageId));
710c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mIntroText,
711c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreIntroTextWithMessageId(mMockContext, messageId));
7121575e7860d2259f1aed201ab23d526cddf787365Mihai Preda        assertEquals(message1.mSourceKey,
7131575e7860d2259f1aed201ab23d526cddf787365Mihai Preda                Body.restoreBodySourceKey(mMockContext, messageId));
714c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler    }
715c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler
716c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler    /**
717fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * Test delete body.
718fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 1. create message without body (message id 1)
719fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 2. create message with body (message id 2. The body has _id 1 and messageKey 2).
720fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 3. delete first message.
721fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 4. verify that body for message 2 has not been deleted.
722fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 5. delete message 2, verify body is deleted.
723fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     */
724fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    public void testDeleteBody() {
725fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        final ContentResolver resolver = mMockContext.getContentResolver();
726fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
727fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // Create account and mailboxes
728fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
729fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long account1Id = account1.mId;
730fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
731fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long box1Id = box1.mId;
732fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
733fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 1. create message without body
734fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
735fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
736fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message1Id = message1.mId;
737fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
738fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 2. create message with body
739fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
740fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
741fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message2Id = message2.mId;
742fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // verify body is there
743fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
744fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
745fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 3. delete first message
746fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Message.CONTENT_URI, message1Id), null, null);
747c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank
748fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 4. verify body for second message wasn't deleted
749fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
750fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
751fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 5. delete second message, check its body is deleted
752fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Message.CONTENT_URI, message2Id), null, null);
753fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNull(loadBodyForMessageId(message2Id));
754fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    }
755fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
756fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    /**
757fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * Test delete orphan bodies.
758fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 1. create message without body (message id 1)
759fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 2. create message with body (message id 2. Body has _id 1 and messageKey 2).
760fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 3. delete first message.
761fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 4. delete some other mailbox -- this triggers delete orphan bodies.
762fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 5. verify that body for message 2 has not been deleted.
763fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     */
764fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    public void testDeleteOrphanBodies() {
765fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        final ContentResolver resolver = mMockContext.getContentResolver();
766fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
767ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create account and two mailboxes
768fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
769fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long account1Id = account1.mId;
770fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
771fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long box1Id = box1.mId;
772fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", account1Id, true, mMockContext);
773fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long box2Id = box2.mId;
774fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
775fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 1. create message without body
776fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
777fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
778fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message1Id = message1.mId;
779fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
780fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 2. create message with body
781fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
782fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
783fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message2Id = message2.mId;
784fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        //verify body is there
785fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
786fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
787fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 3. delete first message
788fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Message.CONTENT_URI, message1Id), null, null);
789fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
790fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 4. delete some mailbox (because it triggers "delete orphan bodies")
791fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Mailbox.CONTENT_URI, box2Id), null, null);
792fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
793fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 5. verify body for second message wasn't deleted during "delete orphan bodies"
794fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
795fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    }
796fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
797fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    /**
7980efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     * Note that we can't use EmailContent.count() here because it uses a projection including
7990efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     * count(*), and count(*) is incompatible with a LIMIT (i.e. the limit would be applied to the
8000efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     * single column returned with count(*), rather than to the query itself)
8010efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     */
8020efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    private int count(Context context, Uri uri, String selection, String[] selectionArgs) {
8030efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Cursor c = context.getContentResolver().query(uri, EmailContent.ID_PROJECTION, selection,
8040efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                selectionArgs, null);
8050efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        try {
8060efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank            return c.getCount();
8070efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        } finally {
8080efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank            c.close();
8090efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        }
8100efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    }
8110efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8120efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    public void testMessageQueryWithLimit() {
8130efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        final Context context = mMockContext;
8140efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8150efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Create account and two mailboxes
8160efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Account acct = ProviderTestUtils.setupAccount("orphaned body", true, context);
8170efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
8180efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", acct.mId, true, context);
8190efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8200efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Create 4 messages in box1
8210efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, false, true, context);
8220efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, false, true, context);
8230efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, false, true, context);
8240efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, false, true, context);
8250efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8260efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Create 4 messages in box2
8270efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box2.mId, false, true, context);
8280efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box2.mId, false, true, context);
8290efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box2.mId, false, true, context);
8300efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box2.mId, false, true, context);
8310efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8320efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Check normal case, special case (limit 1), and arbitrary limits
8330efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(8, count(mMockContext, Message.CONTENT_URI, null, null));
8340efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(1, count(mMockContext, EmailContent.uriWithLimit(Message.CONTENT_URI, 1),
8350efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                null, null));
8360efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(3, count(mMockContext, EmailContent.uriWithLimit(Message.CONTENT_URI, 3),
8370efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                null, null));
8380efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(8, count(mMockContext, EmailContent.uriWithLimit(Message.CONTENT_URI, 100),
8390efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                null, null));
8400efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8410efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Check that it works with selection/selection args
8420efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        String[] args = new String[] {Long.toString(box1.mId)};
8430efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(4, count(mMockContext, Message.CONTENT_URI,
8440efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                MessageColumns.MAILBOX_KEY + "=?", args));
8450efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(1, count(mMockContext,
8460efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                EmailContent.uriWithLimit(Message.CONTENT_URI, 1),
8470efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                MessageColumns.MAILBOX_KEY + "=?", args));
8480efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    }
8490efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8500efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    /**
851ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * Test delete orphan messages
852ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 1. create message without body (message id 1)
853ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 2. create message with body (message id 2. Body has _id 1 and messageKey 2).
854ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 3. delete first message.
855ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 4. delete some other mailbox -- this triggers delete orphan bodies.
856ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 5. verify that body for message 2 has not been deleted.
857ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     */
858ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     public void testDeleteOrphanMessages() {
859ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        final ContentResolver resolver = mMockContext.getContentResolver();
860ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        final Context context = mMockContext;
861ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
862ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create account and two mailboxes
863ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Account acct = ProviderTestUtils.setupAccount("orphaned body", true, context);
864ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
865ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", acct.mId, true, context);
866ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
867ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create 4 messages in box1
868ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_1 =
869ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, false, true, context);
870ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_2 =
871ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, false, true, context);
872ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_3 =
873ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, false, true, context);
874ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_4 =
875ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, false, true, context);
876ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
877ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create 4 messages in box2
878ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_1 =
879ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message1", acct.mId, box2.mId, false, true, context);
880ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_2 =
881ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message2", acct.mId, box2.mId, false, true, context);
882ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_3 =
883ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message3", acct.mId, box2.mId, false, true, context);
884ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_4 =
885ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message4", acct.mId, box2.mId, false, true, context);
886ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
887ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Delete 2 from each mailbox
888ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_1.mId),
889ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
890ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_2.mId),
891ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
892ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_1.mId),
893ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
894ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_2.mId),
895ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
896ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
897ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should be 4 items in the deleted item table
898ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.DELETED_CONTENT_URI, null, null));
899ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
900ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Update 2 from each mailbox
901ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentValues v = new ContentValues();
902ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        v.put(MessageColumns.DISPLAY_NAME, "--updated--");
903ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_3.mId),
904ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
905ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_4.mId),
906ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
907ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_3.mId),
908ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
909ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_4.mId),
910ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
911ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
912ef83299b99288c00b9d661260d19715e73e6889cMarc Blank         // There should be 4 items in the updated item table
913ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.UPDATED_CONTENT_URI, null, null));
914ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
915ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Manually add 2 messages from a "deleted" mailbox to deleted and updated tables
916ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Use a value > 2 for the deleted box id
917ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        long delBoxId = 10;
918ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create 4 messages in the "deleted" mailbox
919ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_A =
920ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageA", acct.mId, delBoxId, false, false, context);
921ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_B =
922ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageB", acct.mId, delBoxId, false, false, context);
923ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_C =
924ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageC", acct.mId, delBoxId, false, false, context);
925ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_D =
926ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageD", acct.mId, delBoxId, false, false, context);
927ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
928ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentValues cv;
929ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // We have to assign id's manually because there are no autoincrement id's for these tables
930ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Start with an id that won't exist, since id's in these tables must be unique
931ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        long msgId = 10;
932ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // It's illegal to manually insert these, so we need to catch the exception
933ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // NOTE: The insert succeeds, and then throws the exception
934ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
935ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_A.toContentValues();
936ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
937ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.DELETED_CONTENT_URI, cv);
938ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
939ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
940ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
941ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_B.toContentValues();
942ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
943ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.DELETED_CONTENT_URI, cv);
944ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
945ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
946ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
947ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_C.toContentValues();
948ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
949ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.UPDATED_CONTENT_URI, cv);
950ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
951ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
952ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
953ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_D.toContentValues();
954ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
955ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.UPDATED_CONTENT_URI, cv);
956ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
957ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
958ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
959ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should be 6 items in the deleted and updated tables
960ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(6, EmailContent.count(context, Message.UPDATED_CONTENT_URI, null, null));
961ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(6, EmailContent.count(context, Message.DELETED_CONTENT_URI, null, null));
962ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
963ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Delete the orphans
9642bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        EmailProvider.deleteMessageOrphans(EmailProvider.getReadableDatabase(context),
965ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                Message.DELETED_TABLE_NAME);
9662bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        EmailProvider.deleteMessageOrphans(EmailProvider.getReadableDatabase(context),
967ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                Message.UPDATED_TABLE_NAME);
968ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
969ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should now be 4 messages in each of the deleted and updated tables again
970ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.UPDATED_CONTENT_URI, null, null));
971ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.DELETED_CONTENT_URI, null, null));
972ef83299b99288c00b9d661260d19715e73e6889cMarc Blank    }
973ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
974ef83299b99288c00b9d661260d19715e73e6889cMarc Blank    /**
9757143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test delete message
9767143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: body
9777143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: attachments
9787143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
9797143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testMessageDelete() {
98028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-delete", true, mMockContext);
9817143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
98228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
9837143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
98428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
98528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
9867143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message1Id = message1.mId;
98728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, false,
98828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
9897143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message2Id = message2.mId;
9907143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND " +
9927143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler                EmailContent.MessageColumns.MAILBOX_KEY + "=?";
9937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String[] selArgs = new String[] { String.valueOf(account1Id), String.valueOf(box1Id) };
9947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9957143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are two messages
9967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
9977143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numMessages);
9987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9997143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete one of them
10007143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1Id);
10017143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
10027143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10037143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there's only one message now
10047143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
10057143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numMessages);
10067143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10077143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the other one
10087143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        uri = ContentUris.withAppendedId(Message.CONTENT_URI, message2Id);
10097143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
10107143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10117143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no messages now
10127143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
10137143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numMessages);
10147143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
1015758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
10167143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
1017ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * Test delete synced message
1018ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: body
1019ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: attachments
1020ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     */
1021ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    public void testSyncedMessageDelete() {
102228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("synced-message-delete", true,
102328448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
1024ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long account1Id = account1.mId;
102528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
1026ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long box1Id = box1.mId;
102728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
102828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1029ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message1Id = message1.mId;
103028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, false,
103128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1032ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message2Id = message2.mId;
1033ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1034ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND "
1035ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                + EmailContent.MessageColumns.MAILBOX_KEY + "=?";
1036ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String[] selArgs = new String[] {
1037ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            String.valueOf(account1Id), String.valueOf(box1Id)
1038ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        };
1039ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1040ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there are two messages
1041ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1042ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(2, numMessages);
1043ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1044ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure we start with no synced deletions
1045ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1046ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1047ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1048ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1049ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // now delete one of them SYNCED
1050ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Uri uri = ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message1Id);
1051ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
1052ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1053ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's only one message now
1054ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1055ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1056ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1057ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's one synced deletion now
1058ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1059ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1060ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1061ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1062ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // now delete the other one NOT SYNCED
1063ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        uri = ContentUris.withAppendedId(Message.CONTENT_URI, message2Id);
1064ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
1065ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1066ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there are no messages now
1067ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1068ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1069ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1070ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's still one deletion now
1071ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1072ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1073ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1074ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    }
1075ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1076ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    /**
1077ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * Test message update
1078ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: body
1079ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: attachments
1080ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     */
1081ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    public void testMessageUpdate() {
108228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-update", true, mMockContext);
1083ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long account1Id = account1.mId;
108428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
1085ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long box1Id = box1.mId;
108628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
108728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1088ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message1Id = message1.mId;
108928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, false,
109028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1091ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message2Id = message2.mId;
1092ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        ContentResolver cr = mMockContext.getContentResolver();
1093ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1094ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND "
1095ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                + EmailContent.MessageColumns.MAILBOX_KEY + "=?";
1096ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String[] selArgs = new String[] {
1097ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            String.valueOf(account1Id), String.valueOf(box1Id)
1098ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        };
1099ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1100ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there are two messages
1101ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1102ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(2, numMessages);
1103ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1104ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // change the first one
1105ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1Id);
1106ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        ContentValues cv = new ContentValues();
1107ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cv.put(MessageColumns.FROM_LIST, "from-list");
1108ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cr.update(uri, cv, null, null);
1109ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1110ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's no updated message
1111ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1112ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1113ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1114ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1115ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // get the message back from the provider, make sure the change "stuck"
1116ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Message restoredMessage = Message.restoreMessageWithId(mMockContext, message1Id);
1117ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals("from-list", restoredMessage.mFrom);
1118ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1119ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // change the second one
1120ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        uri = ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message2Id);
1121ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cv = new ContentValues();
1122ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cv.put(MessageColumns.FROM_LIST, "from-list");
1123ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cr.update(uri, cv, null, null);
1124ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1125ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's one updated message
1126ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1127ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1128ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1129ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1130ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // get the message back from the provider, make sure the change "stuck",
1131ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // as before
1132ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        restoredMessage = Message.restoreMessageWithId(mMockContext, message2Id);
1133ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals("from-list", restoredMessage.mFrom);
1134ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1135ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // get the original message back from the provider
1136ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Cursor c = cr.query(Message.UPDATED_CONTENT_URI, Message.CONTENT_PROJECTION, null, null,
1137ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                null);
1138ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        try {
1139ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            assertTrue(c.moveToFirst());
1140ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            Message originalMessage = EmailContent.getContent(c, Message.class);
1141ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            // make sure this has the original value
1142ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            assertEquals("from message2", originalMessage.mFrom);
1143ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            // Should only be one
1144ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            assertFalse(c.moveToNext());
1145ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        } finally {
1146ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            c.close();
1147ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        }
1148ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1149ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // delete the second message
1150ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cr.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message2Id), null, null);
1151ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1152ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // hey, presto! the change should be gone
1153ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1154ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1155ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1156ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1157ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // and there should now be a deleted record
1158ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1159ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1160ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1161ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    }
1162ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1163ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    /**
11647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: cascaded delete account
11657143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: hostauth
11667143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: body
11677143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: attachments
11687143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: create other account, mailbox & messages and confirm the right objects were deleted
11697143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
11707143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testCascadeDeleteAccount() {
117128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-delete-cascade", true,
117228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
11737143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
117428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
11757143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
117628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        /* Message message1 = */ ProviderTestUtils.setupMessage("message1", account1Id, box1Id,
117728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
117828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        /* Message message2 = */ ProviderTestUtils.setupMessage("message2", account1Id, box1Id,
117928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
11807143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
11817143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there is one account, one mailbox, and two messages
11827143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numAccounts = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
11837143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numAccounts);
11847143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, null, null);
11857143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numBoxes);
11867143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
11877143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numMessages);
11887143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
11897143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // delete the account
11907143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Account.CONTENT_URI, account1Id);
11917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
11927143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
11937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no accounts, mailboxes, or messages
11947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numAccounts = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
11957143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numAccounts);
11967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, null, null);
11977143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numBoxes);
11987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
11997143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numMessages);
12007143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
1201758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
12027143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
12037143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test cascaded delete mailbox
12047143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: body
12057143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: attachments
12067143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: create other mailbox & messages and confirm the right objects were deleted
12077143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
12087143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testCascadeDeleteMailbox() {
120928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("mailbox-delete-cascade", true,
121028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
12117143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
121228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
12137143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
1214ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id,
121528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
1216ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id,
1217ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                false, true, mMockContext);
1218ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message3 = ProviderTestUtils.setupMessage("message3", account1Id, box1Id,
1219ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                false, true, mMockContext);
1220ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message4 = ProviderTestUtils.setupMessage("message4", account1Id, box1Id,
122128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
1222ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ProviderTestUtils.setupMessage("message5", account1Id, box1Id, false, true, mMockContext);
1223ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ProviderTestUtils.setupMessage("message6", account1Id, box1Id, false, true, mMockContext);
12247143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
12257143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND " +
12267143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler                EmailContent.MessageColumns.MAILBOX_KEY + "=?";
12277143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String[] selArgs = new String[] { String.valueOf(account1Id), String.valueOf(box1Id) };
12287143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
12290e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // make sure there are six messages
12307143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1231ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(6, numMessages);
1232ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
1233ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentValues cv = new ContentValues();
1234ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        cv.put(Message.SERVER_ID, "SERVER_ID");
1235ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentResolver resolver = mMockContext.getContentResolver();
1236ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
1237ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Update two messages
1238ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message1.mId),
1239ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                cv, null, null);
1240ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message2.mId),
1241ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                cv, null, null);
1242ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Delete two messages
1243ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message3.mId),
1244ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
1245ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message4.mId),
1246ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
1247ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
1248ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should now be two messages in updated/deleted, and 4 in messages
1249ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1250ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, numMessages);
1251ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1252ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
1253ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(2, numMessages);
1254ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1255ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
12567143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numMessages);
1257758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
12587143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the mailbox
12597143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Mailbox.CONTENT_URI, box1Id);
1260ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(uri, null, null);
1261758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1262ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // there should now be zero messages in all three tables
12637143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
12647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numMessages);
1265ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1266ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
1267ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(0, numMessages);
1268ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1269ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
1270ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(0, numMessages);
12717143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
1272758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
12737143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
12746c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     * Test cascaded delete message
12756c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     * Confirms that deleting a message will also delete its body & attachments
12767143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
12776c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    public void testCascadeMessageDelete() {
12786c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-cascade", true, mMockContext);
12796c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long account1Id = account1.mId;
12806c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
12816c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long box1Id = box1.mId;
1282bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
12836c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Each message has a body, and also give each 2 attachments
12846c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
12856c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                false, mMockContext);
12866c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ArrayList<Attachment> atts = new ArrayList<Attachment>();
12876c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        for (int i = 0; i < 2; i++) {
12886c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
12896c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
12906c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    false, mMockContext));
12916c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        }
12926c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message1.mAttachments = atts;
12936c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message1.save(mMockContext);
12946c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long message1Id = message1.mId;
12956c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
12966c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, true,
12976c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                false, mMockContext);
12986c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        atts = new ArrayList<Attachment>();
12996c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        for (int i = 0; i < 2; i++) {
13006c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
13016c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
13026c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    false, mMockContext));
13036c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        }
13046c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message2.mAttachments = atts;
13056c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message2.save(mMockContext);
13066c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long message2Id = message2.mId;
13076c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13086c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Set up to test total counts of bodies & attachments for our test messages
13096c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        String bodySelection = BodyColumns.MESSAGE_KEY + " IN (?,?)";
13106c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        String attachmentSelection = AttachmentColumns.MESSAGE_KEY + " IN (?,?)";
13116c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        String[] selArgs = new String[] { String.valueOf(message1Id), String.valueOf(message2Id) };
1312bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
13136c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // make sure there are two bodies
13146c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        int numBodies = EmailContent.count(mMockContext, Body.CONTENT_URI, bodySelection, selArgs);
13156c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(2, numBodies);
13166c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13176c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // make sure there are four attachments
13186c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        int numAttachments = EmailContent.count(mMockContext, Attachment.CONTENT_URI,
13196c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                attachmentSelection, selArgs);
13206c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(4, numAttachments);
13216c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13226c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // now delete one of the messages
13236c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1Id);
13246c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
13256c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13266c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // there should be one body and two attachments
13276c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numBodies = EmailContent.count(mMockContext, Body.CONTENT_URI, bodySelection, selArgs);
13286c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(1, numBodies);
13296c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13306c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numAttachments = EmailContent.count(mMockContext, Attachment.CONTENT_URI,
13316c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                attachmentSelection, selArgs);
13326c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(2, numAttachments);
13336c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13346c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // now delete the other message
13356c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        uri = ContentUris.withAppendedId(Message.CONTENT_URI, message2Id);
13366c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
13376c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13386c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // make sure there are no bodies or attachments
13396c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numBodies = EmailContent.count(mMockContext, Body.CONTENT_URI, bodySelection, selArgs);
13406c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(0, numBodies);
13416c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13426c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numAttachments = EmailContent.count(mMockContext, Attachment.CONTENT_URI,
13436c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                attachmentSelection, selArgs);
13446c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(0, numAttachments);
13456c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    }
13467143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
1347976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    /**
1348976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     * Test that our unique file name algorithm works as expected.  Since this test requires an
1349976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     * SD card, we check the environment first, and return immediately if none is mounted.
1350976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     * @throws IOException
1351976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     */
1352976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    public void testCreateUniqueFile() throws IOException {
1353976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        // Delete existing files, if they exist
1354976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        if (!Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {
1355976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            return;
1356976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        }
1357976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        try {
1358976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            String fileName = "A11achm3n1.doc";
1359976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            File uniqueFile = Attachment.createUniqueFile(fileName);
1360976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            assertEquals(fileName, uniqueFile.getName());
1361976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            if (uniqueFile.createNewFile()) {
1362976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                uniqueFile = Attachment.createUniqueFile(fileName);
1363976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                assertEquals("A11achm3n1-2.doc", uniqueFile.getName());
1364976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                if (uniqueFile.createNewFile()) {
1365976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    uniqueFile = Attachment.createUniqueFile(fileName);
1366976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    assertEquals("A11achm3n1-3.doc", uniqueFile.getName());
1367976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                }
1368976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank           }
1369976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            fileName = "A11achm3n1";
1370976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            uniqueFile = Attachment.createUniqueFile(fileName);
1371976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            assertEquals(fileName, uniqueFile.getName());
1372976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            if (uniqueFile.createNewFile()) {
1373976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                uniqueFile = Attachment.createUniqueFile(fileName);
1374976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                assertEquals("A11achm3n1-2", uniqueFile.getName());
1375976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            }
1376976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        } finally {
1377976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            File directory = Environment.getExternalStorageDirectory();
1378976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // These are the files that should be created earlier in the test.  Make sure
1379976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // they are deleted for the next go-around
1380976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            String[] fileNames = new String[] {"A11achm3n1.doc", "A11achm3n1-2.doc", "A11achm3n1"};
1381976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            int length = fileNames.length;
1382976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            for (int i = 0; i < length; i++) {
1383976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                File file = new File(directory, fileNames[i]);
1384976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                if (file.exists()) {
1385976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    file.delete();
1386976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                }
1387976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            }
1388976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        }
1389976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    }
13904119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
13914119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    /**
13924119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler     * Test retrieving attachments by message ID (using EmailContent.Attachment.MESSAGE_ID_URI)
13934119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler     */
13944119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    public void testGetAttachmentByMessageIdUri() {
13954119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
13964119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Note, we don't strictly need accounts, mailboxes or messages to run this test.
13974119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Attachment a1 = ProviderTestUtils.setupAttachment(1, "a1", 100, true, mMockContext);
13984119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Attachment a2 = ProviderTestUtils.setupAttachment(1, "a2", 200, true, mMockContext);
1399758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ProviderTestUtils.setupAttachment(2, "a3", 300, true, mMockContext);
1400758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ProviderTestUtils.setupAttachment(2, "a4", 400, true, mMockContext);
14014119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
14024119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Now ask for the attachments of message id=1
14034119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Note: Using the "sort by size" trick to bring them back in expected order
14044119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Uri uri = ContentUris.withAppendedId(Attachment.MESSAGE_ID_URI, 1);
14054119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Cursor c = mMockContext.getContentResolver().query(uri, Attachment.CONTENT_PROJECTION,
14064119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                null, null, Attachment.SIZE);
14074119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        assertEquals(2, c.getCount());
14084119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
14094119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        try {
14104119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.moveToFirst();
14114119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            Attachment a1Get = EmailContent.getContent(c, Attachment.class);
14124119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-1", a1, a1Get);
14134119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.moveToNext();
14144119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            Attachment a2Get = EmailContent.getContent(c, Attachment.class);
14154119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-2", a2, a2Get);
14164119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        } finally {
14174119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.close();
14184119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        }
14194119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    }
142054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
142154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler    /**
14226c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     * Test deleting attachments by message ID (using EmailContent.Attachment.MESSAGE_ID_URI)
14236c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     */
14246c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    public void testDeleteAttachmentByMessageIdUri() {
14256c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ContentResolver mockResolver = mMockContext.getContentResolver();
14266c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14276c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Note, we don't strictly need accounts, mailboxes or messages to run this test.
14286c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ProviderTestUtils.setupAttachment(1, "a1", 100, true, mMockContext);
14296c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ProviderTestUtils.setupAttachment(1, "a2", 200, true, mMockContext);
14306c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Attachment a3 = ProviderTestUtils.setupAttachment(2, "a3", 300, true, mMockContext);
14316c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Attachment a4 = ProviderTestUtils.setupAttachment(2, "a4", 400, true, mMockContext);
14326c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14336c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Delete all attachments for message id=1
14346c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Uri uri = ContentUris.withAppendedId(Attachment.MESSAGE_ID_URI, 1);
14356c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        mockResolver.delete(uri, null, null);
14366c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14376c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Read back all attachments and confirm that we have the expected remaining attachments
14386c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // (the attachments that are set for message id=2).  Note order-by size to simplify test.
14396c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Cursor c = mockResolver.query(Attachment.CONTENT_URI, Attachment.CONTENT_PROJECTION,
14406c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                null, null, Attachment.SIZE);
14416c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(2, c.getCount());
14426c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14436c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        try {
14446c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            c.moveToFirst();
14456c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            Attachment a3Get = EmailContent.getContent(c, Attachment.class);
14466c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-3", a3, a3Get);
14476c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            c.moveToNext();
14486c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            Attachment a4Get = EmailContent.getContent(c, Attachment.class);
14496c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-4", a4, a4Get);
14506c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        } finally {
14516c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            c.close();
14526c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        }
14536c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    }
14546c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
145552e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo    @SmallTest
145663537746479f4b65517bd217c1a5f76d697367ebMarc Blank    public void testGetDefaultAccountNoneExplicitlySet() {
145763537746479f4b65517bd217c1a5f76d697367ebMarc Blank        Account account1 = ProviderTestUtils.setupAccount("account-default-1", false, mMockContext);
145863537746479f4b65517bd217c1a5f76d697367ebMarc Blank        account1.mIsDefault = false;
145963537746479f4b65517bd217c1a5f76d697367ebMarc Blank        account1.save(mMockContext);
146063537746479f4b65517bd217c1a5f76d697367ebMarc Blank
146163537746479f4b65517bd217c1a5f76d697367ebMarc Blank        // We should find account1 as default
146263537746479f4b65517bd217c1a5f76d697367ebMarc Blank        long defaultAccountId = Account.getDefaultAccountId(mMockContext);
146363537746479f4b65517bd217c1a5f76d697367ebMarc Blank        assertEquals(defaultAccountId, account1.mId);
146463537746479f4b65517bd217c1a5f76d697367ebMarc Blank
146552e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo        Account account2 = ProviderTestUtils.setupAccount("account-default-2", false, mMockContext);
146663537746479f4b65517bd217c1a5f76d697367ebMarc Blank        account2.mIsDefault = false;
146763537746479f4b65517bd217c1a5f76d697367ebMarc Blank        account2.save(mMockContext);
146863537746479f4b65517bd217c1a5f76d697367ebMarc Blank
146952e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo        Account account3 = ProviderTestUtils.setupAccount("account-default-3", false, mMockContext);
147052e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo        account3.mIsDefault = false;
147152e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo        account3.save(mMockContext);
147252e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo
147352e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo        // We should find the earliest one as the default, so that it can be consistent on
147452e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo        // repeated calls.
147563537746479f4b65517bd217c1a5f76d697367ebMarc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
147652e66110d8934cf0a3dd632101a56d4ef45b549aBen Komalo        assertTrue(defaultAccountId == account1.mId);
147763537746479f4b65517bd217c1a5f76d697367ebMarc Blank    }
147863537746479f4b65517bd217c1a5f76d697367ebMarc Blank
14796c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    /**
148054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * Tests of default account behavior
1481758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank     *
148254c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * 1.  Simple set/get
148354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * 2.  Moving default between 3 accounts
148454c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * 3.  Delete default, make sure another becomes default
148554c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     */
148654c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler    public void testSetGetDefaultAccount() {
148754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        // There should be no default account if there are no accounts
148854c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long defaultAccountId = Account.getDefaultAccountId(mMockContext);
1489acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        assertEquals(Account.NO_ACCOUNT, defaultAccountId);
149054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1491acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        Account account1 = ProviderTestUtils.setupAccount("account-default-1", false, mMockContext);
1492acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        account1.mIsDefault = false;
1493acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        account1.save(mMockContext);
149454c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long account1Id = account1.mId;
1495acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        Account account2 = ProviderTestUtils.setupAccount("account-default-2", false, mMockContext);
1496acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        account2.mIsDefault = false;
1497acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        account2.save(mMockContext);
149854c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long account2Id = account2.mId;
1499acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        Account account3 = ProviderTestUtils.setupAccount("account-default-3", false, mMockContext);
1500acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        account3.mIsDefault = false;
1501acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        account3.save(mMockContext);
150254c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long account3Id = account3.mId;
150354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1504acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        // With three accounts, but none marked default, confirm that the first one is the default.
150554c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1506acd985efb4b29da28953308ba3d5c8f43b760379Ben Komalo        assertTrue(defaultAccountId == account1Id);
150754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
15089e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        updateIsDefault(account1, true);
150954c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        defaultAccountId = Account.getDefaultAccountId(mMockContext);
15109e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        assertEquals(account1Id, defaultAccountId);
151154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1512531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        updateIsDefault(account2, true);
1513531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1514531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account2Id, defaultAccountId);
1515531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank
1516531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        updateIsDefault(account3, true);
1517531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1518531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account3Id, defaultAccountId);
151954c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
152054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        // Now delete a non-default account and confirm no change
152154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        Uri uri = ContentUris.withAppendedId(Account.CONTENT_URI, account1Id);
152254c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
152354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1524531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1525531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account3Id, defaultAccountId);
152654c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
152754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        // Now confirm deleting the default account and it switches to another one
152854c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        uri = ContentUris.withAppendedId(Account.CONTENT_URI, account3Id);
152954c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
153054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1531531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1532531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account2Id, defaultAccountId);
1533758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
15349e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        // Now delete the final account and confirm there are no default accounts again
15359e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        uri = ContentUris.withAppendedId(Account.CONTENT_URI, account2Id);
15369e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
15379e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler
153854c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        defaultAccountId = Account.getDefaultAccountId(mMockContext);
15399e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        assertEquals(-1, defaultAccountId);
154054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler    }
154154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
15429e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler    private void updateIsDefault(Account account, boolean newState) {
15439e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        account.setDefaultAccount(newState);
15449e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        ContentValues cv = new ContentValues();
15459e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        cv.put(AccountColumns.IS_DEFAULT, account.mIsDefault);
15469e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        account.update(mMockContext, cv);
15479e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler    }
1548758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1549758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    public static Message setupUnreadMessage(String name, long accountId, long mailboxId,
1550758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank            boolean addBody, boolean saveIt, Context context) {
1551758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message msg =
1552758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank            ProviderTestUtils.setupMessage(name, accountId, mailboxId, addBody, false, context);
1553758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        msg.mFlagRead = false;
1554758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        if (saveIt) {
1555758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank            msg.save(context);
1556758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        }
1557758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        return msg;
1558758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    }
1559758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1560758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    public void testUnreadCountTriggers() {
1561758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Start with one account and three mailboxes
1562758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Account account = ProviderTestUtils.setupAccount("triggers", true, mMockContext);
1563758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Mailbox boxA = ProviderTestUtils.setupMailbox("boxA", account.mId, true, mMockContext);
1564758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Mailbox boxB = ProviderTestUtils.setupMailbox("boxB", account.mId, true, mMockContext);
1565758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Mailbox boxC = ProviderTestUtils.setupMailbox("boxC", account.mId, true, mMockContext);
1566758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1567758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Make sure there are no unreads
1568758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1569758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxB.mId));
1570758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxC.mId));
1571758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1572758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Create 4 unread messages (only 3 named) in boxA
1573758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message message1 = setupUnreadMessage("message1", account.mId, boxA.mId,
1574758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank                false, true, mMockContext);
1575758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message message2= setupUnreadMessage("message2", account.mId, boxA.mId,
1576758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank                false, true, mMockContext);
1577758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message message3 =  setupUnreadMessage("message3", account.mId, boxA.mId,
1578758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank                false, true, mMockContext);
1579758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        setupUnreadMessage("message4", account.mId, boxC.mId, false, true, mMockContext);
1580758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1581758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Make sure the unreads are where we expect them
1582758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(3, getUnreadCount(boxA.mId));
1583758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxB.mId));
1584758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1585758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1586758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // After deleting message 1, the count in box A should be decremented (to 2)
1587758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ContentResolver cr = mMockContext.getContentResolver();
1588758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1.mId);
1589758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.delete(uri, null, null);
1590758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(2, getUnreadCount(boxA.mId));
1591758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxB.mId));
1592758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1593758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1594758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Move message 2 to box B, leaving 1 in box A and 1 in box B
1595758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        message2.mMailboxKey = boxB.mId;
1596758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ContentValues cv = new ContentValues();
1597758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.MAILBOX_KEY, boxB.mId);
1598758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message2.mId), cv, null, null);
1599758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxA.mId));
1600758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1601758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1602758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1603758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Mark message 3 (from box A) read, leaving 0 in box A
1604758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.clear();
1605758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.FLAG_READ, 1);
1606758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message3.mId), cv, null, null);
1607758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1608758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1609758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1610758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1611758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Move message 3 to box C; should be no change (it's read)
1612758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        message3.mMailboxKey = boxC.mId;
1613758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.clear();
1614758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.MAILBOX_KEY, boxC.mId);
1615758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message3.mId), cv, null, null);
1616758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1617758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1618758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1619758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1620758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Mark message 3 unread; it's now in box C, so that box's count should go up to 3
1621758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.clear();
1622758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.FLAG_READ, 0);
1623758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message3.mId), cv, null, null);
1624758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1625758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1626758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(2, getUnreadCount(boxC.mId));
1627758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    }
16289627d014e16235eadf981b9165807dc72a14a383Mihai Preda
16299627d014e16235eadf981b9165807dc72a14a383Mihai Preda    /**
16309627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Test for EmailProvider.createIndex().
16319627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Check that it returns exacly the same string as the one used previously for index creation.
16329627d014e16235eadf981b9165807dc72a14a383Mihai Preda     */
16339627d014e16235eadf981b9165807dc72a14a383Mihai Preda    public void testCreateIndex() {
16349627d014e16235eadf981b9165807dc72a14a383Mihai Preda        String oldStr = "create index message_" + MessageColumns.TIMESTAMP
16359627d014e16235eadf981b9165807dc72a14a383Mihai Preda            + " on " + Message.TABLE_NAME + " (" + MessageColumns.TIMESTAMP + ");";
16369627d014e16235eadf981b9165807dc72a14a383Mihai Preda        String newStr = EmailProvider.createIndex(Message.TABLE_NAME, MessageColumns.TIMESTAMP);
16379627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(newStr, oldStr);
16389627d014e16235eadf981b9165807dc72a14a383Mihai Preda    }
1639c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank
16400e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    public void testDatabaseCorruptionRecovery() {
16410e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final ContentResolver resolver = mMockContext.getContentResolver();
16420e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final Context context = mMockContext;
16430e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16440e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create account and two mailboxes
16450e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Account acct = ProviderTestUtils.setupAccount("acct1", true, context);
16460e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
16470e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16480e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create 4 messages in box1 with bodies
16490e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, true, true, context);
16500e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, true, true, context);
16510e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, true, true, context);
16520e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, true, true, context);
16530e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16540e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four messages
16550e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        int count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
16560e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
16570e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four bodies
16580e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
16590e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
16600e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16610e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProvider.db file
16620e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        File dbFile = mMockContext.getDatabasePath(EmailProvider.DATABASE_NAME);
16630e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProvider.db database should exist (the provider creates it automatically)
16640e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
16650e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
16660e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Delete it, and confirm it is gone
16670e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.delete());
16680e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertFalse(dbFile.exists());
16690e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16700e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProviderBody.db file
16710e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        dbFile = mMockContext.getDatabasePath(EmailProvider.BODY_DATABASE_NAME);
16720e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProviderBody.db database should still exist
16730e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
16740e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
16750e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16760e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // URI to uncache the databases
16770e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // This simulates the Provider starting up again (otherwise, it will still be pointing to
16780e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the already opened files)
16790e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Note that we only have access to the EmailProvider via the ContentResolver; therefore,
16800e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // we cannot directly call into the provider and use a URI for this
16810e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        resolver.update(EmailProvider.INTEGRITY_CHECK_URI, null, null, null);
16820e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16830e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // TODO We should check for the deletion of attachment files once this is implemented in
16840e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the provider
1685bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
16860e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Explanation for what happens below...
16870e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The next time the database is created by the provider, it will notice that there's
16880e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // already a EmailProviderBody.db file.  In this case, it will delete that database to
16890e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // ensure that both are in sync (and empty)
16900e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16910e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no bodies
16920e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
16930e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
16940e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16950e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no messages
16960e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
16970e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
16980e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    }
16990e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17000e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    public void testBodyDatabaseCorruptionRecovery() {
17010e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final ContentResolver resolver = mMockContext.getContentResolver();
17020e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final Context context = mMockContext;
17030e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17040e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create account and two mailboxes
17050e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Account acct = ProviderTestUtils.setupAccount("acct1", true, context);
17060e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
17070e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17080e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create 4 messages in box1 with bodies
17090e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, true, true, context);
17100e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, true, true, context);
17110e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, true, true, context);
17120e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, true, true, context);
17130e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17140e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four messages
17150e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        int count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
17160e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
17170e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four bodies
17180e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
17190e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
17200e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17210e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProviderBody.db file
17220e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        File dbFile = mMockContext.getDatabasePath(EmailProvider.BODY_DATABASE_NAME);
17230e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProviderBody.db database should exist (the provider creates it automatically)
17240e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
17250e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
17260e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Delete it, and confirm it is gone
17270e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.delete());
17280e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertFalse(dbFile.exists());
17290e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17300e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProvider.db file
17310e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        dbFile = mMockContext.getDatabasePath(EmailProvider.DATABASE_NAME);
17320e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProviderBody.db database should still exist
17330e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
17340e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
17350e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17360e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // URI to uncache the databases
17370e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // This simulates the Provider starting up again (otherwise, it will still be pointing to
17380e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the already opened files)
17390e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Note that we only have access to the EmailProvider via the ContentResolver; therefore,
17400e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // we cannot directly call into the provider and use a URI for this
17410e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        resolver.update(EmailProvider.INTEGRITY_CHECK_URI, null, null, null);
17420e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17430e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // TODO We should check for the deletion of attachment files once this is implemented in
17440e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the provider
17450e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17460e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Explanation for what happens below...
17470e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The next time the body database is created by the provider, it will notice that there's
17480e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // already a populated EmailProvider.db file.  In this case, it will delete that database to
17490e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // ensure that both are in sync (and empty)
17500e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17510e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no messages
17520e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
17530e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
17540e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17550e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no bodies
17560e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
17570e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
17580e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    }
1759694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1760bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki    public void testAccountIsSecurityHold() {
1761bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        final Context context = mMockContext;
1762bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account acct1 = ProviderTestUtils.setupAccount("acct1", true, context);
1763bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1764bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account acct2 = ProviderTestUtils.setupAccount("acct2", false, context);
1765bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        acct2.mFlags |= Account.FLAGS_SECURITY_HOLD;
1766bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        acct2.save(context);
1767bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1768bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertFalse(Account.isSecurityHold(context, acct1.mId));
1769bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertTrue(Account.isSecurityHold(context, acct2.mId));
1770bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertFalse(Account.isSecurityHold(context, 9999999)); // No such account
1771bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki   }
1772bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1773bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki    public void testClearAccountHoldFlags() {
1774bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a1 = ProviderTestUtils.setupAccount("holdflag-1", false, mMockContext);
1775bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a1.mFlags = Account.FLAGS_NOTIFY_NEW_MAIL;
17766e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        a1.mPolicy = new Policy();
1777bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a1.save(mMockContext);
1778bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a2 = ProviderTestUtils.setupAccount("holdflag-2", false, mMockContext);
1779bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a2.mFlags = Account.FLAGS_VIBRATE_ALWAYS | Account.FLAGS_SECURITY_HOLD;
17806e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        a2.mPolicy = new Policy();
1781bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a2.save(mMockContext);
1782bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1783bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        // bulk clear
1784bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account.clearSecurityHoldOnAllAccounts(mMockContext);
1785bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1786bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        // confirm new values as expected - no hold flags; other flags unmolested
1787bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a1a = Account.restoreAccountWithId(mMockContext, a1.mId);
1788bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertEquals(Account.FLAGS_NOTIFY_NEW_MAIL, a1a.mFlags);
1789bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a2a = Account.restoreAccountWithId(mMockContext, a2.mId);
1790bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertEquals(Account.FLAGS_VIBRATE_ALWAYS, a2a.mFlags);
1791bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki    }
1792574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1793833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki    private static Message createMessage(Context c, Mailbox b, boolean starred, boolean read) {
1794543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        return ProviderTestUtils.setupMessage(
1795543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy                "1", b.mAccountKey, b.mId, true, true, c, starred, read);
1796543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy    }
1797543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy
17985247ab8cae802272b1e29e81d3b31a1c4e710da5Makoto Onuki    public void testAccountIsEasAccount() {
17996d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki        Account account = new Account();
180025144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        // No hostauth
18015247ab8cae802272b1e29e81d3b31a1c4e710da5Makoto Onuki        assertFalse(account.isEasAccount(mMockContext));
18026d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki
180325144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount(null, false);
180425144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount("", false);
180525144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount("x", false);
180625144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount("eas", true);
180725144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki    }
18086d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki
180925144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki    private void checkAccountIsEasAccount(String protocol, boolean expected) {
181025144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        Account account = ProviderTestUtils.setupAccount("account", false, mMockContext);
181125144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        account.mHostAuthRecv = ProviderTestUtils.setupHostAuth(protocol, "account-hostauth-recv",
1812fe68c0e7c2672e09076038b36ad24f095633d313Todd Kennedy                false, mMockContext);
181325144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        account.save(mMockContext);
181425144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        assertEquals(expected, account.isEasAccount(mMockContext));
18156d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki    }
1816bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank
1817bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank    public void testGetKeyColumnLong() {
1818bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        final Context c = mMockContext;
1819bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Account a = ProviderTestUtils.setupAccount("acct", true, c);
1820bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a.mId, true, c, Mailbox.TYPE_MAIL);
1821bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a.mId, true, c, Mailbox.TYPE_MAIL);
1822bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Message m1 = createMessage(c, b1, false, false);
1823bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Message m2 = createMessage(c, b2, false, false);
1824bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(a.mId, Message.getKeyColumnLong(c, m1.mId, MessageColumns.ACCOUNT_KEY));
1825bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(a.mId, Message.getKeyColumnLong(c, m2.mId, MessageColumns.ACCOUNT_KEY));
1826bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(b1.mId, Message.getKeyColumnLong(c, m1.mId, MessageColumns.MAILBOX_KEY));
1827bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(b2.mId, Message.getKeyColumnLong(c, m2.mId, MessageColumns.MAILBOX_KEY));
1828bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank    }
1829bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank
1830aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki    public void testGetAccountIdForMessageId() {
1831aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        final Context c = mMockContext;
1832aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("acct1", true, c);
1833aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Account a2 = ProviderTestUtils.setupAccount("acct2", true, c);
1834aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a1.mId, true, c, Mailbox.TYPE_MAIL);
1835aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a2.mId, true, c, Mailbox.TYPE_MAIL);
1836aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Message m1 = createMessage(c, b1, false, false);
1837aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Message m2 = createMessage(c, b2, false, false);
1838aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki
1839aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        assertEquals(a1.mId, Account.getAccountIdForMessageId(c, m1.mId));
1840aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        assertEquals(a2.mId, Account.getAccountIdForMessageId(c, m2.mId));
1841aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki
1842aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        // message desn't exist
1843aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        assertEquals(-1, Account.getAccountIdForMessageId(c, 12345));
1844aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki    }
1845aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki
1846200c6bd9fa19b78acc2c1664f858521aa9885353Todd Kennedy    public void testGetAccountForMessageId() {
1847200c6bd9fa19b78acc2c1664f858521aa9885353Todd Kennedy        final Context c = mMockContext;
1848200c6bd9fa19b78acc2c1664f858521aa9885353Todd Kennedy        Account a = ProviderTestUtils.setupAccount("acct", true, c);
1849200c6bd9fa19b78acc2c1664f858521aa9885353Todd Kennedy        Message m1 = ProviderTestUtils.setupMessage("1", a.mId, 1, true, true, c, false, false);
1850200c6bd9fa19b78acc2c1664f858521aa9885353Todd Kennedy        Message m2 = ProviderTestUtils.setupMessage("1", a.mId, 2, true, true, c, false, false);
1851200c6bd9fa19b78acc2c1664f858521aa9885353Todd Kennedy        ProviderTestUtils.assertAccountEqual("x", a, Account.getAccountForMessageId(c, m1.mId));
1852200c6bd9fa19b78acc2c1664f858521aa9885353Todd Kennedy        ProviderTestUtils.assertAccountEqual("x", a, Account.getAccountForMessageId(c, m2.mId));
1853200c6bd9fa19b78acc2c1664f858521aa9885353Todd Kennedy    }
1854200c6bd9fa19b78acc2c1664f858521aa9885353Todd Kennedy
1855e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki    public void testGetAccountGetInboxIdTest() {
1856e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        final Context c = mMockContext;
1857e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
1858e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        // Prepare some data with red-herrings.
1859e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("acct1", true, c);
1860e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Account a2 = ProviderTestUtils.setupAccount("acct2", true, c);
1861e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox b1i = ProviderTestUtils.setupMailbox("b1i", a1.mId, true, c, Mailbox.TYPE_INBOX);
1862e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox b2a = ProviderTestUtils.setupMailbox("b2a", a2.mId, true, c, Mailbox.TYPE_MAIL);
1863e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox b2i = ProviderTestUtils.setupMailbox("b2b", a2.mId, true, c, Mailbox.TYPE_INBOX);
1864e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
1865e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertEquals(b2i.mId, Account.getInboxId(c, a2.mId));
1866d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki
1867d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        // No account found.
1868d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        assertEquals(-1, Account.getInboxId(c, 999999));
1869e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki    }
1870e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
1871261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki    /**
1872261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki     * Check if update to {@link Account#RESET_NEW_MESSAGE_COUNT_URI} resets the new message count.
1873261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki     */
1874261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki    public void testResetNewMessageCount() {
1875261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        final Context c = mMockContext;
1876261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        final ContentResolver cr = c.getContentResolver();
1877261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
1878261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // Prepare test data
1879261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a1 = ProviderTestUtils.setupAccount("acct1", false, c);
1880261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a1.mNewMessageCount = 1;
1881261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a1.save(c);
1882261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a2 = ProviderTestUtils.setupAccount("acct2", false, c);
1883261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a2.mNewMessageCount = 2;
1884261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a2.save(c);
1885261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a3 = ProviderTestUtils.setupAccount("acct3", false, c);
1886261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a3.mNewMessageCount = 3;
1887261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a3.save(c);
1888261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a4 = ProviderTestUtils.setupAccount("acct4", false, c);
1889261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a4.mNewMessageCount = 4;
1890261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a4.save(c);
1891261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a5 = ProviderTestUtils.setupAccount("acct5", false, c);
1892261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a5.mNewMessageCount = 5;
1893261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a5.save(c);
1894261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
1895261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // With ID in URI, no selection
1896261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(ContentUris.withAppendedId(Account.RESET_NEW_MESSAGE_COUNT_URI, a1.mId),
1897261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki                null, null, null);
1898261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
1899261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(2, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
1900261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(3, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
1901261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(4, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
1902261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(5, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
1903261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
1904261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // No ID in URI, with selection
1905261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(Account.RESET_NEW_MESSAGE_COUNT_URI, null,
1906261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki                EmailContent.ID_SELECTION, new String[] {Long.toString(a2.mId)});
1907261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
1908261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
1909261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(3, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
1910261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(4, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
1911261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(5, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
1912261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
1913261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // With ID, with selection
1914261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(ContentUris.withAppendedId(Account.RESET_NEW_MESSAGE_COUNT_URI, a3.mId), null,
1915261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki                EmailContent.ID_SELECTION, new String[] {Long.toString(a3.mId)});
1916261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
1917261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
1918261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
1919261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(4, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
1920261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(5, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
1921261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
1922261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // No ID in URI, no selection
1923261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(Account.RESET_NEW_MESSAGE_COUNT_URI, null, null, null);
1924261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
1925261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
1926261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
1927261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
1928261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
1929261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki    }
1930899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
19319d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    /**
19329d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     * Check if update on ACCOUNT_ID_ADD_TO_FIELD updates the cache properly.
19339d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     */
19349d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    public void testUpdateCacheAccountIdAddToField() {
19359d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        final Context c = mMockContext;
19369d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("a1", true, c);
19379d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19389d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        int start = Account.restoreAccountWithId(c, a1.mId).mNewMessageCount;
19399d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19409d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // +1 to NEW_MESSAGE_COUNT
19419d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        ContentValues cv = new ContentValues();
19429d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        cv.put(EmailContent.FIELD_COLUMN_NAME, AccountColumns.NEW_MESSAGE_COUNT);
19439d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        cv.put(EmailContent.ADD_COLUMN_NAME, 1);
19449d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        mProvider.update(ContentUris.withAppendedId(Account.ADD_TO_FIELD_URI, a1.mId), cv,
19459d5aaeacd6b222877f25924818317c9153708261Makoto Onuki                null, null);
19469d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19479d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Check
19489d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertEquals(start + 1, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
19499d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    }
19509d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19519d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    /**
19529d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     * Check if update on ACCOUNT_RESET_NEW_COUNT updates the cache properly.
19539d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     */
19549d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    public void testUpdateCacheAccountResetNewCount() {
19559d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        final Context c = mMockContext;
19569d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("a1", true, c);
19579d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19589d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // precondition
19599d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertTrue(Account.restoreAccountWithId(c, a1.mId).mNewMessageCount > 0);
19609d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19619d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Reset
19629d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        mProvider.update(Account.RESET_NEW_MESSAGE_COUNT_URI, null, null, null);
19639d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19649d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Check
19659d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
19669d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    }
19679d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19689d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    /**
19699d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     * Check if update on ACCOUNT_RESET_NEW_COUNT_ID updates the cache properly.
19709d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     */
19719d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    public void testUpdateCacheAccountResetNewCountId() {
19729d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        final Context c = mMockContext;
19739d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("a1", true, c);
19749d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19759d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // precondition
19769d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertTrue(Account.restoreAccountWithId(c, a1.mId).mNewMessageCount > 0);
19779d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19789d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Reset
19799d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        mProvider.update(ContentUris.withAppendedId(Account.RESET_NEW_MESSAGE_COUNT_URI, a1.mId),
19809d5aaeacd6b222877f25924818317c9153708261Makoto Onuki                null, null, null);
19819d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19829d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Check
19839d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
19849d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    }
19859d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
19869d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    /**
1987d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank     * Check that we're handling illegal uri's properly (by throwing an exception unless it's a
1988d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank     * query for an id of -1, in which case we return a zero-length cursor)
1989d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank     */
1990d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank    public void testIllegalUri() {
1991d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        final ContentResolver cr = mMockContext.getContentResolver();
1992d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank
1993d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        ContentValues cv = new ContentValues();
1994d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        Uri uri = Uri.parse("content://" + EmailContent.AUTHORITY + "/fooble");
1995d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        try {
1996d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            cr.insert(uri, cv);
1997d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            fail("Insert should have thrown exception");
1998d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        } catch (IllegalArgumentException e) {
1999d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        }
2000d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        try {
2001d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            cr.update(uri, cv, null, null);
2002d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            fail("Update should have thrown exception");
2003d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        } catch (IllegalArgumentException e) {
2004d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        }
2005d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        try {
2006d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            cr.delete(uri, null, null);
2007d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            fail("Delete should have thrown exception");
2008d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        } catch (IllegalArgumentException e) {
2009d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        }
2010d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        try {
2011d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            cr.query(uri, EmailContent.ID_PROJECTION, null, null, null);
2012d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            fail("Query should have thrown exception");
2013d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        } catch (IllegalArgumentException e) {
2014d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        }
2015d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        uri = Uri.parse("content://" + EmailContent.AUTHORITY + "/mailbox/fred");
2016d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        try {
2017d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            cr.query(uri, EmailContent.ID_PROJECTION, null, null, null);
2018d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            fail("Query should have thrown exception");
2019d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        } catch (IllegalArgumentException e) {
2020d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        }
2021d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        uri = Uri.parse("content://" + EmailContent.AUTHORITY + "/mailbox/-1");
2022d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        Cursor c = cr.query(uri, EmailContent.ID_PROJECTION, null, null, null);
2023d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        assertNotNull(c);
2024d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        assertEquals(0, c.getCount());
2025d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        c.close();
2026d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank    }
202722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
202822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    /**
202922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy     * Verify {@link EmailProvider#recalculateMessageCount(android.database.sqlite.SQLiteDatabase)}
203022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy     */
203122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    public void testRecalculateMessageCounts() {
203222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        final Context c = mMockContext;
203322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
203422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Create accounts
203522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Account a1 = ProviderTestUtils.setupAccount("holdflag-1", true, c);
203622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Account a2 = ProviderTestUtils.setupAccount("holdflag-2", true, c);
203722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
203822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Create mailboxes for each account
203922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a1.mId, true, c, Mailbox.TYPE_INBOX);
204022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a1.mId, true, c, Mailbox.TYPE_OUTBOX);
204122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b3 = ProviderTestUtils.setupMailbox("box3", a2.mId, true, c, Mailbox.TYPE_INBOX);
204222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b4 = ProviderTestUtils.setupMailbox("box4", a2.mId, true, c, Mailbox.TYPE_OUTBOX);
204322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox bt = ProviderTestUtils.setupMailbox("boxT", a2.mId, true, c, Mailbox.TYPE_TRASH);
204422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
204522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Create some messages
204622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // b1 (account 1, inbox): 1 message, including 1 starred
204722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Message m11 = createMessage(c, b1, true, false, Message.FLAG_LOADED_COMPLETE);
204822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
204922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // b2 (account 1, outbox): 2 message, including 1 starred
205022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Message m21 = createMessage(c, b2, false, false, Message.FLAG_LOADED_COMPLETE);
205122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Message m22 = createMessage(c, b2, true, true, Message.FLAG_LOADED_COMPLETE);
205222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
205322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // b3 (account 2, inbox): 3 message, including 1 starred
205422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Message m31 = createMessage(c, b3, false, false, Message.FLAG_LOADED_COMPLETE);
205522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Message m32 = createMessage(c, b3, false, false, Message.FLAG_LOADED_COMPLETE);
205622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Message m33 = createMessage(c, b3, true, true, Message.FLAG_LOADED_COMPLETE);
205722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
205822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // b4 (account 2, outbox) has no messages.
205922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
206022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // bt (account 2, trash) has 3 messages, including 2 starred
206122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Message mt1 = createMessage(c, bt, true, false, Message.FLAG_LOADED_COMPLETE);
206222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Message mt2 = createMessage(c, bt, true, false, Message.FLAG_LOADED_COMPLETE);
206322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Message mt3 = createMessage(c, bt, false, false, Message.FLAG_LOADED_COMPLETE);
206422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
206522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Verifiy initial message counts
206622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(1, getMessageCount(b1.mId));
206722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(2, getMessageCount(b2.mId));
206822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(3, getMessageCount(b3.mId));
206922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(0, getMessageCount(b4.mId));
207022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(3, getMessageCount(bt.mId));
207122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
207222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Whew. The setup is done; now let's actually get to the test
207322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
207422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // First, invalidate the message counts.
207522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        setMinusOneToMessageCounts();
207622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(-1, getMessageCount(b1.mId));
207722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(-1, getMessageCount(b2.mId));
207822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(-1, getMessageCount(b3.mId));
207922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(-1, getMessageCount(b4.mId));
208022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(-1, getMessageCount(bt.mId));
208122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
208222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Batch update.
208322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        SQLiteDatabase db = getProvider().getDatabase(mMockContext);
208422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        EmailProvider.recalculateMessageCount(db);
208522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
208622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Check message counts are valid again
208722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(1, getMessageCount(b1.mId));
208822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(2, getMessageCount(b2.mId));
208922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(3, getMessageCount(b3.mId));
209022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(0, getMessageCount(b4.mId));
209122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(3, getMessageCount(bt.mId));
209222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    }
209322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
209422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    /** Creates an account */
209522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    private Account createAccount(Context c, String name, HostAuth recvAuth, HostAuth sendAuth) {
209622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Account account = ProviderTestUtils.setupAccount(name, false, c);
209722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        if (recvAuth != null) {
209822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy            account.mHostAuthKeyRecv = recvAuth.mId;
209922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy            if (sendAuth == null) {
210022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy                account.mHostAuthKeySend = recvAuth.mId;
210122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy            }
210222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        }
210322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        if (sendAuth != null) {
210422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy            account.mHostAuthKeySend = sendAuth.mId;
210522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        }
210622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        account.save(c);
210722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        return account;
210822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    }
210922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
211022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    /** Creates a mailbox; redefine as we need version 17 mailbox values */
211122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    private Mailbox createMailbox(Context c, String displayName, String serverId, long parentKey,
211222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy            long accountId) {
211322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox box = new Mailbox();
211422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
211522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mDisplayName = displayName;
211622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mServerId = serverId;
211722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mParentKey = parentKey;
211822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mAccountKey = accountId;
211922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Don't care about the fields below ... set them for giggles
212022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mType = Mailbox.TYPE_MAIL;
212122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mDelimiter = '/';
212222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mSyncKey = "sync-key";
212322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mSyncLookback = 2;
2124f5418f1f93b02e7fab9f15eb201800b65510998eMarc Blank        box.mSyncInterval = Account.CHECK_INTERVAL_NEVER;
212522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mSyncTime = 3;
212622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mFlagVisible = true;
212722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mFlags = 5;
212822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.mVisibleLimit = 6;
212922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        box.save(c);
213022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        return box;
213122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    }
213222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
213322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    /**
213422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy     * Asserts equality between two mailboxes. We define this as we don't have implementations
213522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy     * for Mailbox#equals().
213622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy     */
213722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    private void assertEquals(Mailbox expected, Mailbox actual) {
213822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        if (expected == null && actual == null) return;
213922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertTrue(expected != null && actual != null);
214022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEqualsExceptServerId(expected, actual, expected.mServerId);
214122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    }
214222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
214322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    /**
214422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy     * Asserts equality between the two mailboxes EXCEPT for the server id. The given server
214522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy     * ID is the expected value.
214622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy     */
214722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    private void assertEqualsExceptServerId(Mailbox expected, Mailbox actual, String serverId) {
214822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        if (expected == null && actual == null) return;
214922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
215022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertTrue(expected != null && actual != null);
215122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(expected.mDisplayName, actual.mDisplayName);
215222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(serverId, actual.mServerId);
215322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(expected.mParentKey, actual.mParentKey);
215422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(expected.mAccountKey, actual.mAccountKey);
215522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    }
215622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
215722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    /** Verifies updating the DB from v17 to v18 works as expected */
215822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    public void testUpgradeFromVersion17ToVersion18() {
215922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        final Context c = mMockContext;
216022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Create accounts
21616e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Account a1 = createAccount(c, "exchange",
216222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy                ProviderTestUtils.setupHostAuth("eas", "exchange.host.com", true, c),
216322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy                null);
216422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Account a2 = createAccount(c, "imap",
216522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy                ProviderTestUtils.setupHostAuth("imap", "imap.host.com", true, c),
216622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy                ProviderTestUtils.setupHostAuth("smtp", "smtp.host.com", true, c));
216722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Account a3 = createAccount(c, "pop3",
216822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy                ProviderTestUtils.setupHostAuth("pop3", "imap.host.com", true, c),
216922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy                ProviderTestUtils.setupHostAuth("smtp", "smtp.host.com", true, c));
217022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
217122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Create mailboxes; some w/ valid parent IDs, others without
217222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b11 = createMailbox(c, "box1", "12", 0L, a1.mId);
217322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b12 = createMailbox(c, "box2", "67", -1L, a1.mId);
217422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b13 = createMailbox(c, "box3", "18", b12.mId, a1.mId);
217522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
217622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b21 = createMailbox(c, "box4", null, 0L, a2.mId);
217722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b22 = createMailbox(c, "box4/foo/bar", "will-be-replaced", 0L, a2.mId);
217822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b23 = createMailbox(c, "box5", null, -1L, a2.mId);
217922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b24 = createMailbox(c, "box6", "box5/box6", b23.mId, a2.mId);
218022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
218122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b31 = createMailbox(c, "box7", "12", 0L, a3.mId);
218222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b32 = createMailbox(c, "box8/foo/bar", "will-be-replaced", 0L, a3.mId);
218322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b33 = createMailbox(c, "box9", "box9", -1L, a3.mId);
218422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox b34 = createMailbox(c, "boxA", "box9/boxA", b33.mId, a3.mId);
218522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
218622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Sanity check the mailboxes that were just added
218722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        Mailbox testMailbox;
218822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b11.mId);
218922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b11, testMailbox);
219022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b12.mId);
219122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b12, testMailbox);
219222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b13.mId);
219322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b13, testMailbox);
219422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b21.mId);
219522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEqualsExceptServerId(b21, testMailbox, null);
219622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b22.mId);
219722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEqualsExceptServerId(b22, testMailbox, "will-be-replaced");
219822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b23.mId);
219922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b23, testMailbox);
220022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b24.mId);
220122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b24, testMailbox);
220222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b31.mId);
220322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEqualsExceptServerId(b31, testMailbox, "12");
220422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b32.mId);
220522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEqualsExceptServerId(b32, testMailbox, "will-be-replaced");
220622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b33.mId);
220722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b33, testMailbox);
220822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b34.mId);
220922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b34, testMailbox);
221022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
221122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        SQLiteDatabase db = getProvider().getDatabase(mMockContext);
221222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        EmailProvider.upgradeFromVersion17ToVersion18(db);
221322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
221422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Verify that only IMAP/POP3 mailboxes w/ a parent key of '0' are changed
221522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // Exchange mailboxes; none should be changed
221622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b11.mId);
221722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b11, testMailbox);
221822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b12.mId);
221922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b12, testMailbox);
222022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b13.mId);
222122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b13, testMailbox);
222222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
222322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // IMAP mailboxes; only mailboxes w/ a parent id of '0' are changed
222422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b21.mId);
222522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEqualsExceptServerId(b21, testMailbox, "box4");
222622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b22.mId);
222722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEqualsExceptServerId(b22, testMailbox, "box4/foo/bar");
222822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b23.mId);
222922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b23, testMailbox);
223022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b24.mId);
223122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b24, testMailbox);
223222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy
223322208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        // POP3 mailboxes; only mailboxes w/ a parent id of '0' are changed
223422208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b31.mId);
223522208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEqualsExceptServerId(b31, testMailbox, "box7");
223622208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b32.mId);
223722208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEqualsExceptServerId(b32, testMailbox, "box8/foo/bar");
223822208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b33.mId);
223922208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b33, testMailbox);
224022208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        testMailbox = Mailbox.restoreMailboxWithId(c, b34.mId);
224122208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy        assertEquals(b34, testMailbox);
224222208771b7b39c5d131372ba6bc45ab23cc22232Todd Kennedy    }
22434c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki
22444c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki    public void testBuildMessageListSelection() {
22454c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        final Context c = mMockContext;
22464c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki
22474c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        assertEquals(Message.ALL_INBOX_SELECTION, Message.buildMessageListSelection(c,
22484c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki                     Mailbox.QUERY_ALL_INBOXES));
22494c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki
22504c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        assertEquals(Message.ALL_DRAFT_SELECTION, Message.buildMessageListSelection(c,
22514c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki                Mailbox.QUERY_ALL_DRAFTS));
22524c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki
22534c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        assertEquals(Message.ALL_OUTBOX_SELECTION, Message.buildMessageListSelection(c,
22544c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki                Mailbox.QUERY_ALL_OUTBOX));
22554c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki
22564c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        assertEquals(Message.ALL_UNREAD_SELECTION, Message.buildMessageListSelection(c,
22574c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki                Mailbox.QUERY_ALL_UNREAD));
22584c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki
22594c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        assertEquals(Message.ALL_FAVORITE_SELECTION, Message.buildMessageListSelection(c,
22604c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki                Mailbox.QUERY_ALL_FAVORITES));
22614c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki
22624c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        final Account account = ProviderTestUtils.setupAccount("1", true, mMockContext);
22634c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        final Mailbox in = ProviderTestUtils.setupMailbox("i", account.mId, true, c,
22644c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki                Mailbox.TYPE_INBOX);
22654c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        final Mailbox out = ProviderTestUtils.setupMailbox("o", account.mId, true, c,
22664c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki                Mailbox.TYPE_OUTBOX);
22674c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki
22684c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        assertEquals(Message.MAILBOX_KEY + "=" + in.mId + " AND " + Message.FLAG_LOADED_SELECTION,
22694c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki                Message.buildMessageListSelection(c, in.mId));
22704c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki
22714c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        // No LOADED check for outboxes.
22724c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki        assertEquals(Message.MAILBOX_KEY + "=" + out.mId,
22734c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki                Message.buildMessageListSelection(c, out.mId));
22744c4e4c3515c3e3300e03f90e02a0c520dc2dff32Makoto Onuki    }
2275f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank
2276f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    /**
2277f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     * Determine whether a list of AccountManager accounts includes a given EmailProvider account
2278f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     * @param amAccountList a list of AccountManager accounts
2279f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     * @param account an EmailProvider account
2280f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     * @param context the caller's context (our test provider's context)
2281f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     * @return whether or not the EmailProvider account is represented in AccountManager
2282f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     */
2283f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    private boolean amAccountListHasAccount(android.accounts.Account[] amAccountList,
2284f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            Account account, Context context) {
2285f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        HostAuth hostAuth = HostAuth.restoreHostAuthWithId(context, account.mHostAuthKeyRecv);
2286f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        if (hostAuth == null) return false;
2287f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        String login = hostAuth.mLogin;
2288f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        for (android.accounts.Account amAccount: amAccountList) {
2289f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            if (amAccount.name.equals(login)) {
2290f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank                return true;
2291f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            }
2292f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        }
2293f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        return false;
2294f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    }
2295f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank
22966e418aa41a17136be0dddb816d843428a0a1e722Marc Blank    public void testAutoCacheNewContent() {
22976e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Account account = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
22986e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        // add hostauth data, which should be saved the first time
22996e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        account.mHostAuthRecv = ProviderTestUtils.setupHostAuth("account-hostauth-recv", -1, false,
23006e418aa41a17136be0dddb816d843428a0a1e722Marc Blank                mMockContext);
23016e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        account.mHostAuthSend = ProviderTestUtils.setupHostAuth("account-hostauth-send", -1, false,
23026e418aa41a17136be0dddb816d843428a0a1e722Marc Blank                mMockContext);
23036e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        account.save(mMockContext);
23046e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Account.CONTENT_URI, account.mId));
23056e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, account.mHostAuthRecv.mId));
23066e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, account.mHostAuthSend.mId));
23076e418aa41a17136be0dddb816d843428a0a1e722Marc Blank    }
23086e418aa41a17136be0dddb816d843428a0a1e722Marc Blank
23096e418aa41a17136be0dddb816d843428a0a1e722Marc Blank    /** Creates a mailbox; redefine as we need version 17 mailbox values */
23106e418aa41a17136be0dddb816d843428a0a1e722Marc Blank    private Mailbox createTypeMailbox(Context c, long accountId, int type) {
23116e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Mailbox box = new Mailbox();
23126e418aa41a17136be0dddb816d843428a0a1e722Marc Blank
23136e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        box.mDisplayName = "foo";
23146e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        box.mServerId = "1:1";
23156e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        box.mParentKey = 0;
23166e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        box.mAccountKey = accountId;
23176e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        // Don't care about the fields below ... set them for giggles
23186e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        box.mType = type;
23196e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        box.save(c);
23206e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        return box;
23216e418aa41a17136be0dddb816d843428a0a1e722Marc Blank    }
23226e418aa41a17136be0dddb816d843428a0a1e722Marc Blank
23236e418aa41a17136be0dddb816d843428a0a1e722Marc Blank    public void testAutoCacheInvalidate() {
23246e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        // Create 3 accounts with hostauth and 3 mailboxes each (2 of which are pre-cached)
23256e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Account a = ProviderTestUtils.setupAccount("account1", false, mMockContext);
23266e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        a.mHostAuthRecv = ProviderTestUtils.setupHostAuth("account-recv", -1, false,
23276e418aa41a17136be0dddb816d843428a0a1e722Marc Blank                mMockContext);
23286e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        a.mHostAuthSend = ProviderTestUtils.setupHostAuth("account-send", -1, false,
23296e418aa41a17136be0dddb816d843428a0a1e722Marc Blank                mMockContext);
23306e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        a.save(mMockContext);
23316e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Mailbox a1 = createTypeMailbox(mMockContext, a.mId, Mailbox.TYPE_INBOX);
23326e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Mailbox a2 = createTypeMailbox(mMockContext, a.mId, Mailbox.TYPE_MAIL);
23336e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Mailbox a3 = createTypeMailbox(mMockContext, a.mId, Mailbox.TYPE_DRAFTS);
23346e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Account b = ProviderTestUtils.setupAccount("account2", false, mMockContext);
23356e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        b.mHostAuthRecv = ProviderTestUtils.setupHostAuth("account-recv", -1, false,
23366e418aa41a17136be0dddb816d843428a0a1e722Marc Blank                mMockContext);
23376e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        b.mHostAuthSend = ProviderTestUtils.setupHostAuth("accoun-send", -1, false,
23386e418aa41a17136be0dddb816d843428a0a1e722Marc Blank                mMockContext);
23396e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        b.save(mMockContext);
23406e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Mailbox b1 = createTypeMailbox(mMockContext, b.mId, Mailbox.TYPE_OUTBOX);
23416e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Mailbox b2 = createTypeMailbox(mMockContext, b.mId, Mailbox.TYPE_MAIL);
23426e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Mailbox b3 = createTypeMailbox(mMockContext, b.mId, Mailbox.TYPE_SENT);
23436e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Account c = ProviderTestUtils.setupAccount("account3", false, mMockContext);
23446e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        c.mHostAuthRecv = ProviderTestUtils.setupHostAuth("account-recv", -1, false,
23456e418aa41a17136be0dddb816d843428a0a1e722Marc Blank                mMockContext);
23466e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        c.mHostAuthSend = ProviderTestUtils.setupHostAuth("account-send", -1, false,
23476e418aa41a17136be0dddb816d843428a0a1e722Marc Blank                mMockContext);
23486e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        c.save(mMockContext);
23496e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Mailbox c1 = createTypeMailbox(mMockContext, c.mId, Mailbox.TYPE_SEARCH);
23506e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Mailbox c2 = createTypeMailbox(mMockContext, c.mId, Mailbox.TYPE_MAIL);
23516e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        Mailbox c3 = createTypeMailbox(mMockContext, c.mId, Mailbox.TYPE_TRASH);
23526e418aa41a17136be0dddb816d843428a0a1e722Marc Blank
23536e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        // Confirm expected cache state
23546e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Account.CONTENT_URI, a.mId));
23556e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, a.mHostAuthRecv.mId));
23566e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, a.mHostAuthSend.mId));
23576e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Account.CONTENT_URI, b.mId));
23586e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, b.mHostAuthRecv.mId));
23596e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, b.mHostAuthSend.mId));
23606e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Account.CONTENT_URI, c.mId));
23616e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, c.mHostAuthRecv.mId));
23626e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, c.mHostAuthSend.mId));
23636e418aa41a17136be0dddb816d843428a0a1e722Marc Blank
23646e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Mailbox.CONTENT_URI, a1.mId));
23656e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(Mailbox.CONTENT_URI, a2.mId));
23666e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Mailbox.CONTENT_URI, a3.mId));
23676e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Mailbox.CONTENT_URI, b1.mId));
23686e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(Mailbox.CONTENT_URI, b2.mId));
23696e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Mailbox.CONTENT_URI, b3.mId));
23706e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Mailbox.CONTENT_URI, c1.mId));
23716e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(Mailbox.CONTENT_URI, c2.mId));
23726e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Mailbox.CONTENT_URI, c3.mId));
23736e418aa41a17136be0dddb816d843428a0a1e722Marc Blank
23746e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        // Delete account b
23756e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        EmailContent.delete(mMockContext, Account.CONTENT_URI, b.mId);
23766e418aa41a17136be0dddb816d843428a0a1e722Marc Blank
23776e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        // Confirm cache state
23786e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Account.CONTENT_URI, a.mId));
23796e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, a.mHostAuthRecv.mId));
23806e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, a.mHostAuthSend.mId));
23816e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(Account.CONTENT_URI, b.mId));
23826e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(HostAuth.CONTENT_URI, b.mHostAuthRecv.mId));
23836e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(HostAuth.CONTENT_URI, b.mHostAuthSend.mId));
23846e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Account.CONTENT_URI, c.mId));
23856e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, c.mHostAuthRecv.mId));
23866e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(HostAuth.CONTENT_URI, c.mHostAuthSend.mId));
23876e418aa41a17136be0dddb816d843428a0a1e722Marc Blank
23886e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Mailbox.CONTENT_URI, a1.mId));
23896e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(Mailbox.CONTENT_URI, a2.mId));
23906e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Mailbox.CONTENT_URI, a3.mId));
23916e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(Mailbox.CONTENT_URI, b1.mId));
23926e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(Mailbox.CONTENT_URI, b2.mId));
23936e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(Mailbox.CONTENT_URI, b3.mId));
23946e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Mailbox.CONTENT_URI, c1.mId));
23956e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertFalse(mProvider.isCached(Mailbox.CONTENT_URI, c2.mId));
23966e418aa41a17136be0dddb816d843428a0a1e722Marc Blank        assertTrue(mProvider.isCached(Mailbox.CONTENT_URI, c3.mId));
23976e418aa41a17136be0dddb816d843428a0a1e722Marc Blank    }
23986e418aa41a17136be0dddb816d843428a0a1e722Marc Blank
2399f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    /**
2400f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     * Remove a single pop/imap account from the AccountManager
2401f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     * @param accountManager our AccountManager
2402f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     * @param name the name of the test account to remove
2403f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     */
2404f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    private void removeAccountManagerAccount(AccountManager accountManager, String name) {
2405f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        try {
2406f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            accountManager.removeAccount(
2407f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank                    new android.accounts.Account(name, AccountManagerTypes.TYPE_POP_IMAP),
2408f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank                    null, null).getResult();
2409f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        } catch (OperationCanceledException e) {
2410f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        } catch (AuthenticatorException e) {
2411f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        } catch (IOException e) {
2412f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        }
2413f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    }
2414f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank
2415f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    /**
2416f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     * Remove all test accounts from the AccountManager
2417f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     * @param accountManager the AccountManager
2418f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank     */
2419f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    private void cleanupTestAccountManagerAccounts(AccountManager accountManager) {
2420f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        android.accounts.Account[] amAccountList =
2421f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            accountManager.getAccountsByType(AccountManagerTypes.TYPE_POP_IMAP);
2422f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        for (android.accounts.Account account: amAccountList) {
2423f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            if (account.name.startsWith(AccountReconciler.ACCOUNT_MANAGER_ACCOUNT_TEST_PREFIX)) {
2424f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank                removeAccountManagerAccount(accountManager, account.name);
2425f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            }
2426f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        }
2427f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    }
2428f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank
2429f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    /** Verifies updating the DB from v21 to v22 works as expected */
2430f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    public void testUpgradeFromVersion21ToVersion22() {
2431f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        String imapTestLogin =
2432f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            AccountReconciler.ACCOUNT_MANAGER_ACCOUNT_TEST_PREFIX + "imap.host.com";
2433f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        String pop3TestLogin =
2434f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            AccountReconciler.ACCOUNT_MANAGER_ACCOUNT_TEST_PREFIX + "pop3.host.com";
2435f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        AccountManager accountManager = AccountManager.get(mContext);
2436f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank
2437f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        // Create provider accounts (one of each type)
2438f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        Account a1 = createAccount(mMockContext, "exchange",
2439f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank                ProviderTestUtils.setupHostAuth("eas", "exchange.host.com", true, mMockContext),
2440f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank                null);
2441f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        HostAuth h2 =
2442f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            ProviderTestUtils.setupHostAuth("imap", "imap.host.com", false, mMockContext);
2443f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        h2.mLogin = imapTestLogin;
2444f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        h2.save(mMockContext);
2445f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        Account a2 = createAccount(mMockContext, "imap", h2,
2446f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank                ProviderTestUtils.setupHostAuth("smtp", "smtp.host.com", true, mMockContext));
2447f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        HostAuth h3 =
2448f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            ProviderTestUtils.setupHostAuth("pop3", "pop3.host.com", false, mMockContext);
2449f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        h3.mLogin = pop3TestLogin;
2450f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        h3.save(mMockContext);
2451f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        Account a3 = createAccount(mMockContext, "pop3", h3,
2452f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank                ProviderTestUtils.setupHostAuth("smtp", "smtp.host.com", true, mMockContext));
2453f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank
2454f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        // Get the current list of AccountManager accounts (we have to use the real context here),
2455f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        // whereas we use the mock context for EmailProvider (this is because the mock context
2456f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        // doesn't implement AccountManager hooks)
2457f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        android.accounts.Account[] amAccountList =
2458f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            accountManager.getAccountsByType(AccountManagerTypes.TYPE_POP_IMAP);
2459f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        // There shouldn't be AccountManager accounts for these
2460f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        assertFalse(amAccountListHasAccount(amAccountList, a1, mMockContext));
2461f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        assertFalse(amAccountListHasAccount(amAccountList, a2, mMockContext));
2462f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        assertFalse(amAccountListHasAccount(amAccountList, a3, mMockContext));
2463f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank
2464f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        amAccountList = null;
2465f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        try {
2466f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            // Upgrade the database
2467f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            SQLiteDatabase db = getProvider().getDatabase(mMockContext);
2468f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            EmailProvider.upgradeFromVersion21ToVersion22(db, getContext());
2469f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank
2470f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            // The pop3 and imap account should now be in account manager
2471f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            amAccountList = accountManager.getAccountsByType(AccountManagerTypes.TYPE_POP_IMAP);
2472f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            assertFalse(amAccountListHasAccount(amAccountList, a1, mMockContext));
2473f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            assertTrue(amAccountListHasAccount(amAccountList, a2, mMockContext));
2474f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            assertTrue(amAccountListHasAccount(amAccountList, a3, mMockContext));
2475f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        } finally {
2476f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank            cleanupTestAccountManagerAccounts(accountManager);
2477f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank        }
2478f3ff0ba91076ef1fb087fc30fe65d9504011c2b3Marc Blank    }
24792bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank
24802bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank    public void testCleanupOrphans() {
24812bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        EmailProvider ep = getProvider();
24822bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        SQLiteDatabase db = ep.getDatabase(mMockContext);
24832bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank
24842bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Account a = ProviderTestUtils.setupAccount("account1", true, mMockContext);
24852bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        // Mailbox a1 and a3 won't have a valid account
24862bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Mailbox a1 = createTypeMailbox(mMockContext, -1, Mailbox.TYPE_INBOX);
24872bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Mailbox a2 = createTypeMailbox(mMockContext, a.mId, Mailbox.TYPE_MAIL);
24882bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Mailbox a3 = createTypeMailbox(mMockContext, -1, Mailbox.TYPE_DRAFTS);
24892bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Mailbox a4 = createTypeMailbox(mMockContext, a.mId, Mailbox.TYPE_SENT);
24902bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Mailbox a5 = createTypeMailbox(mMockContext, a.mId, Mailbox.TYPE_TRASH);
24912bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        // Mailbox ax isn't even saved; use an obviously invalid id
24922bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Mailbox ax = new Mailbox();
24932bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        ax.mId = 69105;
24942bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank
24952bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        // Message mt2 is an orphan, as is mt4
24962bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Message m1 = createMessage(mMockContext, a1, true, false, Message.FLAG_LOADED_COMPLETE);
24972bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Message m2 = createMessage(mMockContext, a2, true, false, Message.FLAG_LOADED_COMPLETE);
24982bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Message m3 = createMessage(mMockContext, a3, true, false, Message.FLAG_LOADED_COMPLETE);
24992bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Message m4 = createMessage(mMockContext, a4, true, false, Message.FLAG_LOADED_COMPLETE);
25002bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Message m5 = createMessage(mMockContext, a5, true, false, Message.FLAG_LOADED_COMPLETE);
25012bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Message mx = createMessage(mMockContext, ax, true, false, Message.FLAG_LOADED_COMPLETE);
25022bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank
25032bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        // Two orphan policies
25042bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Policy p1 = new Policy();
25052bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        p1.save(mMockContext);
25062bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Policy p2 = new Policy();
25072bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        p2.save(mMockContext);
25082bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Policy p3 = new Policy();
25092bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        Policy.setAccountPolicy(mMockContext, a.mId, p3, "0");
25102bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank
25112bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        // We don't want anything cached or the tests below won't work.  Note that
25122bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        // deleteUnlinked is only called by EmailProvider when the caches are empty
25132bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        ContentCache.invalidateAllCaches();
25142bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        // Delete orphaned mailboxes/messages/policies
25152bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        ep.deleteUnlinked(db, Mailbox.TABLE_NAME, MailboxColumns.ACCOUNT_KEY, AccountColumns.ID,
25162bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank                Account.TABLE_NAME);
25172bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        ep.deleteUnlinked(db, Message.TABLE_NAME, MessageColumns.ACCOUNT_KEY, AccountColumns.ID,
25182bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank                Account.TABLE_NAME);
25192bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        ep.deleteUnlinked(db, Policy.TABLE_NAME, PolicyColumns.ID, AccountColumns.POLICY_KEY,
25202bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank                Account.TABLE_NAME);
25212bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank
25222bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        // Make sure the orphaned mailboxes are gone
25232bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNull(Mailbox.restoreMailboxWithId(mMockContext, a1.mId));
25242bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNotNull(Mailbox.restoreMailboxWithId(mMockContext, a2.mId));
25252bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNull(Mailbox.restoreMailboxWithId(mMockContext, a3.mId));
25262bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNotNull(Mailbox.restoreMailboxWithId(mMockContext, a4.mId));
25272bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNotNull(Mailbox.restoreMailboxWithId(mMockContext, a5.mId));
25282bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNull(Mailbox.restoreMailboxWithId(mMockContext, ax.mId));
25292bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank
25302bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        // Make sure orphaned messages are gone
25312bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNull(Message.restoreMessageWithId(mMockContext, m1.mId));
25322bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNotNull(Message.restoreMessageWithId(mMockContext, m2.mId));
25332bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNull(Message.restoreMessageWithId(mMockContext, m3.mId));
25342bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNotNull(Message.restoreMessageWithId(mMockContext, m4.mId));
25352bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNotNull(Message.restoreMessageWithId(mMockContext, m5.mId));
25362bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNull(Message.restoreMessageWithId(mMockContext, mx.mId));
25372bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank
25382bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        // Make sure orphaned policies are gone
25392bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNull(Policy.restorePolicyWithId(mMockContext, p1.mId));
25402bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNull(Policy.restorePolicyWithId(mMockContext, p2.mId));
25412bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        a = Account.restoreAccountWithId(mMockContext, a.mId);
25422bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank        assertNotNull(Policy.restorePolicyWithId(mMockContext, a.mPolicyKey));
25432bdf7ee0f0f4a2b11b5f7c0f8b193080600fefd8Marc Blank    }
25447143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler}
2545