ProviderTests.java revision 76f614720db6a282c3e890969a600585122cdcc5
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
19a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent;
20a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.Account;
21a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.AccountColumns;
22a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.Attachment;
23a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.AttachmentColumns;
24a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.Body;
25a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.BodyColumns;
26a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.HostAuth;
27a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.Mailbox;
28a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.MailboxColumns;
29a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.Message;
30a7bc0319a75184ad706bb35c049af107ac3688e6Marc Blankimport com.android.emailcommon.provider.EmailContent.MessageColumns;
3176f614720db6a282c3e890969a600585122cdcc5Marc Blankimport com.android.emailcommon.utility.TextUtilities;
3231d9acbf0623872f9d4a2b3210b5970854b654c7Marc Blankimport com.android.emailcommon.utility.Utility;
337143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
34ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadlerimport android.content.ContentResolver;
357143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport android.content.ContentUris;
36ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadlerimport android.content.ContentValues;
377143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport android.content.Context;
387143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport android.database.Cursor;
39574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onukiimport android.database.sqlite.SQLiteDatabase;
407143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport android.net.Uri;
414a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadlerimport android.os.Bundle;
42976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blankimport android.os.Environment;
434a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadlerimport android.os.Parcel;
44e37881aac562c066e6e666349749e40b7c116a21Makoto Onukiimport android.test.MoreAsserts;
457143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport android.test.ProviderTestCase2;
467143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
47758a532fce2f672673d38b2daa5f67eb757b118bMarc Blankimport java.io.File;
48758a532fce2f672673d38b2daa5f67eb757b118bMarc Blankimport java.io.IOException;
49758a532fce2f672673d38b2daa5f67eb757b118bMarc Blankimport java.util.ArrayList;
50758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
517143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler/**
527143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * Tests of the Email provider.
53758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank *
547143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * You can run this entire test case with:
557143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler *   runtest -c com.android.email.provider.ProviderTests email
56261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki *
57261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * TODO: Add tests for cursor notification mechanism.  (setNotificationUri and notifyChange)
58261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * We can't test the entire notification mechanism with a mock content resolver, because which URI
59261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * to notify when notifyChange() is called is in the actual content resolver.
60261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * Implementing the same mechanism in a mock one is pointless.  Instead what we could do is check
61261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * what notification URI each cursor has, and with which URI is notified when
62261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * inserting/updating/deleting.  (The former require a new method from AbstractCursor)
637143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler */
647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerpublic class ProviderTests extends ProviderTestCase2<EmailProvider> {
65758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
669d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    private EmailProvider mProvider;
679d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    private Context mMockContext;
687143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
697143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public ProviderTests() {
7031d9acbf0623872f9d4a2b3210b5970854b654c7Marc Blank        super(EmailProvider.class, EmailContent.AUTHORITY);
717143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
72758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
737143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    @Override
747143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void setUp() throws Exception {
757143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        super.setUp();
767143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext = getMockContext();
779d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        mProvider = getProvider();
78349055aad47184b72cd86de1f37ac1b7557d2e70Marc Blank        // Invalidate all caches, since we reset the database for each test
79349055aad47184b72cd86de1f37ac1b7557d2e70Marc Blank        ContentCache.invalidateAllCachesForTest();
807143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
817143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
827143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    @Override
837143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void tearDown() throws Exception {
847143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        super.tearDown();
857143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
867143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
877143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
880d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler     * TODO: Database upgrade tests
890d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler     */
900d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler
910d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler    /**
927143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test simple account save/retrieve
937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testAccountSave() {
9528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-save", true, mMockContext);
967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
97758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Account account2 = EmailContent.Account.restoreAccountWithId(mMockContext, account1Id);
99758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
10028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertAccountEqual("testAccountSave", account1, account2);
1017143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
10241f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
1034a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler    /**
104da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler     * Test simple account save/retrieve with predefined hostauth records
105da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler     */
106da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler    public void testAccountSaveHostAuth() {
107da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
108da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        // add hostauth data, which should be saved the first time
109da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        account1.mHostAuthRecv = ProviderTestUtils.setupHostAuth("account-hostauth-recv", -1, false,
110da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                mMockContext);
111da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        account1.mHostAuthSend = ProviderTestUtils.setupHostAuth("account-hostauth-send", -1, false,
112da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                mMockContext);
113da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        account1.save(mMockContext);
114da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        long account1Id = account1.mId;
115da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler
116da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        // Confirm account reads back correctly
117da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        Account account1get = EmailContent.Account.restoreAccountWithId(mMockContext, account1Id);
118da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        ProviderTestUtils.assertAccountEqual("testAccountSave", account1, account1get);
119da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler
120da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        // Confirm hostauth fields can be accessed & read back correctly
121da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        HostAuth hostAuth1get = EmailContent.HostAuth.restoreHostAuthWithId(mMockContext,
122da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1get.mHostAuthKeyRecv);
123da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        ProviderTestUtils.assertHostAuthEqual("testAccountSaveHostAuth-recv",
124da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1.mHostAuthRecv, hostAuth1get);
125da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        HostAuth hostAuth2get = EmailContent.HostAuth.restoreHostAuthWithId(mMockContext,
126da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1get.mHostAuthKeySend);
127da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        ProviderTestUtils.assertHostAuthEqual("testAccountSaveHostAuth-send",
128da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1.mHostAuthSend, hostAuth2get);
129da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler    }
130da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler
131040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy    public void testAccountGetHostAuthSend() {
132040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        Account account = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
133040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthSend = ProviderTestUtils.setupHostAuth("account-hostauth-send", -1, false,
134040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy                mMockContext);
135040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.save(mMockContext);
136040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        HostAuth authGet;
137040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        HostAuth authTest;
138040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
139040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authTest = account.mHostAuthSend;
140040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authTest);
141040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertTrue(account.mHostAuthKeySend != 0);
142040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
143040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // HostAuth is not changed
144040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthSend(mMockContext);
145040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertTrue(authGet == authTest); // return the same object
146040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
147040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // New HostAuth; based upon mHostAuthKeyRecv
148040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authTest = EmailContent.HostAuth.restoreHostAuthWithId(mMockContext,
149040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy                account.mHostAuthKeySend);
150040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthSend = null;
151040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthSend(mMockContext);
152040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authGet);
153040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(account.mHostAuthSend);
154040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        ProviderTestUtils.assertHostAuthEqual("testAccountGetHostAuthSend-1", authTest, authGet);
155040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
156040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // New HostAuth; completely empty
157040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authTest = new EmailContent.HostAuth();
158040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthSend = null;
159040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthKeySend = 0;
160040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthSend(mMockContext);
161040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authGet);
162040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(account.mHostAuthSend);
163040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        ProviderTestUtils.assertHostAuthEqual("testAccountGetHostAuthSendv-2", authTest, authGet);
164040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy    }
165040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
166040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy    public void testAccountGetHostAuthRecv() {
167040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        Account account = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
168040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthRecv = ProviderTestUtils.setupHostAuth("account-hostauth-recv", -1, false,
169040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy                mMockContext);
170040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.save(mMockContext);
171040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        HostAuth authGet;
172040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        HostAuth authTest;
173040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
174040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authTest = account.mHostAuthRecv;
175040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authTest);
176040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertTrue(account.mHostAuthKeyRecv != 0);
177040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
178040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // HostAuth is not changed
179040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthRecv(mMockContext);
180040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertTrue(authGet == authTest); // return the same object
181040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
182040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // New HostAuth; based upon mHostAuthKeyRecv
183040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authTest = EmailContent.HostAuth.restoreHostAuthWithId(mMockContext,
184040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy                account.mHostAuthKeyRecv);
185040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthRecv = null;
186040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthRecv(mMockContext);
187040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authGet);
188040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(account.mHostAuthRecv);
189040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        ProviderTestUtils.assertHostAuthEqual("testAccountGetHostAuthRecv-1", authTest, authGet);
190040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
191040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        // New HostAuth; completely empty
192040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authTest = new EmailContent.HostAuth();
193040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthRecv = null;
194040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        account.mHostAuthKeyRecv = 0;
195040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        authGet = account.getOrCreateHostAuthRecv(mMockContext);
196040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(authGet);
197040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        assertNotNull(account.mHostAuthRecv);
198040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy        ProviderTestUtils.assertHostAuthEqual("testAccountGetHostAuthRecv-2", authTest, authGet);
199040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy    }
200040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy
201da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler    /**
202040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy     * Simple test of account parceling.  The rather torturous path is to ensure that the
2034a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler     * account is really flattened all the way down to a parcel and back.
2044a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler     */
2054a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler    public void testAccountParcel() {
2064a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Account account1 = ProviderTestUtils.setupAccount("parcel", false, mMockContext);
2074a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Bundle b = new Bundle();
2084a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        b.putParcelable("account", account1);
2094a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Parcel p = Parcel.obtain();
2104a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        b.writeToParcel(p, 0);
2114a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        p.setDataPosition(0);       // rewind it for reading
2124a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Bundle b2 = new Bundle(Account.class.getClassLoader());
2134a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        b2.readFromParcel(p);
2144a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Account account2 = (Account) b2.getParcelable("account");
2154a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        p.recycle();
2164a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler
2174a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        ProviderTestUtils.assertAccountEqual("testAccountParcel", account1, account2);
2184a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler    }
2194a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler
220e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    /**
221e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki     * Test for {@link Account#getShortcutSafeUri()} and
222040ddf60cfef4aaecf4bfe1f897fce3248d777a4Todd Kennedy     * {@link Account#getAccountIdFromShortcutSafeUri}.
223e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki     */
224e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    public void testAccountShortcutSafeUri() {
225e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Account account1 = ProviderTestUtils.setupAccount("account-1", true, mMockContext);
226e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Account account2 = ProviderTestUtils.setupAccount("account-2", true, mMockContext);
227e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final long account1Id = account1.mId;
228e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final long account2Id = account2.mId;
229e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
230e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Uri uri1 = account1.getShortcutSafeUri();
231e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Uri uri2 = account2.getShortcutSafeUri();
232e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
233e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        // Check the path part of the URIs.
234e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        MoreAsserts.assertEquals(new String[] {"account", account1.mCompatibilityUuid},
235e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                uri1.getPathSegments().toArray());
236e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        MoreAsserts.assertEquals(new String[] {"account", account2.mCompatibilityUuid},
237e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                uri2.getPathSegments().toArray());
238e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
239e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account1Id, Account.getAccountIdFromShortcutSafeUri(mMockContext, uri1));
240e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account2Id, Account.getAccountIdFromShortcutSafeUri(mMockContext, uri2));
241e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
242e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        // Test for the Eclair(2.0-2.1) style URI.
243e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account1Id, Account.getAccountIdFromShortcutSafeUri(mMockContext,
244e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                getEclairStyleShortcutUri(account1)));
245e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account2Id, Account.getAccountIdFromShortcutSafeUri(mMockContext,
246e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                getEclairStyleShortcutUri(account2)));
247e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    }
248e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
249e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    private static Uri getEclairStyleShortcutUri(Account account) {
250e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        // We used _id instead of UUID only on Eclair(2.0-2.1).
251e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        return Account.CONTENT_URI.buildUpon().appendEncodedPath("" + account.mId).build();
252e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    }
253e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
2548d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank    public void testGetProtocol() {
2558d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        Account account1 = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
2568d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // add hostauth data, with protocol
257fe68c0e7c2672e09076038b36ad24f095633d313Todd Kennedy        account1.mHostAuthRecv = ProviderTestUtils.setupHostAuth("eas", "account-hostauth-recv",
2588d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank                false, mMockContext);
2598d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // Note that getProtocol uses the receive host auth, so the protocol here shouldn't matter
2608d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // to the test result
261fe68c0e7c2672e09076038b36ad24f095633d313Todd Kennedy        account1.mHostAuthSend = ProviderTestUtils.setupHostAuth("foo", "account-hostauth-send",
2628d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank                false, mMockContext);
2638d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        account1.save(mMockContext);
26425144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        assertEquals("eas", Account.getProtocol(mMockContext, account1.mId));
26525144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        assertEquals("eas", account1.getProtocol(mMockContext));
2668d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        Account account2 = ProviderTestUtils.setupAccount("account-nohostauth", false,
2678d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank                mMockContext);
2688d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        account2.save(mMockContext);
2698d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // Make sure that we return null when there's no host auth
2708d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        assertNull(Account.getProtocol(mMockContext, account2.mId));
2718d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        assertNull(account2.getProtocol(mMockContext));
2728d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // And when there's no account
2738d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        assertNull(Account.getProtocol(mMockContext, 0));
2748d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank    }
2758d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank
276652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki    public void testAccountIsValidId() {
277652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        final Account account1 = ProviderTestUtils.setupAccount("account-1", true, mMockContext);
278652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        final Account account2 = ProviderTestUtils.setupAccount("account-2", true, mMockContext);
279652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki
280652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        assertTrue(Account.isValidId(mMockContext, account1.mId));
281652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        assertTrue(Account.isValidId(mMockContext, account2.mId));
282652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki
283652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        assertFalse(Account.isValidId(mMockContext, 1234567)); // Some random ID
284c133e6f1858e33fabaa6ffa173c1402bf9a98e31Makoto Onuki        assertFalse(Account.isValidId(mMockContext, -1));
285c133e6f1858e33fabaa6ffa173c1402bf9a98e31Makoto Onuki        assertFalse(Account.isValidId(mMockContext, -500));
286652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki    }
287652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki
28841f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    private final static String[] MAILBOX_UNREAD_COUNT_PROJECTION = new String [] {
28941f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        MailboxColumns.UNREAD_COUNT
29041f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    };
29141f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    private final static int MAILBOX_UNREAD_COUNT_COLMUN = 0;
29241f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
29341f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    /**
29441f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     * Get the value of the unread count in the mailbox of the account.
29541f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     * This can be different from the actual number of unread messages in that mailbox.
29641f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     */
29741f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    private int getUnreadCount(long mailboxId) {
29841f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        String text = null;
29941f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        Cursor c = null;
30041f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        try {
30141f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            c = mMockContext.getContentResolver().query(
30241f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    Mailbox.CONTENT_URI,
30341f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    MAILBOX_UNREAD_COUNT_PROJECTION,
30441f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    EmailContent.RECORD_ID + "=?",
30541f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    new String[] { String.valueOf(mailboxId) },
30641f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    null);
30741f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            c.moveToFirst();
30841f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            text = c.getString(MAILBOX_UNREAD_COUNT_COLMUN);
30941f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        } finally {
31041f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            c.close();
31141f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        }
31241f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        return Integer.valueOf(text);
31341f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    }
31441f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
3157143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
3167143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test simple mailbox save/retrieve
3177143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
3187143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testMailboxSave() {
31928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("mailbox-save", true, mMockContext);
3207143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
32128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true,
32228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
3237143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
324758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
3257143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Mailbox box2 = EmailContent.Mailbox.restoreMailboxWithId(mMockContext, box1Id);
326758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
32728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertMailboxEqual("testMailboxSave", box1, box2);
3287143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
329758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
3304119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    private static String[] expectedAttachmentNames =
331976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        new String[] {"attachment1.doc", "attachment2.xls", "attachment3"};
332976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    // The lengths need to be kept in ascending order
3334119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    private static long[] expectedAttachmentSizes = new long[] {31415L, 97701L, 151213L};
334976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank
335fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    /*
336fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * Returns null if the message has no body.
337fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     */
338fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    private Body loadBodyForMessageId(long messageId) {
339fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Cursor c = null;
340fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        try {
341fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            c = mMockContext.getContentResolver().query(
342fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    EmailContent.Body.CONTENT_URI,
343fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    EmailContent.Body.CONTENT_PROJECTION,
344fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    EmailContent.Body.MESSAGE_KEY + "=?",
345fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    new String[] {String.valueOf(messageId)},
346fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    null);
347fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            int numBodies = c.getCount();
348fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            assertTrue("at most one body", numBodies < 2);
349fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            return c.moveToFirst() ? EmailContent.getContent(c, Body.class) : null;
350fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        } finally {
351fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            c.close();
352fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        }
353fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    }
354fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
3557143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
3567143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test simple message save/retrieve
357758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank     *
3587143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: serverId vs. serverIntId
3597143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
3607143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testMessageSave() {
36128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-save", true, mMockContext);
3627143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
36328448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
3647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
3657143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
3667143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Test a simple message (saved with no body)
36728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
36828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
3697143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message1Id = message1.mId;
3707143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Message message1get = EmailContent.Message.restoreMessageWithId(mMockContext, message1Id);
37128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertMessageEqual("testMessageSave", message1, message1get);
3727143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
3737143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Test a message saved with a body
3747143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Note that it will read back w/o the text & html so we must extract those
37528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
37628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
3777143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message2Id = message2.mId;
3787143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String text2 = message2.mText;
3797143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String html2 = message2.mHtml;
380936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        String textReply2 = message2.mTextReply;
381936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        String htmlReply2 = message2.mHtmlReply;
3826c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long sourceKey2 = message2.mSourceKey;
3835fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        String introText2 = message2.mIntroText;
3847143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        message2.mText = null;
3857143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        message2.mHtml = null;
386936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        message2.mTextReply = null;
387936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        message2.mHtmlReply = null;
388e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        message2.mSourceKey = 0;
3895fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        message2.mIntroText = null;
3907143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Message message2get = EmailContent.Message.restoreMessageWithId(mMockContext, message2Id);
39128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertMessageEqual("testMessageSave", message2, message2get);
392758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
3937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Now see if there's a body saved with the right stuff
394fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Body body2 = loadBodyForMessageId(message2Id);
395fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertEquals("body text", text2, body2.mTextContent);
396fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertEquals("body html", html2, body2.mHtmlContent);
397936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals("reply text", textReply2, body2.mTextReply);
398936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals("reply html", htmlReply2, body2.mHtmlReply);
3996c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals("source key", sourceKey2, body2.mSourceKey);
4005fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        assertEquals("intro text", introText2, body2.mIntroText);
401976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank
4024119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Message with attachments and body
403976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        Message message3 = ProviderTestUtils.setupMessage("message3", account1Id, box1Id, true,
404976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                false, mMockContext);
405976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        ArrayList<Attachment> atts = new ArrayList<Attachment>();
406976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        for (int i = 0; i < 3; i++) {
4074119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
4084119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
4094119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    false, mMockContext));
410976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        }
411976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        message3.mAttachments = atts;
4129e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        message3.save(mMockContext);
413976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        long message3Id = message3.mId;
414976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank
415976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        // Now check the attachments; there should be three and they should match name and size
416fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Cursor c = null;
417976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        try {
418976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // Note that there is NO guarantee of the order of returned records in the general case,
419976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // so we specifically ask for ordering by size.  The expectedAttachmentSizes array must
420976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // be kept sorted by size (ascending) for this test to work properly
421976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            c = mMockContext.getContentResolver().query(
422976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.CONTENT_URI,
423976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.CONTENT_PROJECTION,
424976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.MESSAGE_KEY + "=?",
425976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    new String[] {
426976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                            String.valueOf(message3Id)
427976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    },
428976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.SIZE);
429976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            int numAtts = c.getCount();
430976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            assertEquals(3, numAtts);
431976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            int i = 0;
432976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            while (c.moveToNext()) {
4334119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                Attachment actual = EmailContent.getContent(c, Attachment.class);
4344119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                ProviderTestUtils.assertAttachmentEqual("save-message3", atts.get(i), actual);
4354119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                i++;
4364119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            }
4374119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        } finally {
4384119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.close();
4394119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        }
4404119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
4414119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Message with attachments but no body
4424119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Message message4 = ProviderTestUtils.setupMessage("message4", account1Id, box1Id, false,
4434119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                false, mMockContext);
4444119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        atts = new ArrayList<Attachment>();
4454119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        for (int i = 0; i < 3; i++) {
4464119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
4474119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
4484119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    false, mMockContext));
4494119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        }
4504119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        message4.mAttachments = atts;
4519e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        message4.save(mMockContext);
4524119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        long message4Id = message4.mId;
4534119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
4544119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Now check the attachments; there should be three and they should match name and size
4554119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        c = null;
45641f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
4574119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        try {
4584119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            // Note that there is NO guarantee of the order of returned records in the general case,
4594119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            // so we specifically ask for ordering by size.  The expectedAttachmentSizes array must
4604119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            // be kept sorted by size (ascending) for this test to work properly
4614119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c = mMockContext.getContentResolver().query(
4624119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.CONTENT_URI,
4634119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.CONTENT_PROJECTION,
4644119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.MESSAGE_KEY + "=?",
4654119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    new String[] {
4664119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                            String.valueOf(message4Id)
4674119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    },
4684119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.SIZE);
4694119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            int numAtts = c.getCount();
4704119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            assertEquals(3, numAtts);
4714119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            int i = 0;
4724119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            while (c.moveToNext()) {
4734119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                Attachment actual = EmailContent.getContent(c, Attachment.class);
4744119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                ProviderTestUtils.assertAttachmentEqual("save-message4", atts.get(i), actual);
475976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                i++;
476976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            }
477976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        } finally {
478976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            c.close();
4797143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        }
48044144d0301213536b02f2080237b63d8271b2d0bMihai Preda
48144144d0301213536b02f2080237b63d8271b2d0bMihai Preda        // test EmailContent.restoreAttachmentsWitdMessageId()
48244144d0301213536b02f2080237b63d8271b2d0bMihai Preda        Attachment[] attachments =
48344144d0301213536b02f2080237b63d8271b2d0bMihai Preda            Attachment.restoreAttachmentsWithMessageId(mMockContext, message4Id);
48444144d0301213536b02f2080237b63d8271b2d0bMihai Preda        int size = attachments.length;
48544144d0301213536b02f2080237b63d8271b2d0bMihai Preda        assertEquals(3, size);
48644144d0301213536b02f2080237b63d8271b2d0bMihai Preda        for (int i = 0; i < size; ++i) {
48744144d0301213536b02f2080237b63d8271b2d0bMihai Preda            ProviderTestUtils.assertAttachmentEqual("save-message4", atts.get(i), attachments[i]);
48844144d0301213536b02f2080237b63d8271b2d0bMihai Preda        }
4897143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
490758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
4917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
492e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank     * Test that saving a message creates the proper snippet for that message
493e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank     */
494e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank    public void testMessageSaveAddsSnippet() {
495e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Account account = ProviderTestUtils.setupAccount("message-snippet", true, mMockContext);
496e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Mailbox box = ProviderTestUtils.setupMailbox("box1", account.mId, true, mMockContext);
497e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank
498e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // Create a message without a body, unsaved
499e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Message message = ProviderTestUtils.setupMessage("message", account.mId, box.mId, false,
500e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank                false, mMockContext);
501e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mText = "This is some text";
502e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mHtml = "<html>This is some text</html>";
503e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.save(mMockContext);
504e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Message restoredMessage = Message.restoreMessageWithId(mMockContext, message.mId);
505e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // We should have the plain text as the snippet
50676f614720db6a282c3e890969a600585122cdcc5Marc Blank        assertEquals(restoredMessage.mSnippet,
50776f614720db6a282c3e890969a600585122cdcc5Marc Blank                TextUtilities.makeSnippetFromPlainText(message.mText));
508e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank
509e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // Start again
510e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message = ProviderTestUtils.setupMessage("message", account.mId, box.mId, false,
511e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank                false, mMockContext);
512e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mText = null;
513e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mHtml = "<html>This is some text</html>";
514e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.save(mMockContext);
515e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        restoredMessage = Message.restoreMessageWithId(mMockContext, message.mId);
516e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // We should have the plain text as the snippet
51776f614720db6a282c3e890969a600585122cdcc5Marc Blank        assertEquals(restoredMessage.mSnippet,
51876f614720db6a282c3e890969a600585122cdcc5Marc Blank                TextUtilities.makeSnippetFromHtmlText(message.mHtml));
519e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank    }
520e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank
521e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank    /**
5227143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: update account
5237143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
524758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5257143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5267143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: update mailbox
5277143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
528758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5297143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5307143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: update message
5317143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
532758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5337143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5347143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test delete account
5357143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: hostauth
5367143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
5377143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testAccountDelete() {
53828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-delete-1", true, mMockContext);
5397143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
54028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account2 = ProviderTestUtils.setupAccount("account-delete-2", true, mMockContext);
5417143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account2Id = account2.mId;
5427143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5437143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are two accounts
5447143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numBoxes = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
5457143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numBoxes);
5467143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5477143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete one of them
5487143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Account.CONTENT_URI, account1Id);
5497143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
5507143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5517143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there's only one account now
5527143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
5537143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numBoxes);
5547143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5557143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the other one
5567143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        uri = ContentUris.withAppendedId(Account.CONTENT_URI, account2Id);
5577143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
5587143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5597143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no accounts now
5607143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
5617143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numBoxes);
5627143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
563758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5659627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Test for Body.lookupBodyIdWithMessageId()
5669627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Verifies that:
5679627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * - for a message without body, -1 is returned.
5689627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * - for a mesage with body, the id matches the one from loadBodyForMessageId.
5699627d014e16235eadf981b9165807dc72a14a383Mihai Preda     */
5709627d014e16235eadf981b9165807dc72a14a383Mihai Preda    public void testLookupBodyIdWithMessageId() {
5719627d014e16235eadf981b9165807dc72a14a383Mihai Preda        final ContentResolver resolver = mMockContext.getContentResolver();
5729627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
5739627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long account1Id = account1.mId;
5749627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
5759627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long box1Id = box1.mId;
5769627d014e16235eadf981b9165807dc72a14a383Mihai Preda
5779627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 1. create message with no body, check that returned bodyId is -1
5789627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
5799627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
5809627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message1Id = message1.mId;
581bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        long bodyId1 = Body.lookupBodyIdWithMessageId(mMockContext, message1Id);
5829627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(bodyId1, -1);
5839627d014e16235eadf981b9165807dc72a14a383Mihai Preda
5849627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 2. create message with body, check that returned bodyId is correct
5859627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
5869627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
5879627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message2Id = message2.mId;
588bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        long bodyId2 = Body.lookupBodyIdWithMessageId(mMockContext, message2Id);
5899627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body body = loadBodyForMessageId(message2Id);
5909627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body);
5919627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(body.mId, bodyId2);
5929627d014e16235eadf981b9165807dc72a14a383Mihai Preda    }
5939627d014e16235eadf981b9165807dc72a14a383Mihai Preda
5949627d014e16235eadf981b9165807dc72a14a383Mihai Preda    /**
5959627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Test for Body.updateBodyWithMessageId().
5969627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * 1. - create message without body,
5979627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - update its body (set TEXT_CONTENT)
5989627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - check correct updated body is read back
5999627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *
6009627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * 2. - create message with body,
6019627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - update body (set TEXT_CONTENT)
6029627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - check correct updated body is read back
6039627d014e16235eadf981b9165807dc72a14a383Mihai Preda     */
6049627d014e16235eadf981b9165807dc72a14a383Mihai Preda    public void testUpdateBodyWithMessageId() {
6059627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
6069627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long account1Id = account1.mId;
6079627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
6089627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long box1Id = box1.mId;
6099627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6109627d014e16235eadf981b9165807dc72a14a383Mihai Preda        final String textContent = "foobar some odd text";
611936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        final String htmlContent = "and some html";
612936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        final String textReply = "plain text reply";
613936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        final String htmlReply = "or the html reply";
6145fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        final String introText = "fred wrote:";
6159627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6169627d014e16235eadf981b9165807dc72a14a383Mihai Preda        ContentValues values = new ContentValues();
6179627d014e16235eadf981b9165807dc72a14a383Mihai Preda        values.put(BodyColumns.TEXT_CONTENT, textContent);
618936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        values.put(BodyColumns.HTML_CONTENT, htmlContent);
619936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        values.put(BodyColumns.TEXT_REPLY, textReply);
620936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        values.put(BodyColumns.HTML_REPLY, htmlReply);
621e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        values.put(BodyColumns.SOURCE_MESSAGE_KEY, 17);
6225fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        values.put(BodyColumns.INTRO_TEXT, introText);
6239627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6249627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 1
6259627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
6269627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
6279627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message1Id = message1.mId;
6289627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body body1 = loadBodyForMessageId(message1Id);
6299627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNull(body1);
6309627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body.updateBodyWithMessageId(mMockContext, message1Id, values);
6319627d014e16235eadf981b9165807dc72a14a383Mihai Preda        body1 = loadBodyForMessageId(message1Id);
6329627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body1);
6339627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(body1.mTextContent, textContent);
634936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body1.mHtmlContent, htmlContent);
635936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body1.mTextReply, textReply);
636936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body1.mHtmlReply, htmlReply);
637e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        assertEquals(body1.mSourceKey, 17);
6385fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        assertEquals(body1.mIntroText, introText);
6399627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6409627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 2
6419627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
6429627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
6439627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message2Id = message2.mId;
6449627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body body2 = loadBodyForMessageId(message2Id);
6459627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body2);
6469627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertTrue(!body2.mTextContent.equals(textContent));
6479627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body.updateBodyWithMessageId(mMockContext, message2Id, values);
6489627d014e16235eadf981b9165807dc72a14a383Mihai Preda        body2 = loadBodyForMessageId(message1Id);
6499627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body2);
6509627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(body2.mTextContent, textContent);
651936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body2.mHtmlContent, htmlContent);
652936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body2.mTextReply, textReply);
653936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body2.mHtmlReply, htmlReply);
654e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        assertEquals(body2.mSourceKey, 17);
6555fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        assertEquals(body2.mIntroText, introText);
6569627d014e16235eadf981b9165807dc72a14a383Mihai Preda    }
6579627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6589627d014e16235eadf981b9165807dc72a14a383Mihai Preda    /**
659c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler     * Test body retrieve methods
660c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler     */
661c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler    public void testBodyRetrieve() {
662c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        // No account needed
663c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        // No mailbox needed
664c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        Message message1 = ProviderTestUtils.setupMessage("bodyretrieve", 1, 1, true,
665c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                true, mMockContext);
666c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        long messageId = message1.mId;
667c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler
668c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mText,
669c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreBodyTextWithMessageId(mMockContext, messageId));
670c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mHtml,
671c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreBodyHtmlWithMessageId(mMockContext, messageId));
672c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mTextReply,
673c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreReplyTextWithMessageId(mMockContext, messageId));
674c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mHtmlReply,
675c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreReplyHtmlWithMessageId(mMockContext, messageId));
676c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mIntroText,
677c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreIntroTextWithMessageId(mMockContext, messageId));
6781575e7860d2259f1aed201ab23d526cddf787365Mihai Preda        assertEquals(message1.mSourceKey,
6791575e7860d2259f1aed201ab23d526cddf787365Mihai Preda                Body.restoreBodySourceKey(mMockContext, messageId));
680c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler    }
681c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler
682c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler    /**
683fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * Test delete body.
684fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 1. create message without body (message id 1)
685fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 2. create message with body (message id 2. The body has _id 1 and messageKey 2).
686fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 3. delete first message.
687fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 4. verify that body for message 2 has not been deleted.
688fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 5. delete message 2, verify body is deleted.
689fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     */
690fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    public void testDeleteBody() {
691fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        final ContentResolver resolver = mMockContext.getContentResolver();
692fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
693fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // Create account and mailboxes
694fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
695fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long account1Id = account1.mId;
696fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
697fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long box1Id = box1.mId;
698fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
699fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 1. create message without body
700fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
701fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
702fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message1Id = message1.mId;
703fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
704fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 2. create message with body
705fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
706fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
707fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message2Id = message2.mId;
708fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // verify body is there
709fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
710fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
711fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 3. delete first message
712fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Message.CONTENT_URI, message1Id), null, null);
713c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank
714fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 4. verify body for second message wasn't deleted
715fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
716fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
717fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 5. delete second message, check its body is deleted
718fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Message.CONTENT_URI, message2Id), null, null);
719fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNull(loadBodyForMessageId(message2Id));
720fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    }
721fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
722fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    /**
723fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * Test delete orphan bodies.
724fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 1. create message without body (message id 1)
725fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 2. create message with body (message id 2. Body has _id 1 and messageKey 2).
726fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 3. delete first message.
727fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 4. delete some other mailbox -- this triggers delete orphan bodies.
728fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 5. verify that body for message 2 has not been deleted.
729fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     */
730fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    public void testDeleteOrphanBodies() {
731fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        final ContentResolver resolver = mMockContext.getContentResolver();
732fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
733ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create account and two mailboxes
734fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
735fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long account1Id = account1.mId;
736fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
737fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long box1Id = box1.mId;
738fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", account1Id, true, mMockContext);
739fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long box2Id = box2.mId;
740fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
741fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 1. create message without body
742fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
743fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
744fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message1Id = message1.mId;
745fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
746fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 2. create message with body
747fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
748fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
749fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message2Id = message2.mId;
750fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        //verify body is there
751fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
752fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
753fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 3. delete first message
754fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Message.CONTENT_URI, message1Id), null, null);
755fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
756fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 4. delete some mailbox (because it triggers "delete orphan bodies")
757fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Mailbox.CONTENT_URI, box2Id), null, null);
758fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
759fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 5. verify body for second message wasn't deleted during "delete orphan bodies"
760fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
761fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    }
762fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
763fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    /**
7640efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     * Note that we can't use EmailContent.count() here because it uses a projection including
7650efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     * count(*), and count(*) is incompatible with a LIMIT (i.e. the limit would be applied to the
7660efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     * single column returned with count(*), rather than to the query itself)
7670efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     */
7680efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    private int count(Context context, Uri uri, String selection, String[] selectionArgs) {
7690efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Cursor c = context.getContentResolver().query(uri, EmailContent.ID_PROJECTION, selection,
7700efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                selectionArgs, null);
7710efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        try {
7720efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank            return c.getCount();
7730efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        } finally {
7740efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank            c.close();
7750efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        }
7760efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    }
7770efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
7780efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    public void testMessageQueryWithLimit() {
7790efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        final Context context = mMockContext;
7800efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
7810efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Create account and two mailboxes
7820efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Account acct = ProviderTestUtils.setupAccount("orphaned body", true, context);
7830efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
7840efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", acct.mId, true, context);
7850efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
7860efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Create 4 messages in box1
7870efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, false, true, context);
7880efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, false, true, context);
7890efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, false, true, context);
7900efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, false, true, context);
7910efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
7920efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Create 4 messages in box2
7930efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box2.mId, false, true, context);
7940efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box2.mId, false, true, context);
7950efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box2.mId, false, true, context);
7960efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box2.mId, false, true, context);
7970efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
7980efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Check normal case, special case (limit 1), and arbitrary limits
7990efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(8, count(mMockContext, Message.CONTENT_URI, null, null));
8000efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(1, count(mMockContext, EmailContent.uriWithLimit(Message.CONTENT_URI, 1),
8010efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                null, null));
8020efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(3, count(mMockContext, EmailContent.uriWithLimit(Message.CONTENT_URI, 3),
8030efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                null, null));
8040efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(8, count(mMockContext, EmailContent.uriWithLimit(Message.CONTENT_URI, 100),
8050efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                null, null));
8060efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8070efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Check that it works with selection/selection args
8080efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        String[] args = new String[] {Long.toString(box1.mId)};
8090efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(4, count(mMockContext, Message.CONTENT_URI,
8100efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                MessageColumns.MAILBOX_KEY + "=?", args));
8110efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(1, count(mMockContext,
8120efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                EmailContent.uriWithLimit(Message.CONTENT_URI, 1),
8130efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                MessageColumns.MAILBOX_KEY + "=?", args));
8140efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    }
8150efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8160efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    /**
817ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * Test delete orphan messages
818ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 1. create message without body (message id 1)
819ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 2. create message with body (message id 2. Body has _id 1 and messageKey 2).
820ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 3. delete first message.
821ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 4. delete some other mailbox -- this triggers delete orphan bodies.
822ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 5. verify that body for message 2 has not been deleted.
823ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     */
824ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     public void testDeleteOrphanMessages() {
825ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        final ContentResolver resolver = mMockContext.getContentResolver();
826ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        final Context context = mMockContext;
827ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
828ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create account and two mailboxes
829ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Account acct = ProviderTestUtils.setupAccount("orphaned body", true, context);
830ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
831ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", acct.mId, true, context);
832ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
833ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create 4 messages in box1
834ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_1 =
835ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, false, true, context);
836ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_2 =
837ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, false, true, context);
838ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_3 =
839ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, false, true, context);
840ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_4 =
841ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, false, true, context);
842ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
843ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create 4 messages in box2
844ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_1 =
845ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message1", acct.mId, box2.mId, false, true, context);
846ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_2 =
847ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message2", acct.mId, box2.mId, false, true, context);
848ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_3 =
849ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message3", acct.mId, box2.mId, false, true, context);
850ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_4 =
851ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message4", acct.mId, box2.mId, false, true, context);
852ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
853ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Delete 2 from each mailbox
854ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_1.mId),
855ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
856ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_2.mId),
857ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
858ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_1.mId),
859ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
860ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_2.mId),
861ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
862ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
863ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should be 4 items in the deleted item table
864ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.DELETED_CONTENT_URI, null, null));
865ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
866ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Update 2 from each mailbox
867ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentValues v = new ContentValues();
868ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        v.put(MessageColumns.DISPLAY_NAME, "--updated--");
869ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_3.mId),
870ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
871ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_4.mId),
872ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
873ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_3.mId),
874ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
875ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_4.mId),
876ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
877ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
878ef83299b99288c00b9d661260d19715e73e6889cMarc Blank         // There should be 4 items in the updated item table
879ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.UPDATED_CONTENT_URI, null, null));
880ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
881ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Manually add 2 messages from a "deleted" mailbox to deleted and updated tables
882ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Use a value > 2 for the deleted box id
883ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        long delBoxId = 10;
884ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create 4 messages in the "deleted" mailbox
885ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_A =
886ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageA", acct.mId, delBoxId, false, false, context);
887ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_B =
888ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageB", acct.mId, delBoxId, false, false, context);
889ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_C =
890ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageC", acct.mId, delBoxId, false, false, context);
891ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_D =
892ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageD", acct.mId, delBoxId, false, false, context);
893ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
894ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentValues cv;
895ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // We have to assign id's manually because there are no autoincrement id's for these tables
896ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Start with an id that won't exist, since id's in these tables must be unique
897ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        long msgId = 10;
898ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // It's illegal to manually insert these, so we need to catch the exception
899ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // NOTE: The insert succeeds, and then throws the exception
900ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
901ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_A.toContentValues();
902ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
903ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.DELETED_CONTENT_URI, cv);
904ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
905ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
906ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
907ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_B.toContentValues();
908ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
909ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.DELETED_CONTENT_URI, cv);
910ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
911ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
912ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
913ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_C.toContentValues();
914ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
915ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.UPDATED_CONTENT_URI, cv);
916ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
917ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
918ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
919ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_D.toContentValues();
920ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
921ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.UPDATED_CONTENT_URI, cv);
922ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
923ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
924ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
925ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should be 6 items in the deleted and updated tables
926ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(6, EmailContent.count(context, Message.UPDATED_CONTENT_URI, null, null));
927ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(6, EmailContent.count(context, Message.DELETED_CONTENT_URI, null, null));
928ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
929ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Delete the orphans
930ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        EmailProvider.deleteOrphans(EmailProvider.getReadableDatabase(context),
931ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                Message.DELETED_TABLE_NAME);
932ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        EmailProvider.deleteOrphans(EmailProvider.getReadableDatabase(context),
933ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                Message.UPDATED_TABLE_NAME);
934ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
935ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should now be 4 messages in each of the deleted and updated tables again
936ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.UPDATED_CONTENT_URI, null, null));
937ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.DELETED_CONTENT_URI, null, null));
938ef83299b99288c00b9d661260d19715e73e6889cMarc Blank    }
939ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
940ef83299b99288c00b9d661260d19715e73e6889cMarc Blank    /**
9417143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test delete mailbox
9427143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
9437143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testMailboxDelete() {
94428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("mailbox-delete", true, mMockContext);
9457143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
94628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
9477143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
94828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", account1Id, true, mMockContext);
9497143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box2Id = box2.mId;
950758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
9517143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String selection = EmailContent.MailboxColumns.ACCOUNT_KEY + "=?";
9527143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String[] selArgs = new String[] { String.valueOf(account1Id) };
9537143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9547143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are two mailboxes
9557143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, selection, selArgs);
9567143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numBoxes);
9577143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9587143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete one of them
9597143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Mailbox.CONTENT_URI, box1Id);
9607143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
9617143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9627143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there's only one mailbox now
9637143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, selection, selArgs);
9647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numBoxes);
9657143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9667143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the other one
9677143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        uri = ContentUris.withAppendedId(Mailbox.CONTENT_URI, box2Id);
9687143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
9697143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9707143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no mailboxes now
9717143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, selection, selArgs);
9727143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numBoxes);
9737143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
974758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
9757143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
9767143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test delete message
9777143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: body
9787143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: attachments
9797143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
9807143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testMessageDelete() {
98128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-delete", true, mMockContext);
9827143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
98328448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
9847143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
98528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
98628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
9877143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message1Id = message1.mId;
98828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, false,
98928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
9907143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message2Id = message2.mId;
9917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9927143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND " +
9937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler                EmailContent.MessageColumns.MAILBOX_KEY + "=?";
9947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String[] selArgs = new String[] { String.valueOf(account1Id), String.valueOf(box1Id) };
9957143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are two messages
9977143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
9987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numMessages);
9997143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10007143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete one of them
10017143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1Id);
10027143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
10037143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10047143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there's only one message now
10057143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
10067143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numMessages);
10077143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10087143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the other one
10097143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        uri = ContentUris.withAppendedId(Message.CONTENT_URI, message2Id);
10107143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
10117143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10127143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no messages now
10137143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
10147143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numMessages);
10157143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
1016758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
10177143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
1018ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * Test delete synced message
1019ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: body
1020ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: attachments
1021ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     */
1022ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    public void testSyncedMessageDelete() {
102328448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("synced-message-delete", true,
102428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
1025ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long account1Id = account1.mId;
102628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
1027ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long box1Id = box1.mId;
102828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
102928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1030ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message1Id = message1.mId;
103128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, false,
103228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1033ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message2Id = message2.mId;
1034ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1035ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND "
1036ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                + EmailContent.MessageColumns.MAILBOX_KEY + "=?";
1037ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String[] selArgs = new String[] {
1038ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            String.valueOf(account1Id), String.valueOf(box1Id)
1039ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        };
1040ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1041ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there are two messages
1042ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1043ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(2, numMessages);
1044ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1045ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure we start with no synced deletions
1046ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1047ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1048ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1049ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1050ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // now delete one of them SYNCED
1051ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Uri uri = ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message1Id);
1052ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
1053ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1054ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's only one message now
1055ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1056ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1057ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1058ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's one synced deletion now
1059ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1060ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1061ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1062ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1063ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // now delete the other one NOT SYNCED
1064ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        uri = ContentUris.withAppendedId(Message.CONTENT_URI, message2Id);
1065ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
1066ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1067ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there are no messages now
1068ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1069ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1070ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1071ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's still one deletion now
1072ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1073ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1074ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1075ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    }
1076ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1077ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    /**
1078ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * Test message update
1079ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: body
1080ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: attachments
1081ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     */
1082ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    public void testMessageUpdate() {
108328448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-update", true, mMockContext);
1084ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long account1Id = account1.mId;
108528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
1086ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long box1Id = box1.mId;
108728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
108828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1089ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message1Id = message1.mId;
109028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, false,
109128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1092ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message2Id = message2.mId;
1093ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        ContentResolver cr = mMockContext.getContentResolver();
1094ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1095ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND "
1096ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                + EmailContent.MessageColumns.MAILBOX_KEY + "=?";
1097ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String[] selArgs = new String[] {
1098ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            String.valueOf(account1Id), String.valueOf(box1Id)
1099ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        };
1100ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1101ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there are two messages
1102ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1103ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(2, numMessages);
1104ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1105ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // change the first one
1106ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1Id);
1107ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        ContentValues cv = new ContentValues();
1108ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cv.put(MessageColumns.FROM_LIST, "from-list");
1109ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cr.update(uri, cv, null, null);
1110ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1111ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's no updated message
1112ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1113ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1114ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1115ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1116ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // get the message back from the provider, make sure the change "stuck"
1117ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Message restoredMessage = Message.restoreMessageWithId(mMockContext, message1Id);
1118ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals("from-list", restoredMessage.mFrom);
1119ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1120ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // change the second one
1121ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        uri = ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message2Id);
1122ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cv = new ContentValues();
1123ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cv.put(MessageColumns.FROM_LIST, "from-list");
1124ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cr.update(uri, cv, null, null);
1125ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1126ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's one updated message
1127ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1128ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1129ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1130ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1131ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // get the message back from the provider, make sure the change "stuck",
1132ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // as before
1133ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        restoredMessage = Message.restoreMessageWithId(mMockContext, message2Id);
1134ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals("from-list", restoredMessage.mFrom);
1135ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1136ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // get the original message back from the provider
1137ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Cursor c = cr.query(Message.UPDATED_CONTENT_URI, Message.CONTENT_PROJECTION, null, null,
1138ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                null);
1139ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        try {
1140ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            assertTrue(c.moveToFirst());
1141ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            Message originalMessage = EmailContent.getContent(c, Message.class);
1142ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            // make sure this has the original value
1143ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            assertEquals("from message2", originalMessage.mFrom);
1144ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            // Should only be one
1145ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            assertFalse(c.moveToNext());
1146ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        } finally {
1147ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            c.close();
1148ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        }
1149ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1150ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // delete the second message
1151ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cr.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message2Id), null, null);
1152ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1153ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // hey, presto! the change should be gone
1154ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1155ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1156ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1157ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1158ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // and there should now be a deleted record
1159ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1160ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1161ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1162ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    }
1163ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1164ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    /**
11657143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: cascaded delete account
11667143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: hostauth
11677143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: body
11687143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: attachments
11697143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: create other account, mailbox & messages and confirm the right objects were deleted
11707143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
11717143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testCascadeDeleteAccount() {
117228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-delete-cascade", true,
117328448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
11747143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
117528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
11767143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
117728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        /* Message message1 = */ ProviderTestUtils.setupMessage("message1", account1Id, box1Id,
117828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
117928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        /* Message message2 = */ ProviderTestUtils.setupMessage("message2", account1Id, box1Id,
118028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
11817143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
11827143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there is one account, one mailbox, and two messages
11837143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numAccounts = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
11847143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numAccounts);
11857143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, null, null);
11867143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numBoxes);
11877143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
11887143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numMessages);
11897143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
11907143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // delete the account
11917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Account.CONTENT_URI, account1Id);
11927143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
11937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
11947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no accounts, mailboxes, or messages
11957143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numAccounts = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
11967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numAccounts);
11977143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, null, null);
11987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numBoxes);
11997143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
12007143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numMessages);
12017143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
1202758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
12037143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
12047143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test cascaded delete mailbox
12057143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: body
12067143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: attachments
12077143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: create other mailbox & messages and confirm the right objects were deleted
12087143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
12097143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testCascadeDeleteMailbox() {
121028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("mailbox-delete-cascade", true,
121128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
12127143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
121328448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
12147143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
1215ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id,
121628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
1217ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id,
1218ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                false, true, mMockContext);
1219ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message3 = ProviderTestUtils.setupMessage("message3", account1Id, box1Id,
1220ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                false, true, mMockContext);
1221ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message4 = ProviderTestUtils.setupMessage("message4", account1Id, box1Id,
122228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
1223ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ProviderTestUtils.setupMessage("message5", account1Id, box1Id, false, true, mMockContext);
1224ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ProviderTestUtils.setupMessage("message6", account1Id, box1Id, false, true, mMockContext);
12257143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
12267143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND " +
12277143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler                EmailContent.MessageColumns.MAILBOX_KEY + "=?";
12287143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String[] selArgs = new String[] { String.valueOf(account1Id), String.valueOf(box1Id) };
12297143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
12300e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // make sure there are six messages
12317143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1232ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(6, numMessages);
1233ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
1234ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentValues cv = new ContentValues();
1235ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        cv.put(Message.SERVER_ID, "SERVER_ID");
1236ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentResolver resolver = mMockContext.getContentResolver();
1237ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
1238ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Update two messages
1239ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message1.mId),
1240ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                cv, null, null);
1241ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message2.mId),
1242ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                cv, null, null);
1243ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Delete two messages
1244ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message3.mId),
1245ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
1246ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message4.mId),
1247ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
1248ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
1249ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should now be two messages in updated/deleted, and 4 in messages
1250ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1251ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, numMessages);
1252ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1253ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
1254ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(2, numMessages);
1255ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1256ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
12577143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numMessages);
1258758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
12597143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the mailbox
12607143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Mailbox.CONTENT_URI, box1Id);
1261ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(uri, null, null);
1262758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1263ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // there should now be zero messages in all three tables
12647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
12657143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numMessages);
1266ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1267ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
1268ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(0, numMessages);
1269ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1270ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
1271ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(0, numMessages);
12727143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
1273758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
12747143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
12756c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     * Test cascaded delete message
12766c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     * Confirms that deleting a message will also delete its body & attachments
12777143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
12786c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    public void testCascadeMessageDelete() {
12796c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-cascade", true, mMockContext);
12806c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long account1Id = account1.mId;
12816c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
12826c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long box1Id = box1.mId;
1283bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
12846c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Each message has a body, and also give each 2 attachments
12856c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
12866c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                false, mMockContext);
12876c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ArrayList<Attachment> atts = new ArrayList<Attachment>();
12886c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        for (int i = 0; i < 2; i++) {
12896c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
12906c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
12916c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    false, mMockContext));
12926c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        }
12936c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message1.mAttachments = atts;
12946c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message1.save(mMockContext);
12956c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long message1Id = message1.mId;
12966c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
12976c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, true,
12986c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                false, mMockContext);
12996c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        atts = new ArrayList<Attachment>();
13006c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        for (int i = 0; i < 2; i++) {
13016c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
13026c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
13036c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    false, mMockContext));
13046c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        }
13056c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message2.mAttachments = atts;
13066c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message2.save(mMockContext);
13076c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long message2Id = message2.mId;
13086c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13096c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Set up to test total counts of bodies & attachments for our test messages
13106c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        String bodySelection = BodyColumns.MESSAGE_KEY + " IN (?,?)";
13116c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        String attachmentSelection = AttachmentColumns.MESSAGE_KEY + " IN (?,?)";
13126c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        String[] selArgs = new String[] { String.valueOf(message1Id), String.valueOf(message2Id) };
1313bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
13146c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // make sure there are two bodies
13156c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        int numBodies = EmailContent.count(mMockContext, Body.CONTENT_URI, bodySelection, selArgs);
13166c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(2, numBodies);
13176c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13186c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // make sure there are four attachments
13196c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        int numAttachments = EmailContent.count(mMockContext, Attachment.CONTENT_URI,
13206c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                attachmentSelection, selArgs);
13216c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(4, numAttachments);
13226c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13236c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // now delete one of the messages
13246c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1Id);
13256c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
13266c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13276c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // there should be one body and two attachments
13286c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numBodies = EmailContent.count(mMockContext, Body.CONTENT_URI, bodySelection, selArgs);
13296c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(1, numBodies);
13306c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13316c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numAttachments = EmailContent.count(mMockContext, Attachment.CONTENT_URI,
13326c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                attachmentSelection, selArgs);
13336c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(2, numAttachments);
13346c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13356c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // now delete the other message
13366c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        uri = ContentUris.withAppendedId(Message.CONTENT_URI, message2Id);
13376c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
13386c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13396c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // make sure there are no bodies or attachments
13406c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numBodies = EmailContent.count(mMockContext, Body.CONTENT_URI, bodySelection, selArgs);
13416c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(0, numBodies);
13426c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13436c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numAttachments = EmailContent.count(mMockContext, Attachment.CONTENT_URI,
13446c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                attachmentSelection, selArgs);
13456c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(0, numAttachments);
13466c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    }
13477143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
1348976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    /**
1349976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     * Test that our unique file name algorithm works as expected.  Since this test requires an
1350976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     * SD card, we check the environment first, and return immediately if none is mounted.
1351976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     * @throws IOException
1352976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     */
1353976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    public void testCreateUniqueFile() throws IOException {
1354976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        // Delete existing files, if they exist
1355976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        if (!Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {
1356976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            return;
1357976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        }
1358976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        try {
1359976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            String fileName = "A11achm3n1.doc";
1360976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            File uniqueFile = Attachment.createUniqueFile(fileName);
1361976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            assertEquals(fileName, uniqueFile.getName());
1362976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            if (uniqueFile.createNewFile()) {
1363976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                uniqueFile = Attachment.createUniqueFile(fileName);
1364976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                assertEquals("A11achm3n1-2.doc", uniqueFile.getName());
1365976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                if (uniqueFile.createNewFile()) {
1366976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    uniqueFile = Attachment.createUniqueFile(fileName);
1367976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    assertEquals("A11achm3n1-3.doc", uniqueFile.getName());
1368976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                }
1369976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank           }
1370976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            fileName = "A11achm3n1";
1371976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            uniqueFile = Attachment.createUniqueFile(fileName);
1372976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            assertEquals(fileName, uniqueFile.getName());
1373976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            if (uniqueFile.createNewFile()) {
1374976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                uniqueFile = Attachment.createUniqueFile(fileName);
1375976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                assertEquals("A11achm3n1-2", uniqueFile.getName());
1376976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            }
1377976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        } finally {
1378976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            File directory = Environment.getExternalStorageDirectory();
1379976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // These are the files that should be created earlier in the test.  Make sure
1380976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // they are deleted for the next go-around
1381976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            String[] fileNames = new String[] {"A11achm3n1.doc", "A11achm3n1-2.doc", "A11achm3n1"};
1382976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            int length = fileNames.length;
1383976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            for (int i = 0; i < length; i++) {
1384976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                File file = new File(directory, fileNames[i]);
1385976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                if (file.exists()) {
1386976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    file.delete();
1387976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                }
1388976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            }
1389976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        }
1390976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    }
13914119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
13924119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    /**
13934119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler     * Test retrieving attachments by message ID (using EmailContent.Attachment.MESSAGE_ID_URI)
13944119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler     */
13954119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    public void testGetAttachmentByMessageIdUri() {
13964119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
13974119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Note, we don't strictly need accounts, mailboxes or messages to run this test.
13984119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Attachment a1 = ProviderTestUtils.setupAttachment(1, "a1", 100, true, mMockContext);
13994119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Attachment a2 = ProviderTestUtils.setupAttachment(1, "a2", 200, true, mMockContext);
1400758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ProviderTestUtils.setupAttachment(2, "a3", 300, true, mMockContext);
1401758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ProviderTestUtils.setupAttachment(2, "a4", 400, true, mMockContext);
14024119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
14034119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Now ask for the attachments of message id=1
14044119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Note: Using the "sort by size" trick to bring them back in expected order
14054119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Uri uri = ContentUris.withAppendedId(Attachment.MESSAGE_ID_URI, 1);
14064119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Cursor c = mMockContext.getContentResolver().query(uri, Attachment.CONTENT_PROJECTION,
14074119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                null, null, Attachment.SIZE);
14084119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        assertEquals(2, c.getCount());
14094119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
14104119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        try {
14114119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.moveToFirst();
14124119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            Attachment a1Get = EmailContent.getContent(c, Attachment.class);
14134119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-1", a1, a1Get);
14144119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.moveToNext();
14154119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            Attachment a2Get = EmailContent.getContent(c, Attachment.class);
14164119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-2", a2, a2Get);
14174119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        } finally {
14184119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.close();
14194119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        }
14204119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    }
142154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
142254c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler    /**
14236c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     * Test deleting attachments by message ID (using EmailContent.Attachment.MESSAGE_ID_URI)
14246c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     */
14256c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    public void testDeleteAttachmentByMessageIdUri() {
14266c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ContentResolver mockResolver = mMockContext.getContentResolver();
14276c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14286c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Note, we don't strictly need accounts, mailboxes or messages to run this test.
14296c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ProviderTestUtils.setupAttachment(1, "a1", 100, true, mMockContext);
14306c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ProviderTestUtils.setupAttachment(1, "a2", 200, true, mMockContext);
14316c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Attachment a3 = ProviderTestUtils.setupAttachment(2, "a3", 300, true, mMockContext);
14326c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Attachment a4 = ProviderTestUtils.setupAttachment(2, "a4", 400, true, mMockContext);
14336c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14346c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Delete all attachments for message id=1
14356c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Uri uri = ContentUris.withAppendedId(Attachment.MESSAGE_ID_URI, 1);
14366c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        mockResolver.delete(uri, null, null);
14376c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14386c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Read back all attachments and confirm that we have the expected remaining attachments
14396c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // (the attachments that are set for message id=2).  Note order-by size to simplify test.
14406c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Cursor c = mockResolver.query(Attachment.CONTENT_URI, Attachment.CONTENT_PROJECTION,
14416c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                null, null, Attachment.SIZE);
14426c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(2, c.getCount());
14436c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14446c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        try {
14456c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            c.moveToFirst();
14466c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            Attachment a3Get = EmailContent.getContent(c, Attachment.class);
14476c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-3", a3, a3Get);
14486c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            c.moveToNext();
14496c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            Attachment a4Get = EmailContent.getContent(c, Attachment.class);
14506c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-4", a4, a4Get);
14516c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        } finally {
14526c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            c.close();
14536c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        }
14546c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    }
14556c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14566c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    /**
145754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * Tests of default account behavior
1458758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank     *
145954c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * 1.  Simple set/get
146054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * 2.  Moving default between 3 accounts
146154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * 3.  Delete default, make sure another becomes default
146254c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     */
146354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler    public void testSetGetDefaultAccount() {
146454c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        // There should be no default account if there are no accounts
146554c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long defaultAccountId = Account.getDefaultAccountId(mMockContext);
146654c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        assertEquals(-1, defaultAccountId);
146754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
146854c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-default-1", true, mMockContext);
146954c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long account1Id = account1.mId;
147054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        Account account2 = ProviderTestUtils.setupAccount("account-default-2", true, mMockContext);
147154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long account2Id = account2.mId;
147254c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        Account account3 = ProviderTestUtils.setupAccount("account-default-3", true, mMockContext);
147354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long account3Id = account3.mId;
147454c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
14759e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        // With three accounts, but none marked default, confirm that some default account
14769e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        // is returned.  Which one is undefined here.
147754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        defaultAccountId = Account.getDefaultAccountId(mMockContext);
14789e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        assertTrue(defaultAccountId == account1Id
14799e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler                    || defaultAccountId == account2Id
14809e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler                    || defaultAccountId == account3Id);
148154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
14829e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        updateIsDefault(account1, true);
148354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        defaultAccountId = Account.getDefaultAccountId(mMockContext);
14849e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        assertEquals(account1Id, defaultAccountId);
148554c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1486531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        updateIsDefault(account2, true);
1487531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1488531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account2Id, defaultAccountId);
1489531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank
1490531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        updateIsDefault(account3, true);
1491531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1492531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account3Id, defaultAccountId);
149354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
149454c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        // Now delete a non-default account and confirm no change
149554c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        Uri uri = ContentUris.withAppendedId(Account.CONTENT_URI, account1Id);
149654c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
149754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1498531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1499531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account3Id, defaultAccountId);
150054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
150154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        // Now confirm deleting the default account and it switches to another one
150254c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        uri = ContentUris.withAppendedId(Account.CONTENT_URI, account3Id);
150354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
150454c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1505531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1506531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account2Id, defaultAccountId);
1507758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
15089e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        // Now delete the final account and confirm there are no default accounts again
15099e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        uri = ContentUris.withAppendedId(Account.CONTENT_URI, account2Id);
15109e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
15119e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler
151254c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        defaultAccountId = Account.getDefaultAccountId(mMockContext);
15139e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        assertEquals(-1, defaultAccountId);
151454c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler    }
151554c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
15169e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler    private void updateIsDefault(Account account, boolean newState) {
15179e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        account.setDefaultAccount(newState);
15189e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        ContentValues cv = new ContentValues();
15199e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        cv.put(AccountColumns.IS_DEFAULT, account.mIsDefault);
15209e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        account.update(mMockContext, cv);
15219e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler    }
1522758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1523758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    public static Message setupUnreadMessage(String name, long accountId, long mailboxId,
1524758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank            boolean addBody, boolean saveIt, Context context) {
1525758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message msg =
1526758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank            ProviderTestUtils.setupMessage(name, accountId, mailboxId, addBody, false, context);
1527758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        msg.mFlagRead = false;
1528758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        if (saveIt) {
1529758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank            msg.save(context);
1530758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        }
1531758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        return msg;
1532758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    }
1533758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1534758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    public void testUnreadCountTriggers() {
1535758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Start with one account and three mailboxes
1536758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Account account = ProviderTestUtils.setupAccount("triggers", true, mMockContext);
1537758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Mailbox boxA = ProviderTestUtils.setupMailbox("boxA", account.mId, true, mMockContext);
1538758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Mailbox boxB = ProviderTestUtils.setupMailbox("boxB", account.mId, true, mMockContext);
1539758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Mailbox boxC = ProviderTestUtils.setupMailbox("boxC", account.mId, true, mMockContext);
1540758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1541758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Make sure there are no unreads
1542758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1543758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxB.mId));
1544758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxC.mId));
1545758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1546758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Create 4 unread messages (only 3 named) in boxA
1547758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message message1 = setupUnreadMessage("message1", account.mId, boxA.mId,
1548758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank                false, true, mMockContext);
1549758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message message2= setupUnreadMessage("message2", account.mId, boxA.mId,
1550758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank                false, true, mMockContext);
1551758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message message3 =  setupUnreadMessage("message3", account.mId, boxA.mId,
1552758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank                false, true, mMockContext);
1553758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        setupUnreadMessage("message4", account.mId, boxC.mId, false, true, mMockContext);
1554758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1555758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Make sure the unreads are where we expect them
1556758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(3, getUnreadCount(boxA.mId));
1557758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxB.mId));
1558758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1559758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1560758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // After deleting message 1, the count in box A should be decremented (to 2)
1561758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ContentResolver cr = mMockContext.getContentResolver();
1562758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1.mId);
1563758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.delete(uri, null, null);
1564758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(2, getUnreadCount(boxA.mId));
1565758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxB.mId));
1566758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1567758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1568758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Move message 2 to box B, leaving 1 in box A and 1 in box B
1569758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        message2.mMailboxKey = boxB.mId;
1570758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ContentValues cv = new ContentValues();
1571758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.MAILBOX_KEY, boxB.mId);
1572758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message2.mId), cv, null, null);
1573758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxA.mId));
1574758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1575758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1576758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1577758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Mark message 3 (from box A) read, leaving 0 in box A
1578758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.clear();
1579758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.FLAG_READ, 1);
1580758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message3.mId), cv, null, null);
1581758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1582758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1583758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1584758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1585758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Move message 3 to box C; should be no change (it's read)
1586758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        message3.mMailboxKey = boxC.mId;
1587758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.clear();
1588758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.MAILBOX_KEY, boxC.mId);
1589758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message3.mId), cv, null, null);
1590758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1591758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1592758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1593758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1594758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Mark message 3 unread; it's now in box C, so that box's count should go up to 3
1595758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.clear();
1596758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.FLAG_READ, 0);
1597758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message3.mId), cv, null, null);
1598758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1599758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1600758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(2, getUnreadCount(boxC.mId));
1601758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    }
16029627d014e16235eadf981b9165807dc72a14a383Mihai Preda
16039627d014e16235eadf981b9165807dc72a14a383Mihai Preda    /**
16049627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Test for EmailProvider.createIndex().
16059627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Check that it returns exacly the same string as the one used previously for index creation.
16069627d014e16235eadf981b9165807dc72a14a383Mihai Preda     */
16079627d014e16235eadf981b9165807dc72a14a383Mihai Preda    public void testCreateIndex() {
16089627d014e16235eadf981b9165807dc72a14a383Mihai Preda        String oldStr = "create index message_" + MessageColumns.TIMESTAMP
16099627d014e16235eadf981b9165807dc72a14a383Mihai Preda            + " on " + Message.TABLE_NAME + " (" + MessageColumns.TIMESTAMP + ");";
16109627d014e16235eadf981b9165807dc72a14a383Mihai Preda        String newStr = EmailProvider.createIndex(Message.TABLE_NAME, MessageColumns.TIMESTAMP);
16119627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(newStr, oldStr);
16129627d014e16235eadf981b9165807dc72a14a383Mihai Preda    }
1613c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank
16140e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    public void testDatabaseCorruptionRecovery() {
16150e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final ContentResolver resolver = mMockContext.getContentResolver();
16160e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final Context context = mMockContext;
16170e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16180e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create account and two mailboxes
16190e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Account acct = ProviderTestUtils.setupAccount("acct1", true, context);
16200e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
16210e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16220e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create 4 messages in box1 with bodies
16230e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, true, true, context);
16240e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, true, true, context);
16250e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, true, true, context);
16260e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, true, true, context);
16270e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16280e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four messages
16290e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        int count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
16300e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
16310e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four bodies
16320e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
16330e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
16340e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16350e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProvider.db file
16360e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        File dbFile = mMockContext.getDatabasePath(EmailProvider.DATABASE_NAME);
16370e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProvider.db database should exist (the provider creates it automatically)
16380e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
16390e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
16400e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Delete it, and confirm it is gone
16410e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.delete());
16420e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertFalse(dbFile.exists());
16430e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16440e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProviderBody.db file
16450e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        dbFile = mMockContext.getDatabasePath(EmailProvider.BODY_DATABASE_NAME);
16460e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProviderBody.db database should still exist
16470e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
16480e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
16490e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16500e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // URI to uncache the databases
16510e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // This simulates the Provider starting up again (otherwise, it will still be pointing to
16520e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the already opened files)
16530e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Note that we only have access to the EmailProvider via the ContentResolver; therefore,
16540e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // we cannot directly call into the provider and use a URI for this
16550e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        resolver.update(EmailProvider.INTEGRITY_CHECK_URI, null, null, null);
16560e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16570e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // TODO We should check for the deletion of attachment files once this is implemented in
16580e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the provider
1659bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
16600e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Explanation for what happens below...
16610e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The next time the database is created by the provider, it will notice that there's
16620e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // already a EmailProviderBody.db file.  In this case, it will delete that database to
16630e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // ensure that both are in sync (and empty)
16640e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16650e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no bodies
16660e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
16670e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
16680e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16690e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no messages
16700e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
16710e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
16720e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    }
16730e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16740e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    public void testBodyDatabaseCorruptionRecovery() {
16750e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final ContentResolver resolver = mMockContext.getContentResolver();
16760e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final Context context = mMockContext;
16770e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16780e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create account and two mailboxes
16790e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Account acct = ProviderTestUtils.setupAccount("acct1", true, context);
16800e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
16810e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16820e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create 4 messages in box1 with bodies
16830e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, true, true, context);
16840e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, true, true, context);
16850e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, true, true, context);
16860e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, true, true, context);
16870e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16880e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four messages
16890e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        int count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
16900e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
16910e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four bodies
16920e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
16930e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
16940e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16950e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProviderBody.db file
16960e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        File dbFile = mMockContext.getDatabasePath(EmailProvider.BODY_DATABASE_NAME);
16970e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProviderBody.db database should exist (the provider creates it automatically)
16980e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
16990e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
17000e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Delete it, and confirm it is gone
17010e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.delete());
17020e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertFalse(dbFile.exists());
17030e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17040e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProvider.db file
17050e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        dbFile = mMockContext.getDatabasePath(EmailProvider.DATABASE_NAME);
17060e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProviderBody.db database should still exist
17070e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
17080e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
17090e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17100e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // URI to uncache the databases
17110e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // This simulates the Provider starting up again (otherwise, it will still be pointing to
17120e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the already opened files)
17130e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Note that we only have access to the EmailProvider via the ContentResolver; therefore,
17140e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // we cannot directly call into the provider and use a URI for this
17150e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        resolver.update(EmailProvider.INTEGRITY_CHECK_URI, null, null, null);
17160e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17170e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // TODO We should check for the deletion of attachment files once this is implemented in
17180e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the provider
17190e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17200e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Explanation for what happens below...
17210e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The next time the body database is created by the provider, it will notice that there's
17220e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // already a populated EmailProvider.db file.  In this case, it will delete that database to
17230e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // ensure that both are in sync (and empty)
17240e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17250e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no messages
17260e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
17270e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
17280e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17290e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no bodies
17300e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
17310e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
17320e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    }
1733694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1734694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank    public void testFindMailboxOfType() {
1735694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        final Context context = mMockContext;
1736694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1737694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        // Create two accounts and a variety of mailbox types
1738694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Account acct1 = ProviderTestUtils.setupAccount("acct1", true, context);
1739694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Inbox =
1740694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Inbox1", acct1.mId, true, context, Mailbox.TYPE_INBOX);
1741694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Calendar
1742694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        = ProviderTestUtils.setupMailbox("Cal1", acct1.mId, true, context, Mailbox.TYPE_CALENDAR);
1743694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Contacts =
1744694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Con1", acct1.mId, true, context, Mailbox.TYPE_CONTACTS);
1745694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Account acct2 = ProviderTestUtils.setupAccount("acct1", true, context);
1746694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Inbox =
1747694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Inbox2", acct2.mId, true, context, Mailbox.TYPE_INBOX);
1748694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Calendar =
1749694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Cal2", acct2.mId, true, context, Mailbox.TYPE_CALENDAR);
1750694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Contacts =
1751694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Con2", acct2.mId, true, context, Mailbox.TYPE_CONTACTS);
1752694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1753694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        // Check that we can find them by type
1754694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct1Inbox.mId,
1755694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_INBOX));
1756694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct2Inbox.mId,
1757694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct2.mId, Mailbox.TYPE_INBOX));
1758694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct1Calendar.mId,
1759694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_CALENDAR));
1760694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct2Calendar.mId,
1761694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct2.mId, Mailbox.TYPE_CALENDAR));
1762694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct1Contacts.mId,
1763694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_CONTACTS));
1764694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct2Contacts.mId,
1765694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct2.mId, Mailbox.TYPE_CONTACTS));
17666ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler
17676ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler        // Check that nonexistent mailboxes are not returned
17686ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler        assertEquals(Mailbox.NO_MAILBOX,
17696ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_DRAFTS));
17706ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler        assertEquals(Mailbox.NO_MAILBOX,
17716ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_OUTBOX));
17726ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler
17736ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler        // delete account 1 and confirm no mailboxes are returned
17746ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler        context.getContentResolver().delete(
17756ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler                ContentUris.withAppendedId(Account.CONTENT_URI, acct1.mId), null, null);
17766ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler        assertEquals(Mailbox.NO_MAILBOX,
17776ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_INBOX));
17786ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler        assertEquals(Mailbox.NO_MAILBOX,
17796ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_CALENDAR));
17806ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler        assertEquals(Mailbox.NO_MAILBOX,
17816ebaa90847e6e9c7624c18905971a003b2ee902bAndy Stadler                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_CONTACTS));
1782694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank    }
1783694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1784694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank    public void testRestoreMailboxOfType() {
1785694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        final Context context = mMockContext;
1786694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1787694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        // Create two accounts and a variety of mailbox types
1788694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Account acct1 = ProviderTestUtils.setupAccount("acct1", true, context);
1789694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Inbox =
1790694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Inbox1", acct1.mId, true, context, Mailbox.TYPE_INBOX);
1791694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Calendar
1792694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        = ProviderTestUtils.setupMailbox("Cal1", acct1.mId, true, context, Mailbox.TYPE_CALENDAR);
1793694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Contacts =
1794694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Con1", acct1.mId, true, context, Mailbox.TYPE_CONTACTS);
1795694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Account acct2 = ProviderTestUtils.setupAccount("acct1", true, context);
1796694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Inbox =
1797694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Inbox2", acct2.mId, true, context, Mailbox.TYPE_INBOX);
1798694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Calendar =
1799694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Cal2", acct2.mId, true, context, Mailbox.TYPE_CALENDAR);
1800694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Contacts =
1801694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Con2", acct2.mId, true, context, Mailbox.TYPE_CONTACTS);
1802694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1803694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        // Check that we can find them by type
1804694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct1Inbox,
1805694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct1.mId, Mailbox.TYPE_INBOX));
1806694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct2Inbox,
1807694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct2.mId, Mailbox.TYPE_INBOX));
1808694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct1Calendar,
1809694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct1.mId, Mailbox.TYPE_CALENDAR));
1810694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct2Calendar,
1811694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct2.mId, Mailbox.TYPE_CALENDAR));
1812694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct1Contacts,
1813694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct1.mId, Mailbox.TYPE_CONTACTS));
1814694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct2Contacts,
1815694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct2.mId, Mailbox.TYPE_CONTACTS));
1816694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank    }
1817bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1818bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki    public void testAccountIsSecurityHold() {
1819bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        final Context context = mMockContext;
1820bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account acct1 = ProviderTestUtils.setupAccount("acct1", true, context);
1821bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1822bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account acct2 = ProviderTestUtils.setupAccount("acct2", false, context);
1823bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        acct2.mFlags |= Account.FLAGS_SECURITY_HOLD;
1824bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        acct2.save(context);
1825bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1826bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertFalse(Account.isSecurityHold(context, acct1.mId));
1827bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertTrue(Account.isSecurityHold(context, acct2.mId));
1828bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertFalse(Account.isSecurityHold(context, 9999999)); // No such account
1829bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki   }
1830bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1831bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki    public void testClearAccountHoldFlags() {
1832bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a1 = ProviderTestUtils.setupAccount("holdflag-1", false, mMockContext);
1833bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a1.mFlags = Account.FLAGS_NOTIFY_NEW_MAIL;
1834bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a1.save(mMockContext);
1835bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a2 = ProviderTestUtils.setupAccount("holdflag-2", false, mMockContext);
1836bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a2.mFlags = Account.FLAGS_VIBRATE_ALWAYS | Account.FLAGS_SECURITY_HOLD;
1837bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a2.save(mMockContext);
1838bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1839bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        // bulk clear
1840bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account.clearSecurityHoldOnAllAccounts(mMockContext);
1841bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1842bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        // confirm new values as expected - no hold flags; other flags unmolested
1843bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a1a = Account.restoreAccountWithId(mMockContext, a1.mId);
1844bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertEquals(Account.FLAGS_NOTIFY_NEW_MAIL, a1a.mFlags);
1845bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a2a = Account.restoreAccountWithId(mMockContext, a2.mId);
1846bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertEquals(Account.FLAGS_VIBRATE_ALWAYS, a2a.mFlags);
1847bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki    }
1848574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1849574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    /**
1850574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki     * @return the number of messages in a mailbox.
1851574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki     */
1852574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    private int getMessageCount(long mailboxId) {
1853fab77f147f85766d2f75d8aece0aaa4ffb3838e8Marc Blank        return Utility.getFirstRowInt(mMockContext,
1854fab77f147f85766d2f75d8aece0aaa4ffb3838e8Marc Blank                ContentUris.withAppendedId(Mailbox.CONTENT_URI, mailboxId),
1855fab77f147f85766d2f75d8aece0aaa4ffb3838e8Marc Blank                new String[] {MailboxColumns.MESSAGE_COUNT}, null, null, null, 0);
1856574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    }
1857574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1858574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    /** Set -1 to the message count of all mailboxes for the recalculateMessageCount test. */
1859574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    private void setMinusOneToMessageCounts() {
1860574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        ContentValues values = new ContentValues();
1861574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        values.put(MailboxColumns.MESSAGE_COUNT, -1);
1862574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
18635b0c2c7f344e72915ac63ff45cf3d65885373a39Makoto Onuki        // EmailProvider.update() doesn't allow updating messageCount, so directly use the DB.
18645b0c2c7f344e72915ac63ff45cf3d65885373a39Makoto Onuki        SQLiteDatabase db = getProvider().getDatabase(mMockContext);
18655b0c2c7f344e72915ac63ff45cf3d65885373a39Makoto Onuki        db.update(Mailbox.TABLE_NAME, values, null, null);
1866574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    }
1867574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1868574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    /**
1869833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     * Test for the message count triggers (insert/delete/move mailbox), and also
1870574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki     * {@link EmailProvider#recalculateMessageCount}.
1871833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     *
1872833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     * It also covers:
1873833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     * - {@link Mailbox#getMessageCountByMailboxType(Context, int)}
18742ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki     * - {@link Mailbox#getUnreadCountByAccountAndMailboxType(Context, long, int)}
1875833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     * - {@link Mailbox#getUnreadCountByMailboxType(Context, int)}
1876833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     * - {@link Message#getFavoriteMessageCount(Context)}
18779c0da8b84f2e52b38134719fcbf80c9d3c777970Makoto Onuki     * - {@link Message#getFavoriteMessageCount(Context, long)}
1878574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki     */
1879574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    public void testMessageCount() {
1880574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        final Context c = mMockContext;
1881574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1882574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Create 2 accounts
1883574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        Account a1 = ProviderTestUtils.setupAccount("holdflag-1", true, c);
1884574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        Account a2 = ProviderTestUtils.setupAccount("holdflag-2", true, c);
1885574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1886574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Create 2 mailboxes for each account
1887833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a1.mId, true, c, Mailbox.TYPE_INBOX);
1888833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a1.mId, true, c, Mailbox.TYPE_OUTBOX);
1889833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Mailbox b3 = ProviderTestUtils.setupMailbox("box3", a2.mId, true, c, Mailbox.TYPE_INBOX);
1890833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Mailbox b4 = ProviderTestUtils.setupMailbox("box4", a2.mId, true, c, Mailbox.TYPE_OUTBOX);
1891d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        Mailbox bt = ProviderTestUtils.setupMailbox("boxT", a2.mId, true, c, Mailbox.TYPE_TRASH);
1892574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1893574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // 0. Check the initial values, just in case.
1894574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1895574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b1.mId));
1896574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b2.mId));
1897574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b3.mId));
1898574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b4.mId));
1899d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        assertEquals(0, getMessageCount(bt.mId));
1900574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1901833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(0, Message.getFavoriteMessageCount(c));
19029c0da8b84f2e52b38134719fcbf80c9d3c777970Makoto Onuki        assertEquals(0, Message.getFavoriteMessageCount(c, a1.mId));
19039c0da8b84f2e52b38134719fcbf80c9d3c777970Makoto Onuki        assertEquals(0, Message.getFavoriteMessageCount(c, a2.mId));
1904833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByMailboxType(c, Mailbox.TYPE_INBOX));
1905833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByMailboxType(c, Mailbox.TYPE_OUTBOX));
1906833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(0, Mailbox.getMessageCountByMailboxType(c, Mailbox.TYPE_INBOX));
1907833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(0, Mailbox.getMessageCountByMailboxType(c, Mailbox.TYPE_OUTBOX));
1908d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        assertEquals(0, Mailbox.getMessageCountByMailboxType(c, Mailbox.TYPE_TRASH));
1909833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki
19102ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByAccountAndMailboxType(c,
19112ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki                a1.mId, Mailbox.TYPE_INBOX));
19122ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByAccountAndMailboxType(c,
19132ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki                a1.mId, Mailbox.TYPE_OUTBOX));
19142ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByAccountAndMailboxType(c,
1915d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki                a1.mId, Mailbox.TYPE_TRASH));
1916d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByAccountAndMailboxType(c,
19172ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki                a2.mId, Mailbox.TYPE_INBOX));
19182ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByAccountAndMailboxType(c,
19192ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki                a2.mId, Mailbox.TYPE_OUTBOX));
1920d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByAccountAndMailboxType(c,
1921d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki                a2.mId, Mailbox.TYPE_TRASH));
19222ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki
1923574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // 1. Test for insert triggers.
1924574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1925574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Create some messages
19269c0da8b84f2e52b38134719fcbf80c9d3c777970Makoto Onuki        // b1 (account 1, inbox): 1 message, including 1 starred
1927543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        Message m11 = createMessage(c, b1, true, false, Message.FLAG_LOADED_COMPLETE);
1928574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
19299c0da8b84f2e52b38134719fcbf80c9d3c777970Makoto Onuki        // b2 (account 1, outbox): 2 message, including 1 starred
1930543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        Message m21 = createMessage(c, b2, false, false, Message.FLAG_LOADED_COMPLETE);
1931543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        Message m22 = createMessage(c, b2, true, true, Message.FLAG_LOADED_COMPLETE);
1932574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
19339c0da8b84f2e52b38134719fcbf80c9d3c777970Makoto Onuki        // b3 (account 2, inbox): 3 message, including 1 starred
1934543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        Message m31 = createMessage(c, b3, false, false, Message.FLAG_LOADED_COMPLETE);
1935543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        Message m32 = createMessage(c, b3, false, false, Message.FLAG_LOADED_COMPLETE);
1936543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        Message m33 = createMessage(c, b3, true, true, Message.FLAG_LOADED_COMPLETE);
1937574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
19382ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        // b4 (account 2, outbox) has no messages.
1939574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1940d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        // bt (account 2, trash) has 3 messages, including 2 starred
1941543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        Message mt1 = createMessage(c, bt, true, false, Message.FLAG_LOADED_COMPLETE);
1942543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        Message mt2 = createMessage(c, bt, true, false, Message.FLAG_LOADED_COMPLETE);
1943543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        Message mt3 = createMessage(c, bt, false, false, Message.FLAG_LOADED_COMPLETE);
1944d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki
1945574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Check message counts
1946574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b1.mId));
1947574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(2, getMessageCount(b2.mId));
1948574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(3, getMessageCount(b3.mId));
1949574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b4.mId));
1950d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        assertEquals(3, getMessageCount(bt.mId));
1951574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1952833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        // Check the simple counting methods.
1953d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        assertEquals(3, Message.getFavoriteMessageCount(c)); // excludes starred in trash
19549c0da8b84f2e52b38134719fcbf80c9d3c777970Makoto Onuki        assertEquals(2, Message.getFavoriteMessageCount(c, a1.mId));
1955d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        assertEquals(1, Message.getFavoriteMessageCount(c, a2.mId)); // excludes starred in trash
1956833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(3, Mailbox.getUnreadCountByMailboxType(c, Mailbox.TYPE_INBOX));
1957833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(1, Mailbox.getUnreadCountByMailboxType(c, Mailbox.TYPE_OUTBOX));
1958833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(4, Mailbox.getMessageCountByMailboxType(c, Mailbox.TYPE_INBOX));
1959833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(2, Mailbox.getMessageCountByMailboxType(c, Mailbox.TYPE_OUTBOX));
1960d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        assertEquals(3, Mailbox.getMessageCountByMailboxType(c, Mailbox.TYPE_TRASH));
1961833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki
19622ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        assertEquals(1, Mailbox.getUnreadCountByAccountAndMailboxType(c,
19632ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki                a1.mId, Mailbox.TYPE_INBOX));
19642ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        assertEquals(1, Mailbox.getUnreadCountByAccountAndMailboxType(c,
19652ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki                a1.mId, Mailbox.TYPE_OUTBOX));
1966d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByAccountAndMailboxType(c,
1967d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki                a1.mId, Mailbox.TYPE_TRASH));
19682ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        assertEquals(2, Mailbox.getUnreadCountByAccountAndMailboxType(c,
19692ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki                a2.mId, Mailbox.TYPE_INBOX));
19702ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByAccountAndMailboxType(c,
19712ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki                a2.mId, Mailbox.TYPE_OUTBOX));
1972d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki        assertEquals(3, Mailbox.getUnreadCountByAccountAndMailboxType(c,
1973d072f9905d8572f454be1f2ea5d7ba173d2b57d1Makoto Onuki                a2.mId, Mailbox.TYPE_TRASH));
19742ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki
1975574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // 2. test for recalculateMessageCount.
1976574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1977574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // First, invalidate the message counts.
1978574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        setMinusOneToMessageCounts();
1979574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(-1, getMessageCount(b1.mId));
1980574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(-1, getMessageCount(b2.mId));
1981574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(-1, getMessageCount(b3.mId));
1982574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(-1, getMessageCount(b4.mId));
1983574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1984574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Batch update.
1985574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        SQLiteDatabase db = getProvider().getDatabase(mMockContext);
1986574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        EmailProvider.recalculateMessageCount(db);
1987574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1988574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Check message counts
1989574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b1.mId));
1990574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(2, getMessageCount(b2.mId));
1991574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(3, getMessageCount(b3.mId));
1992574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b4.mId));
1993574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1994574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // 3. Check the "move mailbox" trigger.
1995574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1996574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Move m32 (in mailbox 3) to mailbox 4.
1997574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        ContentValues values = new ContentValues();
1998574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        values.put(MessageColumns.MAILBOX_KEY, b4.mId);
1999574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2000574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        getProvider().update(Message.CONTENT_URI, values, EmailContent.ID_SELECTION,
2001574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki                new String[] {"" + m32.mId});
2002574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2003574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Check message counts
2004574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b1.mId));
2005574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(2, getMessageCount(b2.mId));
2006574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(2, getMessageCount(b3.mId));
2007574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b4.mId));
2008574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2009574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // 4. Check the delete trigger.
2010574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2011574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Delete m11 (in mailbox 1)
2012574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        getProvider().delete(Message.CONTENT_URI, EmailContent.ID_SELECTION,
2013574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki                new String[] {"" + m11.mId});
2014574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Delete m21 (in mailbox 2)
2015574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        getProvider().delete(Message.CONTENT_URI, EmailContent.ID_SELECTION,
2016574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki                new String[] {"" + m21.mId});
2017574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2018574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Check message counts
2019574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b1.mId));
2020574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b2.mId));
2021574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(2, getMessageCount(b3.mId));
2022574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b4.mId));
2023d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki
2024d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        // No such mailbox type.
2025d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        assertEquals(0, Mailbox.getMessageCountByMailboxType(c, 99999));
20262ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByAccountAndMailboxType(c, a1.mId, 99999));
2027d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        assertEquals(0, Mailbox.getUnreadCountByMailboxType(c, 99999));
20282ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki
20292ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        // No such account
20302ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByAccountAndMailboxType(c,
20312ac1eaf8c3f7122da7900f0ea5a1198264631d74Makoto Onuki                99999, Mailbox.TYPE_INBOX));
2032574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    }
2033833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki
2034833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki    private static Message createMessage(Context c, Mailbox b, boolean starred, boolean read) {
2035543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        return ProviderTestUtils.setupMessage(
2036543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy                "1", b.mAccountKey, b.mId, true, true, c, starred, read);
2037543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy    }
2038543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy
2039543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy    private static Message createMessage(Context c, Mailbox b, boolean starred, boolean read,
2040543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy            int flagLoaded) {
2041543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        Message message = ProviderTestUtils.setupMessage(
2042543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy                "1", b.mAccountKey, b.mId, true, false, c, starred, read);
2043543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        message.mFlagLoaded = flagLoaded;
2044543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        message.save(c);
2045543953ad87a12d251fcec82c57d00383225b4149Todd Kennedy        return message;
2046833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki    }
20476d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki
20485247ab8cae802272b1e29e81d3b31a1c4e710da5Makoto Onuki    public void testAccountIsEasAccount() {
20496d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki        Account account = new Account();
205025144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        // No hostauth
20515247ab8cae802272b1e29e81d3b31a1c4e710da5Makoto Onuki        assertFalse(account.isEasAccount(mMockContext));
20526d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki
205325144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount(null, false);
205425144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount("", false);
205525144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount("x", false);
205625144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount("eas", true);
205725144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki    }
20586d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki
205925144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki    private void checkAccountIsEasAccount(String protocol, boolean expected) {
206025144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        Account account = ProviderTestUtils.setupAccount("account", false, mMockContext);
206125144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        account.mHostAuthRecv = ProviderTestUtils.setupHostAuth(protocol, "account-hostauth-recv",
2062fe68c0e7c2672e09076038b36ad24f095633d313Todd Kennedy                false, mMockContext);
206325144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        account.save(mMockContext);
206425144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        assertEquals(expected, account.isEasAccount(mMockContext));
20656d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki    }
2066bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank
2067bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank    public void testGetKeyColumnLong() {
2068bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        final Context c = mMockContext;
2069bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Account a = ProviderTestUtils.setupAccount("acct", true, c);
2070bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a.mId, true, c, Mailbox.TYPE_MAIL);
2071bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a.mId, true, c, Mailbox.TYPE_MAIL);
2072bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Message m1 = createMessage(c, b1, false, false);
2073bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Message m2 = createMessage(c, b2, false, false);
2074bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(a.mId, Message.getKeyColumnLong(c, m1.mId, MessageColumns.ACCOUNT_KEY));
2075bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(a.mId, Message.getKeyColumnLong(c, m2.mId, MessageColumns.ACCOUNT_KEY));
2076bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(b1.mId, Message.getKeyColumnLong(c, m1.mId, MessageColumns.MAILBOX_KEY));
2077bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(b2.mId, Message.getKeyColumnLong(c, m2.mId, MessageColumns.MAILBOX_KEY));
2078bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank    }
2079bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank
2080aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki    public void testGetAccountIdForMessageId() {
2081aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        final Context c = mMockContext;
2082aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("acct1", true, c);
2083aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Account a2 = ProviderTestUtils.setupAccount("acct2", true, c);
2084aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a1.mId, true, c, Mailbox.TYPE_MAIL);
2085aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a2.mId, true, c, Mailbox.TYPE_MAIL);
2086aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Message m1 = createMessage(c, b1, false, false);
2087aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        Message m2 = createMessage(c, b2, false, false);
2088aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki
2089aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        assertEquals(a1.mId, Account.getAccountIdForMessageId(c, m1.mId));
2090aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        assertEquals(a2.mId, Account.getAccountIdForMessageId(c, m2.mId));
2091aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki
2092aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        // message desn't exist
2093aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki        assertEquals(-1, Account.getAccountIdForMessageId(c, 12345));
2094aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki    }
2095aef9515ee70f1f0b6cc4fa601078597b55831331Makoto Onuki
2096bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank    public void testGetAccountMailboxFromMessageId() {
2097bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        final Context c = mMockContext;
2098bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Account a = ProviderTestUtils.setupAccount("acct", true, c);
2099bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a.mId, true, c, Mailbox.TYPE_MAIL);
2100bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a.mId, true, c, Mailbox.TYPE_MAIL);
2101bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Message m1 = createMessage(c, b1, false, false);
2102bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Message m2 = createMessage(c, b2, false, false);
2103bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        ProviderTestUtils.assertAccountEqual("x", a, Account.getAccountForMessageId(c, m1.mId));
2104bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        ProviderTestUtils.assertAccountEqual("x", a, Account.getAccountForMessageId(c, m2.mId));
2105bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        // Restore the mailboxes, since the unread & total counts will have changed
2106bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        b1 = Mailbox.restoreMailboxWithId(c, b1.mId);
2107bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        b2 = Mailbox.restoreMailboxWithId(c, b2.mId);
2108bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        ProviderTestUtils.assertMailboxEqual("x", b1, Mailbox.getMailboxForMessageId(c, m1.mId));
2109bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        ProviderTestUtils.assertMailboxEqual("x", b2, Mailbox.getMailboxForMessageId(c, m2.mId));
2110bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank    }
2111e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2112e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki    public void testGetAccountGetInboxIdTest() {
2113e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        final Context c = mMockContext;
2114e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2115e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        // Prepare some data with red-herrings.
2116e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("acct1", true, c);
2117e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Account a2 = ProviderTestUtils.setupAccount("acct2", true, c);
2118e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox b1i = ProviderTestUtils.setupMailbox("b1i", a1.mId, true, c, Mailbox.TYPE_INBOX);
2119e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox b2a = ProviderTestUtils.setupMailbox("b2a", a2.mId, true, c, Mailbox.TYPE_MAIL);
2120e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox b2i = ProviderTestUtils.setupMailbox("b2b", a2.mId, true, c, Mailbox.TYPE_INBOX);
2121e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2122e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertEquals(b2i.mId, Account.getInboxId(c, a2.mId));
2123d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki
2124d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        // No account found.
2125d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        assertEquals(-1, Account.getInboxId(c, 999999));
2126e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki    }
2127e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2128a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki    public void testGetMailboxType() {
2129a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        final Context c = mMockContext;
2130a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki
2131a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        Account a = ProviderTestUtils.setupAccount("acct1", true, c);
2132a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        Mailbox bi = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_INBOX);
2133a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        Mailbox bm = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_MAIL);
2134a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki
2135a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        assertEquals(Mailbox.TYPE_INBOX, Mailbox.getMailboxType(c, bi.mId));
2136a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        assertEquals(Mailbox.TYPE_MAIL, Mailbox.getMailboxType(c, bm.mId));
2137a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        assertEquals(-1, Mailbox.getMailboxType(c, 999999)); // mailbox not found
2138a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki    }
2139a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki
2140ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki    public void testGetDisplayName() {
2141ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki        final Context c = mMockContext;
2142ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki
2143ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki        Account a = ProviderTestUtils.setupAccount("acct1", true, c);
2144ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki        Mailbox bi = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_INBOX);
2145ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki        Mailbox bm = ProviderTestUtils.setupMailbox("b2", a.mId, true, c, Mailbox.TYPE_MAIL);
2146ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki
2147ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki        assertEquals("b1", Mailbox.getDisplayName(c, bi.mId));
2148ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki        assertEquals("b2", Mailbox.getDisplayName(c, bm.mId));
2149ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki        assertEquals(null, Mailbox.getDisplayName(c, 999999)); // mailbox not found
2150ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki    }
2151ee7205d100eff01a75c292b80f41cd24a2b19b84Makoto Onuki
2152e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki    public void testMailboxIsRefreshable() {
2153e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        final Context c = mMockContext;
2154e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2155e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Account a = ProviderTestUtils.setupAccount("acct1", true, c);
2156e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox bi = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_INBOX);
2157e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox bm = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_MAIL);
2158e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox bd = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_DRAFTS);
2159e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox bo = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_OUTBOX);
2160e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2161e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertTrue(Mailbox.isRefreshable(c, bi.mId));
2162e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertTrue(Mailbox.isRefreshable(c, bm.mId));
2163e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertFalse(Mailbox.isRefreshable(c, bd.mId));
2164e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertFalse(Mailbox.isRefreshable(c, bo.mId));
2165e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2166e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        // No such mailbox
2167a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        assertFalse(Mailbox.isRefreshable(c, 9999999));
2168e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2169e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        // Magic mailboxes can't be refreshed.
2170e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertFalse(Mailbox.isRefreshable(c, Mailbox.QUERY_ALL_DRAFTS));
2171e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertFalse(Mailbox.isRefreshable(c, Mailbox.QUERY_ALL_INBOXES));
2172e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki    }
2173767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki
2174767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki    public void testMailboxCanMoveFrom() {
2175767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        final Context c = mMockContext;
2176767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki
2177767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        Account a = ProviderTestUtils.setupAccount("acct1", true, c);
2178767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        Mailbox bi = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_INBOX);
2179767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        Mailbox bm = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_MAIL);
2180767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        Mailbox bd = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_DRAFTS);
2181767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        Mailbox bo = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_OUTBOX);
2182767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki
2183767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        assertTrue(Mailbox.canMoveFrom(c, bi.mId));
2184767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        assertTrue(Mailbox.canMoveFrom(c, bm.mId));
2185767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        assertFalse(Mailbox.canMoveFrom(c, bd.mId));
2186767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        assertFalse(Mailbox.canMoveFrom(c, bo.mId));
2187767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki    }
2188261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2189261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki    /**
2190261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki     * Check if update to {@link Account#RESET_NEW_MESSAGE_COUNT_URI} resets the new message count.
2191261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki     */
2192261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki    public void testResetNewMessageCount() {
2193261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        final Context c = mMockContext;
2194261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        final ContentResolver cr = c.getContentResolver();
2195261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2196261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // Prepare test data
2197261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a1 = ProviderTestUtils.setupAccount("acct1", false, c);
2198261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a1.mNewMessageCount = 1;
2199261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a1.save(c);
2200261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a2 = ProviderTestUtils.setupAccount("acct2", false, c);
2201261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a2.mNewMessageCount = 2;
2202261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a2.save(c);
2203261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a3 = ProviderTestUtils.setupAccount("acct3", false, c);
2204261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a3.mNewMessageCount = 3;
2205261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a3.save(c);
2206261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a4 = ProviderTestUtils.setupAccount("acct4", false, c);
2207261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a4.mNewMessageCount = 4;
2208261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a4.save(c);
2209261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a5 = ProviderTestUtils.setupAccount("acct5", false, c);
2210261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a5.mNewMessageCount = 5;
2211261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a5.save(c);
2212261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2213261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // With ID in URI, no selection
2214261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(ContentUris.withAppendedId(Account.RESET_NEW_MESSAGE_COUNT_URI, a1.mId),
2215261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki                null, null, null);
2216261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
2217261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(2, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
2218261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(3, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
2219261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(4, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
2220261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(5, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
2221261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2222261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // No ID in URI, with selection
2223261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(Account.RESET_NEW_MESSAGE_COUNT_URI, null,
2224261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki                EmailContent.ID_SELECTION, new String[] {Long.toString(a2.mId)});
2225261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
2226261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
2227261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(3, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
2228261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(4, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
2229261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(5, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
2230261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2231261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // With ID, with selection
2232261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(ContentUris.withAppendedId(Account.RESET_NEW_MESSAGE_COUNT_URI, a3.mId), null,
2233261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki                EmailContent.ID_SELECTION, new String[] {Long.toString(a3.mId)});
2234261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
2235261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
2236261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
2237261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(4, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
2238261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(5, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
2239261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2240261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // No ID in URI, no selection
2241261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(Account.RESET_NEW_MESSAGE_COUNT_URI, null, null, null);
2242261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
2243261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
2244261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
2245261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
2246261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
2247261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki    }
2248899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2249899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki    private static Message createMessageWithTimestamp(Context c, Mailbox b, long timestamp) {
2250899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m = ProviderTestUtils.setupMessage("1", b.mAccountKey, b.mId, true, false, c, false,
2251899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki                false);
2252899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        m.mTimeStamp = timestamp;
2253899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        m.save(c);
2254899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        return m;
2255899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki    }
2256899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
22576f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki    public void testMessageGetLatestIncomingMessage() {
2258899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        final Context c = mMockContext;
2259899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2260899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        // Create 2 accounts with a inbox.
2261899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Account a1 = ProviderTestUtils.setupAccount("a1", true, c);
2262899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Account a2 = ProviderTestUtils.setupAccount("a2", true, c);
2263899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2264899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a1.mId, true, c, Mailbox.TYPE_INBOX);
22656f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        Mailbox b1d = ProviderTestUtils.setupMailbox("box1d", a1.mId, true, c, Mailbox.TYPE_DRAFTS);
22666f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        Mailbox b1o = ProviderTestUtils.setupMailbox("box1o", a1.mId, true, c, Mailbox.TYPE_OUTBOX);
22676f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        Mailbox b1s = ProviderTestUtils.setupMailbox("box1s", a1.mId, true, c, Mailbox.TYPE_SENT);
22686f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a2.mId, true, c, Mailbox.TYPE_MAIL);
2269899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2270899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        // Create some messages
2271899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m11 = createMessageWithTimestamp(c, b1, 33);
2272899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m12 = createMessageWithTimestamp(c, b1, 10);
22736f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        Message m13 = createMessageWithTimestamp(c, b1, 1000); // latest incoming
22746f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        Message m1d = createMessageWithTimestamp(c, b1d, 2000);
22756f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        Message m1o = createMessageWithTimestamp(c, b1o, 2000);
22766f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        Message m1s = createMessageWithTimestamp(c, b1s, 2000);
2277899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
22786f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        Message m21 = createMessageWithTimestamp(c, b2, 99); // latest incoming
2279899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m22 = createMessageWithTimestamp(c, b2, 1);
2280899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m23 = createMessageWithTimestamp(c, b2, 2);
2281899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2282899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        // Check!
22836f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        assertEquals(m13.mId, Message.getLatestIncomingMessage(c, a1.mId).mId);
22846f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        assertEquals(m21.mId, Message.getLatestIncomingMessage(c, a2.mId).mId);
2285899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2286899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        // No such account
22876f3d167cfa948d20153c2172c34cbede5ec83a1dMakoto Onuki        assertEquals(null, Message.getLatestIncomingMessage(c, 9999999L));
2288899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki    }
22899d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
22909d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    /**
22919d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     * Check if update on ACCOUNT_ID_ADD_TO_FIELD updates the cache properly.
22929d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     */
22939d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    public void testUpdateCacheAccountIdAddToField() {
22949d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        final Context c = mMockContext;
22959d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("a1", true, c);
22969d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
22979d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        int start = Account.restoreAccountWithId(c, a1.mId).mNewMessageCount;
22989d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
22999d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // +1 to NEW_MESSAGE_COUNT
23009d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        ContentValues cv = new ContentValues();
23019d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        cv.put(EmailContent.FIELD_COLUMN_NAME, AccountColumns.NEW_MESSAGE_COUNT);
23029d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        cv.put(EmailContent.ADD_COLUMN_NAME, 1);
23039d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        mProvider.update(ContentUris.withAppendedId(Account.ADD_TO_FIELD_URI, a1.mId), cv,
23049d5aaeacd6b222877f25924818317c9153708261Makoto Onuki                null, null);
23059d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23069d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Check
23079d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertEquals(start + 1, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
23089d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    }
23099d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23109d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    /**
23119d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     * Check if update on ACCOUNT_RESET_NEW_COUNT updates the cache properly.
23129d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     */
23139d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    public void testUpdateCacheAccountResetNewCount() {
23149d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        final Context c = mMockContext;
23159d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("a1", true, c);
23169d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23179d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // precondition
23189d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertTrue(Account.restoreAccountWithId(c, a1.mId).mNewMessageCount > 0);
23199d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23209d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Reset
23219d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        mProvider.update(Account.RESET_NEW_MESSAGE_COUNT_URI, null, null, null);
23229d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23239d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Check
23249d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
23259d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    }
23269d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23279d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    /**
23289d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     * Check if update on ACCOUNT_RESET_NEW_COUNT_ID updates the cache properly.
23299d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     */
23309d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    public void testUpdateCacheAccountResetNewCountId() {
23319d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        final Context c = mMockContext;
23329d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("a1", true, c);
23339d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23349d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // precondition
23359d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertTrue(Account.restoreAccountWithId(c, a1.mId).mNewMessageCount > 0);
23369d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23379d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Reset
23389d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        mProvider.update(ContentUris.withAppendedId(Account.RESET_NEW_MESSAGE_COUNT_URI, a1.mId),
23399d5aaeacd6b222877f25924818317c9153708261Makoto Onuki                null, null, null);
23409d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23419d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Check
23429d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
23439d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    }
23449d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23459d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    /**
23469d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     * Check if update on MAILBOX_ID_ADD_TO_FIELD updates the cache properly.
23479d5aaeacd6b222877f25924818317c9153708261Makoto Onuki     */
23489d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    public void testUpdateCacheMailboxIdAddToField() {
23499d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        final Context c = mMockContext;
23509d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("a1", true, c);
23519d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a1.mId, true, c, Mailbox.TYPE_INBOX);
23529d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23539d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        int start = Mailbox.restoreMailboxWithId(c, b1.mId).mSyncInterval;
23549d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23559d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // +1 to SYNC_INTERVAL
23569d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        ContentValues cv = new ContentValues();
23579d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        cv.put(EmailContent.FIELD_COLUMN_NAME, MailboxColumns.SYNC_INTERVAL);
23589d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        cv.put(EmailContent.ADD_COLUMN_NAME, 1);
23599d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        mProvider.update(ContentUris.withAppendedId(Mailbox.ADD_TO_FIELD_URI, a1.mId), cv,
23609d5aaeacd6b222877f25924818317c9153708261Makoto Onuki                null, null);
23619d5aaeacd6b222877f25924818317c9153708261Makoto Onuki
23629d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        // Check
23639d5aaeacd6b222877f25924818317c9153708261Makoto Onuki        assertEquals(start + 1, Mailbox.restoreMailboxWithId(c, b1.mId).mSyncInterval);
23649d5aaeacd6b222877f25924818317c9153708261Makoto Onuki    }
2365d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank
2366d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank    /**
2367d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank     * Check that we're handling illegal uri's properly (by throwing an exception unless it's a
2368d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank     * query for an id of -1, in which case we return a zero-length cursor)
2369d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank     */
2370d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank    public void testIllegalUri() {
2371d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        final ContentResolver cr = mMockContext.getContentResolver();
2372d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank
2373d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        ContentValues cv = new ContentValues();
2374d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        Uri uri = Uri.parse("content://" + EmailContent.AUTHORITY + "/fooble");
2375d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        try {
2376d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            cr.insert(uri, cv);
2377d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            fail("Insert should have thrown exception");
2378d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        } catch (IllegalArgumentException e) {
2379d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        }
2380d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        try {
2381d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            cr.update(uri, cv, null, null);
2382d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            fail("Update should have thrown exception");
2383d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        } catch (IllegalArgumentException e) {
2384d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        }
2385d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        try {
2386d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            cr.delete(uri, null, null);
2387d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            fail("Delete should have thrown exception");
2388d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        } catch (IllegalArgumentException e) {
2389d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        }
2390d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        try {
2391d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            cr.query(uri, EmailContent.ID_PROJECTION, null, null, null);
2392d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            fail("Query should have thrown exception");
2393d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        } catch (IllegalArgumentException e) {
2394d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        }
2395d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        uri = Uri.parse("content://" + EmailContent.AUTHORITY + "/mailbox/fred");
2396d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        try {
2397d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            cr.query(uri, EmailContent.ID_PROJECTION, null, null, null);
2398d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank            fail("Query should have thrown exception");
2399d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        } catch (IllegalArgumentException e) {
2400d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        }
2401d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        uri = Uri.parse("content://" + EmailContent.AUTHORITY + "/mailbox/-1");
2402d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        Cursor c = cr.query(uri, EmailContent.ID_PROJECTION, null, null, null);
2403d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        assertNotNull(c);
2404d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        assertEquals(0, c.getCount());
2405d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank        c.close();
2406d306ba34387f3a7e77a4b8d98c6ac45cc14b95adMarc Blank    }
24077143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler}
2408