ProviderTests.java revision 899c5b866192a4c4a12413446d10e5d98dbf94fa
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
19e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blankimport com.android.email.Snippet;
207143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport com.android.email.provider.EmailContent.Account;
219e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadlerimport com.android.email.provider.EmailContent.AccountColumns;
22976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blankimport com.android.email.provider.EmailContent.Attachment;
236c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadlerimport com.android.email.provider.EmailContent.AttachmentColumns;
247143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport com.android.email.provider.EmailContent.Body;
259627d014e16235eadf981b9165807dc72a14a383Mihai Predaimport com.android.email.provider.EmailContent.BodyColumns;
26da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadlerimport com.android.email.provider.EmailContent.HostAuth;
277143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport com.android.email.provider.EmailContent.Mailbox;
2841f775bbc731b25854da9f5a80c66a4aa1eb0af9satokimport com.android.email.provider.EmailContent.MailboxColumns;
297143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport com.android.email.provider.EmailContent.Message;
30ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadlerimport com.android.email.provider.EmailContent.MessageColumns;
317143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
32ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadlerimport android.content.ContentResolver;
337143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport android.content.ContentUris;
34ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadlerimport android.content.ContentValues;
357143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport android.content.Context;
367143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport android.database.Cursor;
37574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onukiimport android.database.sqlite.SQLiteDatabase;
387143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport android.net.Uri;
394a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadlerimport android.os.Bundle;
40976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blankimport android.os.Environment;
414a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadlerimport android.os.Parcel;
42e37881aac562c066e6e666349749e40b7c116a21Makoto Onukiimport android.test.MoreAsserts;
437143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerimport android.test.ProviderTestCase2;
447143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
45758a532fce2f672673d38b2daa5f67eb757b118bMarc Blankimport java.io.File;
46758a532fce2f672673d38b2daa5f67eb757b118bMarc Blankimport java.io.IOException;
47758a532fce2f672673d38b2daa5f67eb757b118bMarc Blankimport java.util.ArrayList;
48758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
497143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler/**
507143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * Tests of the Email provider.
51758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank *
527143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler * You can run this entire test case with:
537143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler *   runtest -c com.android.email.provider.ProviderTests email
54261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki *
55261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * TODO: Add tests for cursor notification mechanism.  (setNotificationUri and notifyChange)
56261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * We can't test the entire notification mechanism with a mock content resolver, because which URI
57261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * to notify when notifyChange() is called is in the actual content resolver.
58261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * Implementing the same mechanism in a mock one is pointless.  Instead what we could do is check
59261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * what notification URI each cursor has, and with which URI is notified when
60261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki * inserting/updating/deleting.  (The former require a new method from AbstractCursor)
617143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler */
627143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadlerpublic class ProviderTests extends ProviderTestCase2<EmailProvider> {
63758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    EmailProvider mProvider;
657143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    Context mMockContext;
667143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
677143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public ProviderTests() {
687143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        super(EmailProvider.class, EmailProvider.EMAIL_AUTHORITY);
697143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
70758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
717143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    @Override
727143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void setUp() throws Exception {
737143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        super.setUp();
747143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext = getMockContext();
757143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
767143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
777143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    @Override
787143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void tearDown() throws Exception {
797143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        super.tearDown();
807143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
817143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
827143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
830d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler     * TODO: Database upgrade tests
840d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler     */
850d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler
860d00889f83fc8c1d69039a2c849b630fb4dd28ddAndrew Stadler    /**
877143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test simple account save/retrieve
887143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
897143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testAccountSave() {
9028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-save", true, mMockContext);
917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
92758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Account account2 = EmailContent.Account.restoreAccountWithId(mMockContext, account1Id);
94758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
9528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertAccountEqual("testAccountSave", account1, account2);
967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
9741f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
984a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler    /**
99da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler     * Test simple account save/retrieve with predefined hostauth records
100da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler     */
101da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler    public void testAccountSaveHostAuth() {
102da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
103da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        // add hostauth data, which should be saved the first time
104da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        account1.mHostAuthRecv = ProviderTestUtils.setupHostAuth("account-hostauth-recv", -1, false,
105da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                mMockContext);
106da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        account1.mHostAuthSend = ProviderTestUtils.setupHostAuth("account-hostauth-send", -1, false,
107da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                mMockContext);
108da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        account1.save(mMockContext);
109da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        long account1Id = account1.mId;
110da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler
111da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        // Confirm account reads back correctly
112da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        Account account1get = EmailContent.Account.restoreAccountWithId(mMockContext, account1Id);
113da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        ProviderTestUtils.assertAccountEqual("testAccountSave", account1, account1get);
114da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler
115da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        // Confirm hostauth fields can be accessed & read back correctly
116da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        HostAuth hostAuth1get = EmailContent.HostAuth.restoreHostAuthWithId(mMockContext,
117da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1get.mHostAuthKeyRecv);
118da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        ProviderTestUtils.assertHostAuthEqual("testAccountSaveHostAuth-recv",
119da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1.mHostAuthRecv, hostAuth1get);
120da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        HostAuth hostAuth2get = EmailContent.HostAuth.restoreHostAuthWithId(mMockContext,
121da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1get.mHostAuthKeySend);
122da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler        ProviderTestUtils.assertHostAuthEqual("testAccountSaveHostAuth-send",
123da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler                account1.mHostAuthSend, hostAuth2get);
124da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler    }
125da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler
126da8836a76cd8a6eaa7e3693eeacc6393870b2066Andrew Stadler    /**
1274a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler     * Simple test of account parceling.  The rather tortuous path is to ensure that the
1284a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler     * account is really flattened all the way down to a parcel and back.
1294a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler     */
1304a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler    public void testAccountParcel() {
1314a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Account account1 = ProviderTestUtils.setupAccount("parcel", false, mMockContext);
1324a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Bundle b = new Bundle();
1334a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        b.putParcelable("account", account1);
1344a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Parcel p = Parcel.obtain();
1354a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        b.writeToParcel(p, 0);
1364a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        p.setDataPosition(0);       // rewind it for reading
1374a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Bundle b2 = new Bundle(Account.class.getClassLoader());
1384a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        b2.readFromParcel(p);
1394a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        Account account2 = (Account) b2.getParcelable("account");
1404a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        p.recycle();
1414a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler
1424a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler        ProviderTestUtils.assertAccountEqual("testAccountParcel", account1, account2);
1434a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler    }
1444a8c70c09be3914ded18031b4cca5a6d867de0d3Andrew Stadler
145e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    /**
146e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki     * Test for {@link Account#getShortcutSafeUri()} and
147e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki     * {@link Account#getAccountIdForShortcutSafeUri}.
148e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki     */
149e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    public void testAccountShortcutSafeUri() {
150e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Account account1 = ProviderTestUtils.setupAccount("account-1", true, mMockContext);
151e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Account account2 = ProviderTestUtils.setupAccount("account-2", true, mMockContext);
152e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final long account1Id = account1.mId;
153e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final long account2Id = account2.mId;
154e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
155e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Uri uri1 = account1.getShortcutSafeUri();
156e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        final Uri uri2 = account2.getShortcutSafeUri();
157e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
158e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        // Check the path part of the URIs.
159e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        MoreAsserts.assertEquals(new String[] {"account", account1.mCompatibilityUuid},
160e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                uri1.getPathSegments().toArray());
161e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        MoreAsserts.assertEquals(new String[] {"account", account2.mCompatibilityUuid},
162e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                uri2.getPathSegments().toArray());
163e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
164e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account1Id, Account.getAccountIdFromShortcutSafeUri(mMockContext, uri1));
165e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account2Id, Account.getAccountIdFromShortcutSafeUri(mMockContext, uri2));
166e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
167e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        // Test for the Eclair(2.0-2.1) style URI.
168e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account1Id, Account.getAccountIdFromShortcutSafeUri(mMockContext,
169e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                getEclairStyleShortcutUri(account1)));
170e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        assertEquals(account2Id, Account.getAccountIdFromShortcutSafeUri(mMockContext,
171e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki                getEclairStyleShortcutUri(account2)));
172e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    }
173e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
174e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    private static Uri getEclairStyleShortcutUri(Account account) {
175e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        // We used _id instead of UUID only on Eclair(2.0-2.1).
176e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki        return Account.CONTENT_URI.buildUpon().appendEncodedPath("" + account.mId).build();
177e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki    }
178e37881aac562c066e6e666349749e40b7c116a21Makoto Onuki
1798d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank    public void testGetProtocol() {
1808d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        Account account1 = ProviderTestUtils.setupAccount("account-hostauth", false, mMockContext);
1818d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // add hostauth data, with protocol
1828d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        account1.mHostAuthRecv = ProviderTestUtils.setupHostAuth("eas", "account-hostauth-recv", -1,
1838d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank                false, mMockContext);
1848d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // Note that getProtocol uses the receive host auth, so the protocol here shouldn't matter
1858d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // to the test result
1868d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        account1.mHostAuthSend = ProviderTestUtils.setupHostAuth("foo", "account-hostauth-send", -1,
1878d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank                false, mMockContext);
1888d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        account1.save(mMockContext);
18925144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        assertEquals("eas", Account.getProtocol(mMockContext, account1.mId));
19025144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        assertEquals("eas", account1.getProtocol(mMockContext));
1918d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        Account account2 = ProviderTestUtils.setupAccount("account-nohostauth", false,
1928d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank                mMockContext);
1938d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        account2.save(mMockContext);
1948d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // Make sure that we return null when there's no host auth
1958d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        assertNull(Account.getProtocol(mMockContext, account2.mId));
1968d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        assertNull(account2.getProtocol(mMockContext));
1978d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        // And when there's no account
1988d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank        assertNull(Account.getProtocol(mMockContext, 0));
1998d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank    }
2008d8f86e899165772a7d91250b98dfc3c0d78b538Marc Blank
201652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki    public void testAccountIsValidId() {
202652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        final Account account1 = ProviderTestUtils.setupAccount("account-1", true, mMockContext);
203652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        final Account account2 = ProviderTestUtils.setupAccount("account-2", true, mMockContext);
204652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki
205652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        assertTrue(Account.isValidId(mMockContext, account1.mId));
206652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        assertTrue(Account.isValidId(mMockContext, account2.mId));
207652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki
208652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki        assertFalse(Account.isValidId(mMockContext, 1234567)); // Some random ID
209c133e6f1858e33fabaa6ffa173c1402bf9a98e31Makoto Onuki        assertFalse(Account.isValidId(mMockContext, -1));
210c133e6f1858e33fabaa6ffa173c1402bf9a98e31Makoto Onuki        assertFalse(Account.isValidId(mMockContext, -500));
211652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki    }
212652be6fb3d04a4ceba6b765cd3160cdaef9e6107Makoto Onuki
21341f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    private final static String[] MAILBOX_UNREAD_COUNT_PROJECTION = new String [] {
21441f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        MailboxColumns.UNREAD_COUNT
21541f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    };
21641f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    private final static int MAILBOX_UNREAD_COUNT_COLMUN = 0;
21741f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
21841f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    /**
21941f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     * Get the value of the unread count in the mailbox of the account.
22041f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     * This can be different from the actual number of unread messages in that mailbox.
22141f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     * @param accountId
22241f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     * @param mailboxId
22341f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     * @return
22441f775bbc731b25854da9f5a80c66a4aa1eb0af9satok     */
22541f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    private int getUnreadCount(long mailboxId) {
22641f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        String text = null;
22741f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        Cursor c = null;
22841f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        try {
22941f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            c = mMockContext.getContentResolver().query(
23041f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    Mailbox.CONTENT_URI,
23141f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    MAILBOX_UNREAD_COUNT_PROJECTION,
23241f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    EmailContent.RECORD_ID + "=?",
23341f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    new String[] { String.valueOf(mailboxId) },
23441f775bbc731b25854da9f5a80c66a4aa1eb0af9satok                    null);
23541f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            c.moveToFirst();
23641f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            text = c.getString(MAILBOX_UNREAD_COUNT_COLMUN);
23741f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        } finally {
23841f775bbc731b25854da9f5a80c66a4aa1eb0af9satok            c.close();
23941f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        }
24041f775bbc731b25854da9f5a80c66a4aa1eb0af9satok        return Integer.valueOf(text);
24141f775bbc731b25854da9f5a80c66a4aa1eb0af9satok    }
24241f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
2437143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
2447143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: HostAuth tests
2457143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
246758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
2477143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
248e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler     * Test the various combinations of SSL, TLS, and trust-certificates encoded as Uris
249e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler     */
250ef83299b99288c00b9d661260d19715e73e6889cMarc Blank    @SuppressWarnings("deprecation")
251e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler    public void testHostAuthSecurityUri() {
252e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        HostAuth ha = ProviderTestUtils.setupHostAuth("uri-security", 1, false, mMockContext);
253e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler
254e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        final int MASK =
255e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler            HostAuth.FLAG_SSL | HostAuth.FLAG_TLS | HostAuth.FLAG_TRUST_ALL_CERTIFICATES;
256e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler
257e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Set various URIs and check the resulting flags
258e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("protocol://user:password@server:123");
259e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(0, ha.mFlags & MASK);
260e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("protocol+ssl+://user:password@server:123");
261e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(HostAuth.FLAG_SSL, ha.mFlags & MASK);
262e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("protocol+ssl+trustallcerts://user:password@server:123");
263e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(HostAuth.FLAG_SSL | HostAuth.FLAG_TRUST_ALL_CERTIFICATES, ha.mFlags & MASK);
264e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("protocol+tls+://user:password@server:123");
265e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(HostAuth.FLAG_TLS, ha.mFlags & MASK);
266e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("protocol+tls+trustallcerts://user:password@server:123");
267e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(HostAuth.FLAG_TLS | HostAuth.FLAG_TRUST_ALL_CERTIFICATES, ha.mFlags & MASK);
268e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler
269e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Now check the retrival method (building URI from flags)
270e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.mFlags &= ~MASK;
271e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        String uriString = ha.getStoreUri();
272e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertTrue(uriString.startsWith("protocol://"));
273e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.mFlags |= HostAuth.FLAG_SSL;
274e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        uriString = ha.getStoreUri();
275e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertTrue(uriString.startsWith("protocol+ssl+://"));
276e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.mFlags |= HostAuth.FLAG_TRUST_ALL_CERTIFICATES;
277e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        uriString = ha.getStoreUri();
278e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertTrue(uriString.startsWith("protocol+ssl+trustallcerts://"));
279e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.mFlags &= ~MASK;
280e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.mFlags |= HostAuth.FLAG_TLS;
281e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        uriString = ha.getStoreUri();
282e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertTrue(uriString.startsWith("protocol+tls+://"));
283e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.mFlags |= HostAuth.FLAG_TRUST_ALL_CERTIFICATES;
284e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        uriString = ha.getStoreUri();
285e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertTrue(uriString.startsWith("protocol+tls+trustallcerts://"));
286e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler    }
287e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler
288e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler    /**
289e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler     * Test port assignments made from Uris
290e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler     */
291ef83299b99288c00b9d661260d19715e73e6889cMarc Blank    @SuppressWarnings("deprecation")
292e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler    public void testHostAuthPortAssignments() {
293e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        HostAuth ha = ProviderTestUtils.setupHostAuth("uri-port", 1, false, mMockContext);
294e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler
295e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Set various URIs and check the resulting flags
296e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Hardwired port
297e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("imap://user:password@server:123");
298e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(123, ha.mPort);
299e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Auto-assigned ports
300e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("imap://user:password@server");
301e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(143, ha.mPort);
302e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("imap+ssl://user:password@server");
303e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(993, ha.mPort);
304e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("imap+ssl+trustallcerts://user:password@server");
305e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(993, ha.mPort);
306e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("imap+tls://user:password@server");
307e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(143, ha.mPort);
308e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("imap+tls+trustallcerts://user:password@server");
309e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(143, ha.mPort);
310e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler
311e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Hardwired port
312e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("pop3://user:password@server:123");
313e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(123, ha.mPort);
314e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Auto-assigned ports
315e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("pop3://user:password@server");
316e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(110, ha.mPort);
317e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("pop3+ssl://user:password@server");
318e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(995, ha.mPort);
319e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("pop3+ssl+trustallcerts://user:password@server");
320e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(995, ha.mPort);
321e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("pop3+tls://user:password@server");
322e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(110, ha.mPort);
323e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("pop3+tls+trustallcerts://user:password@server");
324e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(110, ha.mPort);
325e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler
326e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Hardwired port
327e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("eas://user:password@server:123");
328e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(123, ha.mPort);
329e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Auto-assigned ports
330e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("eas://user:password@server");
331e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(80, ha.mPort);
332e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("eas+ssl://user:password@server");
333e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(443, ha.mPort);
334e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("eas+ssl+trustallcerts://user:password@server");
335e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(443, ha.mPort);
336e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler
337e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Hardwired port
338e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("smtp://user:password@server:123");
339e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(123, ha.mPort);
340e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        // Auto-assigned ports
341e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("smtp://user:password@server");
342e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(587, ha.mPort);
343e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("smtp+ssl://user:password@server");
344e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(465, ha.mPort);
345e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("smtp+ssl+trustallcerts://user:password@server");
346e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(465, ha.mPort);
347e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("smtp+tls://user:password@server");
348e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(587, ha.mPort);
349e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        ha.setStoreUri("smtp+tls+trustallcerts://user:password@server");
350e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler        assertEquals(587, ha.mPort);
351e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler    }
352e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler
353e4a7cc440f081ef9c4375a2bd2f82680cc11b152Andrew Stadler    /**
3547143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test simple mailbox save/retrieve
3557143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
3567143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testMailboxSave() {
35728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("mailbox-save", true, mMockContext);
3587143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
35928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true,
36028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
3617143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
362758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
3637143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Mailbox box2 = EmailContent.Mailbox.restoreMailboxWithId(mMockContext, box1Id);
364758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
36528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertMailboxEqual("testMailboxSave", box1, box2);
3667143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
367758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
3684119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    private static String[] expectedAttachmentNames =
369976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        new String[] {"attachment1.doc", "attachment2.xls", "attachment3"};
370976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    // The lengths need to be kept in ascending order
3714119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    private static long[] expectedAttachmentSizes = new long[] {31415L, 97701L, 151213L};
372976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank
373fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    /*
374fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * Returns null if the message has no body.
375fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     */
376fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    private Body loadBodyForMessageId(long messageId) {
377fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Cursor c = null;
378fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        try {
379fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            c = mMockContext.getContentResolver().query(
380fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    EmailContent.Body.CONTENT_URI,
381fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    EmailContent.Body.CONTENT_PROJECTION,
382fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    EmailContent.Body.MESSAGE_KEY + "=?",
383fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    new String[] {String.valueOf(messageId)},
384fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                    null);
385fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            int numBodies = c.getCount();
386fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            assertTrue("at most one body", numBodies < 2);
387fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            return c.moveToFirst() ? EmailContent.getContent(c, Body.class) : null;
388fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        } finally {
389fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda            c.close();
390fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        }
391fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    }
392fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
3937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
3947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test simple message save/retrieve
395758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank     *
3967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: serverId vs. serverIntId
3977143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
3987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testMessageSave() {
39928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-save", true, mMockContext);
4007143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
40128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
4027143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
4037143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
4047143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Test a simple message (saved with no body)
40528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
40628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
4077143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message1Id = message1.mId;
4087143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Message message1get = EmailContent.Message.restoreMessageWithId(mMockContext, message1Id);
40928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertMessageEqual("testMessageSave", message1, message1get);
4107143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
4117143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Test a message saved with a body
4127143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Note that it will read back w/o the text & html so we must extract those
41328448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
41428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
4157143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message2Id = message2.mId;
4167143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String text2 = message2.mText;
4177143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String html2 = message2.mHtml;
418936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        String textReply2 = message2.mTextReply;
419936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        String htmlReply2 = message2.mHtmlReply;
4206c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long sourceKey2 = message2.mSourceKey;
4215fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        String introText2 = message2.mIntroText;
4227143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        message2.mText = null;
4237143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        message2.mHtml = null;
424936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        message2.mTextReply = null;
425936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        message2.mHtmlReply = null;
426e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        message2.mSourceKey = 0;
4275fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        message2.mIntroText = null;
4287143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Message message2get = EmailContent.Message.restoreMessageWithId(mMockContext, message2Id);
42928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        ProviderTestUtils.assertMessageEqual("testMessageSave", message2, message2get);
430758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
4317143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // Now see if there's a body saved with the right stuff
432fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Body body2 = loadBodyForMessageId(message2Id);
433fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertEquals("body text", text2, body2.mTextContent);
434fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertEquals("body html", html2, body2.mHtmlContent);
435936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals("reply text", textReply2, body2.mTextReply);
436936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals("reply html", htmlReply2, body2.mHtmlReply);
4376c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals("source key", sourceKey2, body2.mSourceKey);
4385fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        assertEquals("intro text", introText2, body2.mIntroText);
439976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank
4404119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Message with attachments and body
441976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        Message message3 = ProviderTestUtils.setupMessage("message3", account1Id, box1Id, true,
442976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                false, mMockContext);
443976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        ArrayList<Attachment> atts = new ArrayList<Attachment>();
444976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        for (int i = 0; i < 3; i++) {
4454119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
4464119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
4474119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    false, mMockContext));
448976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        }
449976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        message3.mAttachments = atts;
4509e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        message3.save(mMockContext);
451976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        long message3Id = message3.mId;
452976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank
453976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        // Now check the attachments; there should be three and they should match name and size
454fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Cursor c = null;
455976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        try {
456976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // Note that there is NO guarantee of the order of returned records in the general case,
457976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // so we specifically ask for ordering by size.  The expectedAttachmentSizes array must
458976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // be kept sorted by size (ascending) for this test to work properly
459976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            c = mMockContext.getContentResolver().query(
460976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.CONTENT_URI,
461976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.CONTENT_PROJECTION,
462976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.MESSAGE_KEY + "=?",
463976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    new String[] {
464976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                            String.valueOf(message3Id)
465976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    },
466976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    Attachment.SIZE);
467976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            int numAtts = c.getCount();
468976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            assertEquals(3, numAtts);
469976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            int i = 0;
470976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            while (c.moveToNext()) {
4714119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                Attachment actual = EmailContent.getContent(c, Attachment.class);
4724119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                ProviderTestUtils.assertAttachmentEqual("save-message3", atts.get(i), actual);
4734119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                i++;
4744119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            }
4754119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        } finally {
4764119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.close();
4774119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        }
4784119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
4794119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Message with attachments but no body
4804119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Message message4 = ProviderTestUtils.setupMessage("message4", account1Id, box1Id, false,
4814119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                false, mMockContext);
4824119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        atts = new ArrayList<Attachment>();
4834119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        for (int i = 0; i < 3; i++) {
4844119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
4854119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
4864119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    false, mMockContext));
4874119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        }
4884119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        message4.mAttachments = atts;
4899e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        message4.save(mMockContext);
4904119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        long message4Id = message4.mId;
4914119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
4924119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Now check the attachments; there should be three and they should match name and size
4934119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        c = null;
49441f775bbc731b25854da9f5a80c66a4aa1eb0af9satok
4954119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        try {
4964119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            // Note that there is NO guarantee of the order of returned records in the general case,
4974119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            // so we specifically ask for ordering by size.  The expectedAttachmentSizes array must
4984119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            // be kept sorted by size (ascending) for this test to work properly
4994119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c = mMockContext.getContentResolver().query(
5004119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.CONTENT_URI,
5014119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.CONTENT_PROJECTION,
5024119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.MESSAGE_KEY + "=?",
5034119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    new String[] {
5044119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                            String.valueOf(message4Id)
5054119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    },
5064119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                    Attachment.SIZE);
5074119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            int numAtts = c.getCount();
5084119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            assertEquals(3, numAtts);
5094119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            int i = 0;
5104119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            while (c.moveToNext()) {
5114119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                Attachment actual = EmailContent.getContent(c, Attachment.class);
5124119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                ProviderTestUtils.assertAttachmentEqual("save-message4", atts.get(i), actual);
513976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                i++;
514976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            }
515976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        } finally {
516976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            c.close();
5177143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        }
51844144d0301213536b02f2080237b63d8271b2d0bMihai Preda
51944144d0301213536b02f2080237b63d8271b2d0bMihai Preda        // test EmailContent.restoreAttachmentsWitdMessageId()
52044144d0301213536b02f2080237b63d8271b2d0bMihai Preda        Attachment[] attachments =
52144144d0301213536b02f2080237b63d8271b2d0bMihai Preda            Attachment.restoreAttachmentsWithMessageId(mMockContext, message4Id);
52244144d0301213536b02f2080237b63d8271b2d0bMihai Preda        int size = attachments.length;
52344144d0301213536b02f2080237b63d8271b2d0bMihai Preda        assertEquals(3, size);
52444144d0301213536b02f2080237b63d8271b2d0bMihai Preda        for (int i = 0; i < size; ++i) {
52544144d0301213536b02f2080237b63d8271b2d0bMihai Preda            ProviderTestUtils.assertAttachmentEqual("save-message4", atts.get(i), attachments[i]);
52644144d0301213536b02f2080237b63d8271b2d0bMihai Preda        }
5277143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
528758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5297143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
530e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank     * Test that saving a message creates the proper snippet for that message
531e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank     */
532e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank    public void testMessageSaveAddsSnippet() {
533e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Account account = ProviderTestUtils.setupAccount("message-snippet", true, mMockContext);
534e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Mailbox box = ProviderTestUtils.setupMailbox("box1", account.mId, true, mMockContext);
535e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank
536e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // Create a message without a body, unsaved
537e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Message message = ProviderTestUtils.setupMessage("message", account.mId, box.mId, false,
538e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank                false, mMockContext);
539e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mText = "This is some text";
540e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mHtml = "<html>This is some text</html>";
541e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.save(mMockContext);
542e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        Message restoredMessage = Message.restoreMessageWithId(mMockContext, message.mId);
543e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // We should have the plain text as the snippet
544e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        assertEquals(restoredMessage.mSnippet, Snippet.fromPlainText(message.mText));
545e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank
546e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // Start again
547e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message = ProviderTestUtils.setupMessage("message", account.mId, box.mId, false,
548e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank                false, mMockContext);
549e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mText = null;
550e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.mHtml = "<html>This is some text</html>";
551e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        message.save(mMockContext);
552e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        restoredMessage = Message.restoreMessageWithId(mMockContext, message.mId);
553e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        // We should have the plain text as the snippet
554e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank        assertEquals(restoredMessage.mSnippet, Snippet.fromHtmlText(message.mHtml));
555e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank    }
556e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank
557e7b9e4ab94093127002f4cddd3ffcc3deb1c0b41Marc Blank    /**
5587143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: update account
5597143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
560758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5617143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5627143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: update mailbox
5637143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
564758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5657143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5667143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: update message
5677143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
568758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
5697143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
5707143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test delete account
5717143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: hostauth
5727143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
5737143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testAccountDelete() {
57428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-delete-1", true, mMockContext);
5757143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
57628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account2 = ProviderTestUtils.setupAccount("account-delete-2", true, mMockContext);
5777143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account2Id = account2.mId;
5787143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5797143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are two accounts
5807143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numBoxes = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
5817143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numBoxes);
5827143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5837143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete one of them
5847143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Account.CONTENT_URI, account1Id);
5857143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
5867143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5877143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there's only one account now
5887143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
5897143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numBoxes);
5907143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the other one
5927143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        uri = ContentUris.withAppendedId(Account.CONTENT_URI, account2Id);
5937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
5947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
5957143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no accounts now
5967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
5977143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numBoxes);
5987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
599758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
6007143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
6019627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Test for Body.lookupBodyIdWithMessageId()
6029627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Verifies that:
6039627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * - for a message without body, -1 is returned.
6049627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * - for a mesage with body, the id matches the one from loadBodyForMessageId.
6059627d014e16235eadf981b9165807dc72a14a383Mihai Preda     */
6069627d014e16235eadf981b9165807dc72a14a383Mihai Preda    public void testLookupBodyIdWithMessageId() {
6079627d014e16235eadf981b9165807dc72a14a383Mihai Preda        final ContentResolver resolver = mMockContext.getContentResolver();
6089627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
6099627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long account1Id = account1.mId;
6109627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
6119627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long box1Id = box1.mId;
6129627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6139627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 1. create message with no body, check that returned bodyId is -1
6149627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
6159627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
6169627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message1Id = message1.mId;
617bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        long bodyId1 = Body.lookupBodyIdWithMessageId(mMockContext, message1Id);
6189627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(bodyId1, -1);
6199627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6209627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 2. create message with body, check that returned bodyId is correct
6219627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
6229627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
6239627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message2Id = message2.mId;
624bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        long bodyId2 = Body.lookupBodyIdWithMessageId(mMockContext, message2Id);
6259627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body body = loadBodyForMessageId(message2Id);
6269627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body);
6279627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(body.mId, bodyId2);
6289627d014e16235eadf981b9165807dc72a14a383Mihai Preda    }
6299627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6309627d014e16235eadf981b9165807dc72a14a383Mihai Preda    /**
6319627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Test for Body.updateBodyWithMessageId().
6329627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * 1. - create message without body,
6339627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - update its body (set TEXT_CONTENT)
6349627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - check correct updated body is read back
6359627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *
6369627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * 2. - create message with body,
6379627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - update body (set TEXT_CONTENT)
6389627d014e16235eadf981b9165807dc72a14a383Mihai Preda     *    - check correct updated body is read back
6399627d014e16235eadf981b9165807dc72a14a383Mihai Preda     */
6409627d014e16235eadf981b9165807dc72a14a383Mihai Preda    public void testUpdateBodyWithMessageId() {
6419627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
6429627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long account1Id = account1.mId;
6439627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
6449627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long box1Id = box1.mId;
6459627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6469627d014e16235eadf981b9165807dc72a14a383Mihai Preda        final String textContent = "foobar some odd text";
647936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        final String htmlContent = "and some html";
648936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        final String textReply = "plain text reply";
649936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        final String htmlReply = "or the html reply";
6505fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        final String introText = "fred wrote:";
6519627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6529627d014e16235eadf981b9165807dc72a14a383Mihai Preda        ContentValues values = new ContentValues();
6539627d014e16235eadf981b9165807dc72a14a383Mihai Preda        values.put(BodyColumns.TEXT_CONTENT, textContent);
654936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        values.put(BodyColumns.HTML_CONTENT, htmlContent);
655936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        values.put(BodyColumns.TEXT_REPLY, textReply);
656936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        values.put(BodyColumns.HTML_REPLY, htmlReply);
657e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        values.put(BodyColumns.SOURCE_MESSAGE_KEY, 17);
6585fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        values.put(BodyColumns.INTRO_TEXT, introText);
6599627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6609627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 1
6619627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
6629627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
6639627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message1Id = message1.mId;
6649627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body body1 = loadBodyForMessageId(message1Id);
6659627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNull(body1);
6669627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body.updateBodyWithMessageId(mMockContext, message1Id, values);
6679627d014e16235eadf981b9165807dc72a14a383Mihai Preda        body1 = loadBodyForMessageId(message1Id);
6689627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body1);
6699627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(body1.mTextContent, textContent);
670936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body1.mHtmlContent, htmlContent);
671936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body1.mTextReply, textReply);
672936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body1.mHtmlReply, htmlReply);
673e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        assertEquals(body1.mSourceKey, 17);
6745fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        assertEquals(body1.mIntroText, introText);
6759627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6769627d014e16235eadf981b9165807dc72a14a383Mihai Preda        // 2
6779627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
6789627d014e16235eadf981b9165807dc72a14a383Mihai Preda                true, mMockContext);
6799627d014e16235eadf981b9165807dc72a14a383Mihai Preda        long message2Id = message2.mId;
6809627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body body2 = loadBodyForMessageId(message2Id);
6819627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body2);
6829627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertTrue(!body2.mTextContent.equals(textContent));
6839627d014e16235eadf981b9165807dc72a14a383Mihai Preda        Body.updateBodyWithMessageId(mMockContext, message2Id, values);
6849627d014e16235eadf981b9165807dc72a14a383Mihai Preda        body2 = loadBodyForMessageId(message1Id);
6859627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertNotNull(body2);
6869627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(body2.mTextContent, textContent);
687936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body2.mHtmlContent, htmlContent);
688936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body2.mTextReply, textReply);
689936babc145e2e6eb2e222f2ce5e3da8f9e4fb9f2Andrew Stadler        assertEquals(body2.mHtmlReply, htmlReply);
690e25698319325d5e9619bc45ae85d861b0f1c5954Marc Blank        assertEquals(body2.mSourceKey, 17);
6915fc57eccefeba517fe5e6f093786f37c6c4d50e6Marc Blank        assertEquals(body2.mIntroText, introText);
6929627d014e16235eadf981b9165807dc72a14a383Mihai Preda    }
6939627d014e16235eadf981b9165807dc72a14a383Mihai Preda
6949627d014e16235eadf981b9165807dc72a14a383Mihai Preda    /**
695c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler     * Test body retrieve methods
696c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler     */
697c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler    public void testBodyRetrieve() {
698c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        // No account needed
699c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        // No mailbox needed
700c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        Message message1 = ProviderTestUtils.setupMessage("bodyretrieve", 1, 1, true,
701c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                true, mMockContext);
702c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        long messageId = message1.mId;
703c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler
704c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mText,
705c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreBodyTextWithMessageId(mMockContext, messageId));
706c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mHtml,
707c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreBodyHtmlWithMessageId(mMockContext, messageId));
708c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mTextReply,
709c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreReplyTextWithMessageId(mMockContext, messageId));
710c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mHtmlReply,
711c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreReplyHtmlWithMessageId(mMockContext, messageId));
712c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler        assertEquals(message1.mIntroText,
713c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler                Body.restoreIntroTextWithMessageId(mMockContext, messageId));
7141575e7860d2259f1aed201ab23d526cddf787365Mihai Preda        assertEquals(message1.mSourceKey,
7151575e7860d2259f1aed201ab23d526cddf787365Mihai Preda                Body.restoreBodySourceKey(mMockContext, messageId));
716c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler    }
717c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler
718c41c47fa07a22f8a7612fb0191f152a36d95b7a5Andrew Stadler    /**
719fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * Test delete body.
720fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 1. create message without body (message id 1)
721fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 2. create message with body (message id 2. The body has _id 1 and messageKey 2).
722fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 3. delete first message.
723fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 4. verify that body for message 2 has not been deleted.
724fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 5. delete message 2, verify body is deleted.
725fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     */
726fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    public void testDeleteBody() {
727fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        final ContentResolver resolver = mMockContext.getContentResolver();
728fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
729fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // Create account and mailboxes
730fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
731fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long account1Id = account1.mId;
732fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
733fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long box1Id = box1.mId;
734fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
735fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 1. create message without body
736fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
737fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
738fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message1Id = message1.mId;
739fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
740fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 2. create message with body
741fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
742fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
743fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message2Id = message2.mId;
744fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // verify body is there
745fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
746fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
747fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 3. delete first message
748fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Message.CONTENT_URI, message1Id), null, null);
749c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank
750fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 4. verify body for second message wasn't deleted
751fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
752fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
753fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 5. delete second message, check its body is deleted
754fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Message.CONTENT_URI, message2Id), null, null);
755fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNull(loadBodyForMessageId(message2Id));
756fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    }
757fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
758fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    /**
759fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * Test delete orphan bodies.
760fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 1. create message without body (message id 1)
761fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 2. create message with body (message id 2. Body has _id 1 and messageKey 2).
762fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 3. delete first message.
763fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 4. delete some other mailbox -- this triggers delete orphan bodies.
764fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     * 5. verify that body for message 2 has not been deleted.
765fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda     */
766fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    public void testDeleteOrphanBodies() {
767fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        final ContentResolver resolver = mMockContext.getContentResolver();
768fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
769ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create account and two mailboxes
770fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Account account1 = ProviderTestUtils.setupAccount("orphaned body", true, mMockContext);
771fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long account1Id = account1.mId;
772fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
773fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long box1Id = box1.mId;
774fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", account1Id, true, mMockContext);
775fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long box2Id = box2.mId;
776fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
777fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 1. create message without body
778fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
779fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
780fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message1Id = message1.mId;
781fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
782fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 2. create message with body
783fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        Message message2 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
784fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda                true, mMockContext);
785fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        long message2Id = message2.mId;
786fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        //verify body is there
787fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
788fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
789fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 3. delete first message
790fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Message.CONTENT_URI, message1Id), null, null);
791fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
792fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 4. delete some mailbox (because it triggers "delete orphan bodies")
793fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        resolver.delete(ContentUris.withAppendedId(Mailbox.CONTENT_URI, box2Id), null, null);
794fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
795fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        // 5. verify body for second message wasn't deleted during "delete orphan bodies"
796fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda        assertNotNull(loadBodyForMessageId(message2Id));
797fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    }
798fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda
799fb7974f5bfb6275fb856b0f7ff386ef10680c83aMihai Preda    /**
8000efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     * Note that we can't use EmailContent.count() here because it uses a projection including
8010efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     * count(*), and count(*) is incompatible with a LIMIT (i.e. the limit would be applied to the
8020efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     * single column returned with count(*), rather than to the query itself)
8030efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank     */
8040efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    private int count(Context context, Uri uri, String selection, String[] selectionArgs) {
8050efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Cursor c = context.getContentResolver().query(uri, EmailContent.ID_PROJECTION, selection,
8060efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                selectionArgs, null);
8070efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        try {
8080efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank            return c.getCount();
8090efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        } finally {
8100efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank            c.close();
8110efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        }
8120efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    }
8130efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8140efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    public void testMessageQueryWithLimit() {
8150efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        final Context context = mMockContext;
8160efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8170efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Create account and two mailboxes
8180efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Account acct = ProviderTestUtils.setupAccount("orphaned body", true, context);
8190efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
8200efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", acct.mId, true, context);
8210efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8220efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Create 4 messages in box1
8230efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, false, true, context);
8240efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, false, true, context);
8250efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, false, true, context);
8260efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, false, true, context);
8270efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8280efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Create 4 messages in box2
8290efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box2.mId, false, true, context);
8300efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box2.mId, false, true, context);
8310efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box2.mId, false, true, context);
8320efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box2.mId, false, true, context);
8330efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8340efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Check normal case, special case (limit 1), and arbitrary limits
8350efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(8, count(mMockContext, Message.CONTENT_URI, null, null));
8360efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(1, count(mMockContext, EmailContent.uriWithLimit(Message.CONTENT_URI, 1),
8370efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                null, null));
8380efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(3, count(mMockContext, EmailContent.uriWithLimit(Message.CONTENT_URI, 3),
8390efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                null, null));
8400efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(8, count(mMockContext, EmailContent.uriWithLimit(Message.CONTENT_URI, 100),
8410efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                null, null));
8420efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8430efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        // Check that it works with selection/selection args
8440efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        String[] args = new String[] {Long.toString(box1.mId)};
8450efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(4, count(mMockContext, Message.CONTENT_URI,
8460efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                MessageColumns.MAILBOX_KEY + "=?", args));
8470efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank        assertEquals(1, count(mMockContext,
8480efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                EmailContent.uriWithLimit(Message.CONTENT_URI, 1),
8490efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank                MessageColumns.MAILBOX_KEY + "=?", args));
8500efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    }
8510efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank
8520efe738e05a31e0c1ebfba645bd2364a373a3f33Marc Blank    /**
853ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * Test delete orphan messages
854ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 1. create message without body (message id 1)
855ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 2. create message with body (message id 2. Body has _id 1 and messageKey 2).
856ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 3. delete first message.
857ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 4. delete some other mailbox -- this triggers delete orphan bodies.
858ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     * 5. verify that body for message 2 has not been deleted.
859ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     */
860ef83299b99288c00b9d661260d19715e73e6889cMarc Blank     public void testDeleteOrphanMessages() {
861ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        final ContentResolver resolver = mMockContext.getContentResolver();
862ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        final Context context = mMockContext;
863ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
864ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create account and two mailboxes
865ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Account acct = ProviderTestUtils.setupAccount("orphaned body", true, context);
866ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
867ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", acct.mId, true, context);
868ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
869ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create 4 messages in box1
870ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_1 =
871ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, false, true, context);
872ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_2 =
873ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, false, true, context);
874ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_3 =
875ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, false, true, context);
876ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg1_4 =
877ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, false, true, context);
878ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
879ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create 4 messages in box2
880ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_1 =
881ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message1", acct.mId, box2.mId, false, true, context);
882ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_2 =
883ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message2", acct.mId, box2.mId, false, true, context);
884ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_3 =
885ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message3", acct.mId, box2.mId, false, true, context);
886ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msg2_4 =
887ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("message4", acct.mId, box2.mId, false, true, context);
888ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
889ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Delete 2 from each mailbox
890ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_1.mId),
891ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
892ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_2.mId),
893ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
894ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_1.mId),
895ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
896ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_2.mId),
897ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
898ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
899ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should be 4 items in the deleted item table
900ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.DELETED_CONTENT_URI, null, null));
901ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
902ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Update 2 from each mailbox
903ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentValues v = new ContentValues();
904ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        v.put(MessageColumns.DISPLAY_NAME, "--updated--");
905ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_3.mId),
906ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
907ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg1_4.mId),
908ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
909ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_3.mId),
910ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
911ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, msg2_4.mId),
912ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                v, null, null);
913ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
914ef83299b99288c00b9d661260d19715e73e6889cMarc Blank         // There should be 4 items in the updated item table
915ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.UPDATED_CONTENT_URI, null, null));
916ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
917ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Manually add 2 messages from a "deleted" mailbox to deleted and updated tables
918ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Use a value > 2 for the deleted box id
919ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        long delBoxId = 10;
920ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Create 4 messages in the "deleted" mailbox
921ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_A =
922ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageA", acct.mId, delBoxId, false, false, context);
923ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_B =
924ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageB", acct.mId, delBoxId, false, false, context);
925ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_C =
926ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageC", acct.mId, delBoxId, false, false, context);
927ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message msgX_D =
928ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            ProviderTestUtils.setupMessage("messageD", acct.mId, delBoxId, false, false, context);
929ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
930ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentValues cv;
931ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // We have to assign id's manually because there are no autoincrement id's for these tables
932ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Start with an id that won't exist, since id's in these tables must be unique
933ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        long msgId = 10;
934ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // It's illegal to manually insert these, so we need to catch the exception
935ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // NOTE: The insert succeeds, and then throws the exception
936ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
937ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_A.toContentValues();
938ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
939ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.DELETED_CONTENT_URI, cv);
940ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
941ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
942ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
943ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_B.toContentValues();
944ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
945ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.DELETED_CONTENT_URI, cv);
946ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
947ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
948ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
949ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_C.toContentValues();
950ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
951ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.UPDATED_CONTENT_URI, cv);
952ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
953ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
954ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        try {
955ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv = msgX_D.toContentValues();
956ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            cv.put(EmailContent.RECORD_ID, msgId++);
957ef83299b99288c00b9d661260d19715e73e6889cMarc Blank            resolver.insert(Message.UPDATED_CONTENT_URI, cv);
958ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        } catch (IllegalArgumentException e) {
959ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        }
960ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
961ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should be 6 items in the deleted and updated tables
962ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(6, EmailContent.count(context, Message.UPDATED_CONTENT_URI, null, null));
963ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(6, EmailContent.count(context, Message.DELETED_CONTENT_URI, null, null));
964ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
965ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Delete the orphans
966ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        EmailProvider.deleteOrphans(EmailProvider.getReadableDatabase(context),
967ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                Message.DELETED_TABLE_NAME);
968ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        EmailProvider.deleteOrphans(EmailProvider.getReadableDatabase(context),
969ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                Message.UPDATED_TABLE_NAME);
970ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
971ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should now be 4 messages in each of the deleted and updated tables again
972ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.UPDATED_CONTENT_URI, null, null));
973ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, EmailContent.count(context, Message.DELETED_CONTENT_URI, null, null));
974ef83299b99288c00b9d661260d19715e73e6889cMarc Blank    }
975ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
976ef83299b99288c00b9d661260d19715e73e6889cMarc Blank    /**
9777143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test delete mailbox
9787143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
9797143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testMailboxDelete() {
98028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("mailbox-delete", true, mMockContext);
9817143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
98228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
9837143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
98428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box2 = ProviderTestUtils.setupMailbox("box2", account1Id, true, mMockContext);
9857143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box2Id = box2.mId;
986758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
9877143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String selection = EmailContent.MailboxColumns.ACCOUNT_KEY + "=?";
9887143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String[] selArgs = new String[] { String.valueOf(account1Id) };
9897143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9907143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are two mailboxes
9917143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, selection, selArgs);
9927143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numBoxes);
9937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9947143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete one of them
9957143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Mailbox.CONTENT_URI, box1Id);
9967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
9977143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
9987143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there's only one mailbox now
9997143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, selection, selArgs);
10007143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numBoxes);
10017143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10027143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the other one
10037143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        uri = ContentUris.withAppendedId(Mailbox.CONTENT_URI, box2Id);
10047143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
10057143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10067143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no mailboxes now
10077143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, selection, selArgs);
10087143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numBoxes);
10097143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
1010758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
10117143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
10127143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test delete message
10137143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: body
10147143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: attachments
10157143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
10167143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testMessageDelete() {
101728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-delete", true, mMockContext);
10187143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
101928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
10207143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
102128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
102228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
10237143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message1Id = message1.mId;
102428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, false,
102528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
10267143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long message2Id = message2.mId;
10277143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10287143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND " +
10297143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler                EmailContent.MessageColumns.MAILBOX_KEY + "=?";
10307143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String[] selArgs = new String[] { String.valueOf(account1Id), String.valueOf(box1Id) };
10317143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10327143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are two messages
10337143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
10347143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numMessages);
10357143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10367143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete one of them
10377143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1Id);
10387143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
10397143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10407143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there's only one message now
10417143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
10427143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numMessages);
10437143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10447143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the other one
10457143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        uri = ContentUris.withAppendedId(Message.CONTENT_URI, message2Id);
10467143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
10477143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
10487143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no messages now
10497143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
10507143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numMessages);
10517143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
1052758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
10537143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
1054ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * Test delete synced message
1055ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: body
1056ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: attachments
1057ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     */
1058ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    public void testSyncedMessageDelete() {
105928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("synced-message-delete", true,
106028448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
1061ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long account1Id = account1.mId;
106228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
1063ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long box1Id = box1.mId;
106428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
106528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1066ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message1Id = message1.mId;
106728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, false,
106828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1069ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message2Id = message2.mId;
1070ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1071ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND "
1072ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                + EmailContent.MessageColumns.MAILBOX_KEY + "=?";
1073ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String[] selArgs = new String[] {
1074ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            String.valueOf(account1Id), String.valueOf(box1Id)
1075ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        };
1076ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1077ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there are two messages
1078ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1079ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(2, numMessages);
1080ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1081ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure we start with no synced deletions
1082ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1083ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1084ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1085ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1086ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // now delete one of them SYNCED
1087ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Uri uri = ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message1Id);
1088ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
1089ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1090ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's only one message now
1091ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1092ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1093ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1094ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's one synced deletion now
1095ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1096ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1097ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1098ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1099ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // now delete the other one NOT SYNCED
1100ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        uri = ContentUris.withAppendedId(Message.CONTENT_URI, message2Id);
1101ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
1102ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1103ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there are no messages now
1104ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1105ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1106ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1107ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's still one deletion now
1108ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1109ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1110ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1111ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    }
1112ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1113ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    /**
1114ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * Test message update
1115ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: body
1116ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     * TODO: attachments
1117ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler     */
1118ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    public void testMessageUpdate() {
111928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-update", true, mMockContext);
1120ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long account1Id = account1.mId;
112128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
1122ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long box1Id = box1.mId;
112328448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, false,
112428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1125ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message1Id = message1.mId;
112628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, false,
112728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                true, mMockContext);
1128ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        long message2Id = message2.mId;
1129ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        ContentResolver cr = mMockContext.getContentResolver();
1130ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1131ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND "
1132ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                + EmailContent.MessageColumns.MAILBOX_KEY + "=?";
1133ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        String[] selArgs = new String[] {
1134ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            String.valueOf(account1Id), String.valueOf(box1Id)
1135ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        };
1136ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1137ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there are two messages
1138ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1139ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(2, numMessages);
1140ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1141ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // change the first one
1142ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1Id);
1143ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        ContentValues cv = new ContentValues();
1144ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cv.put(MessageColumns.FROM_LIST, "from-list");
1145ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cr.update(uri, cv, null, null);
1146ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1147ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's no updated message
1148ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1149ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1150ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1151ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1152ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // get the message back from the provider, make sure the change "stuck"
1153ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Message restoredMessage = Message.restoreMessageWithId(mMockContext, message1Id);
1154ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals("from-list", restoredMessage.mFrom);
1155ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1156ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // change the second one
1157ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        uri = ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message2Id);
1158ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cv = new ContentValues();
1159ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cv.put(MessageColumns.FROM_LIST, "from-list");
1160ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cr.update(uri, cv, null, null);
1161ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1162ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // make sure there's one updated message
1163ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1164ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1165ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1166ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1167ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // get the message back from the provider, make sure the change "stuck",
1168ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // as before
1169ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        restoredMessage = Message.restoreMessageWithId(mMockContext, message2Id);
1170ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals("from-list", restoredMessage.mFrom);
1171ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1172ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // get the original message back from the provider
1173ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        Cursor c = cr.query(Message.UPDATED_CONTENT_URI, Message.CONTENT_PROJECTION, null, null,
1174ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                null);
1175ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        try {
1176ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            assertTrue(c.moveToFirst());
1177ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            Message originalMessage = EmailContent.getContent(c, Message.class);
1178ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            // make sure this has the original value
1179ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            assertEquals("from message2", originalMessage.mFrom);
1180ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            // Should only be one
1181ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            assertFalse(c.moveToNext());
1182ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        } finally {
1183ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler            c.close();
1184ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        }
1185ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1186ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // delete the second message
1187ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        cr.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message2Id), null, null);
1188ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1189ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // hey, presto! the change should be gone
1190ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1191ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1192ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(0, numMessages);
1193ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1194ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        // and there should now be a deleted record
1195ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1196ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler                selArgs);
1197ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler        assertEquals(1, numMessages);
1198ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    }
1199ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler
1200ddc871d9eddd088c0200a30dbfeb24812a81cf80Andrew Stadler    /**
12017143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: cascaded delete account
12027143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: hostauth
12037143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: body
12047143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: attachments
12057143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: create other account, mailbox & messages and confirm the right objects were deleted
12067143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
12077143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testCascadeDeleteAccount() {
120828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-delete-cascade", true,
120928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
12107143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
121128448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
12127143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
121328448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        /* Message message1 = */ ProviderTestUtils.setupMessage("message1", account1Id, box1Id,
121428448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
121528448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        /* Message message2 = */ ProviderTestUtils.setupMessage("message2", account1Id, box1Id,
121628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
12177143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
12187143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there is one account, one mailbox, and two messages
12197143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numAccounts = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
12207143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numAccounts);
12217143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, null, null);
12227143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(1, numBoxes);
12237143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
12247143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numMessages);
12257143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
12267143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // delete the account
12277143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Account.CONTENT_URI, account1Id);
12287143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
12297143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
12307143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // make sure there are no accounts, mailboxes, or messages
12317143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numAccounts = EmailContent.count(mMockContext, Account.CONTENT_URI, null, null);
12327143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numAccounts);
12337143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numBoxes = EmailContent.count(mMockContext, Mailbox.CONTENT_URI, null, null);
12347143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numBoxes);
12357143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
12367143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numMessages);
12377143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
1238758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
12397143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
12407143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * Test cascaded delete mailbox
12417143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: body
12427143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: attachments
12437143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     * TODO: create other mailbox & messages and confirm the right objects were deleted
12447143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
12457143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    public void testCascadeDeleteMailbox() {
124628448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("mailbox-delete-cascade", true,
124728448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                mMockContext);
12487143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long account1Id = account1.mId;
124928448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
12507143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        long box1Id = box1.mId;
1251ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id,
125228448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
1253ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id,
1254ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                false, true, mMockContext);
1255ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message3 = ProviderTestUtils.setupMessage("message3", account1Id, box1Id,
1256ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                false, true, mMockContext);
1257ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        Message message4 = ProviderTestUtils.setupMessage("message4", account1Id, box1Id,
125828448e782b825d1978c0923003a2cf91efe733dcAndrew Stadler                false, true, mMockContext);
1259ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ProviderTestUtils.setupMessage("message5", account1Id, box1Id, false, true, mMockContext);
1260ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ProviderTestUtils.setupMessage("message6", account1Id, box1Id, false, true, mMockContext);
12617143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
12627143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String selection = EmailContent.MessageColumns.ACCOUNT_KEY + "=? AND " +
12637143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler                EmailContent.MessageColumns.MAILBOX_KEY + "=?";
12647143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        String[] selArgs = new String[] { String.valueOf(account1Id), String.valueOf(box1Id) };
12657143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
12660e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // make sure there are six messages
12677143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        int numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1268ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(6, numMessages);
1269ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
1270ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentValues cv = new ContentValues();
1271ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        cv.put(Message.SERVER_ID, "SERVER_ID");
1272ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        ContentResolver resolver = mMockContext.getContentResolver();
1273ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
1274ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Update two messages
1275ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message1.mId),
1276ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                cv, null, null);
1277ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.update(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message2.mId),
1278ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                cv, null, null);
1279ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // Delete two messages
1280ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message3.mId),
1281ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
1282ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(ContentUris.withAppendedId(Message.SYNCED_CONTENT_URI, message4.mId),
1283ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                null, null);
1284ef83299b99288c00b9d661260d19715e73e6889cMarc Blank
1285ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // There should now be two messages in updated/deleted, and 4 in messages
1286ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
1287ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(4, numMessages);
1288ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1289ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
1290ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(2, numMessages);
1291ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1292ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
12937143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(2, numMessages);
1294758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
12957143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        // now delete the mailbox
12967143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        Uri uri = ContentUris.withAppendedId(Mailbox.CONTENT_URI, box1Id);
1297ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        resolver.delete(uri, null, null);
1298758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1299ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        // there should now be zero messages in all three tables
13007143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        numMessages = EmailContent.count(mMockContext, Message.CONTENT_URI, selection, selArgs);
13017143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler        assertEquals(0, numMessages);
1302ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.DELETED_CONTENT_URI, selection,
1303ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
1304ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(0, numMessages);
1305ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        numMessages = EmailContent.count(mMockContext, Message.UPDATED_CONTENT_URI, selection,
1306ef83299b99288c00b9d661260d19715e73e6889cMarc Blank                selArgs);
1307ef83299b99288c00b9d661260d19715e73e6889cMarc Blank        assertEquals(0, numMessages);
13087143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    }
1309758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
13107143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler    /**
13116c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     * Test cascaded delete message
13126c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     * Confirms that deleting a message will also delete its body & attachments
13137143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler     */
13146c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    public void testCascadeMessageDelete() {
13156c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Account account1 = ProviderTestUtils.setupAccount("message-cascade", true, mMockContext);
13166c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long account1Id = account1.mId;
13176c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", account1Id, true, mMockContext);
13186c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long box1Id = box1.mId;
1319bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
13206c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Each message has a body, and also give each 2 attachments
13216c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Message message1 = ProviderTestUtils.setupMessage("message1", account1Id, box1Id, true,
13226c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                false, mMockContext);
13236c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ArrayList<Attachment> atts = new ArrayList<Attachment>();
13246c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        for (int i = 0; i < 2; i++) {
13256c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
13266c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
13276c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    false, mMockContext));
13286c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        }
13296c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message1.mAttachments = atts;
13306c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message1.save(mMockContext);
13316c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long message1Id = message1.mId;
13326c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13336c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Message message2 = ProviderTestUtils.setupMessage("message2", account1Id, box1Id, true,
13346c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                false, mMockContext);
13356c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        atts = new ArrayList<Attachment>();
13366c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        for (int i = 0; i < 2; i++) {
13376c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            atts.add(ProviderTestUtils.setupAttachment(
13386c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    -1, expectedAttachmentNames[i], expectedAttachmentSizes[i],
13396c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                    false, mMockContext));
13406c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        }
13416c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message2.mAttachments = atts;
13426c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        message2.save(mMockContext);
13436c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        long message2Id = message2.mId;
13446c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13456c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Set up to test total counts of bodies & attachments for our test messages
13466c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        String bodySelection = BodyColumns.MESSAGE_KEY + " IN (?,?)";
13476c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        String attachmentSelection = AttachmentColumns.MESSAGE_KEY + " IN (?,?)";
13486c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        String[] selArgs = new String[] { String.valueOf(message1Id), String.valueOf(message2Id) };
1349bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
13506c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // make sure there are two bodies
13516c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        int numBodies = EmailContent.count(mMockContext, Body.CONTENT_URI, bodySelection, selArgs);
13526c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(2, numBodies);
13536c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13546c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // make sure there are four attachments
13556c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        int numAttachments = EmailContent.count(mMockContext, Attachment.CONTENT_URI,
13566c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                attachmentSelection, selArgs);
13576c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(4, numAttachments);
13586c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13596c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // now delete one of the messages
13606c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1Id);
13616c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
13626c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13636c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // there should be one body and two attachments
13646c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numBodies = EmailContent.count(mMockContext, Body.CONTENT_URI, bodySelection, selArgs);
13656c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(1, numBodies);
13666c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13676c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numAttachments = EmailContent.count(mMockContext, Attachment.CONTENT_URI,
13686c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                attachmentSelection, selArgs);
13696c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(2, numAttachments);
13706c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13716c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // now delete the other message
13726c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        uri = ContentUris.withAppendedId(Message.CONTENT_URI, message2Id);
13736c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
13746c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13756c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // make sure there are no bodies or attachments
13766c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numBodies = EmailContent.count(mMockContext, Body.CONTENT_URI, bodySelection, selArgs);
13776c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(0, numBodies);
13786c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
13796c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        numAttachments = EmailContent.count(mMockContext, Attachment.CONTENT_URI,
13806c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                attachmentSelection, selArgs);
13816c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(0, numAttachments);
13826c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    }
13837143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler
1384976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    /**
1385976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     * Test that our unique file name algorithm works as expected.  Since this test requires an
1386976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     * SD card, we check the environment first, and return immediately if none is mounted.
1387976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     * @throws IOException
1388976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank     */
1389976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    public void testCreateUniqueFile() throws IOException {
1390976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        // Delete existing files, if they exist
1391976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        if (!Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {
1392976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            return;
1393976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        }
1394976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        try {
1395976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            String fileName = "A11achm3n1.doc";
1396976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            File uniqueFile = Attachment.createUniqueFile(fileName);
1397976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            assertEquals(fileName, uniqueFile.getName());
1398976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            if (uniqueFile.createNewFile()) {
1399976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                uniqueFile = Attachment.createUniqueFile(fileName);
1400976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                assertEquals("A11achm3n1-2.doc", uniqueFile.getName());
1401976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                if (uniqueFile.createNewFile()) {
1402976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    uniqueFile = Attachment.createUniqueFile(fileName);
1403976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    assertEquals("A11achm3n1-3.doc", uniqueFile.getName());
1404976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                }
1405976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank           }
1406976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            fileName = "A11achm3n1";
1407976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            uniqueFile = Attachment.createUniqueFile(fileName);
1408976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            assertEquals(fileName, uniqueFile.getName());
1409976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            if (uniqueFile.createNewFile()) {
1410976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                uniqueFile = Attachment.createUniqueFile(fileName);
1411976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                assertEquals("A11achm3n1-2", uniqueFile.getName());
1412976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            }
1413976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        } finally {
1414976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            File directory = Environment.getExternalStorageDirectory();
1415976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // These are the files that should be created earlier in the test.  Make sure
1416976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            // they are deleted for the next go-around
1417976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            String[] fileNames = new String[] {"A11achm3n1.doc", "A11achm3n1-2.doc", "A11achm3n1"};
1418976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            int length = fileNames.length;
1419976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            for (int i = 0; i < length; i++) {
1420976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                File file = new File(directory, fileNames[i]);
1421976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                if (file.exists()) {
1422976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                    file.delete();
1423976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank                }
1424976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank            }
1425976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank        }
1426976f92908dd2f69f21f62690632ff24b08d9f5d3Marc Blank    }
14274119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
14284119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    /**
14294119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler     * Test retrieving attachments by message ID (using EmailContent.Attachment.MESSAGE_ID_URI)
14304119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler     */
14314119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    public void testGetAttachmentByMessageIdUri() {
14324119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
14334119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Note, we don't strictly need accounts, mailboxes or messages to run this test.
14344119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Attachment a1 = ProviderTestUtils.setupAttachment(1, "a1", 100, true, mMockContext);
14354119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Attachment a2 = ProviderTestUtils.setupAttachment(1, "a2", 200, true, mMockContext);
1436758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ProviderTestUtils.setupAttachment(2, "a3", 300, true, mMockContext);
1437758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ProviderTestUtils.setupAttachment(2, "a4", 400, true, mMockContext);
14384119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
14394119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Now ask for the attachments of message id=1
14404119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        // Note: Using the "sort by size" trick to bring them back in expected order
14414119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Uri uri = ContentUris.withAppendedId(Attachment.MESSAGE_ID_URI, 1);
14424119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        Cursor c = mMockContext.getContentResolver().query(uri, Attachment.CONTENT_PROJECTION,
14434119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler                null, null, Attachment.SIZE);
14444119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        assertEquals(2, c.getCount());
14454119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler
14464119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        try {
14474119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.moveToFirst();
14484119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            Attachment a1Get = EmailContent.getContent(c, Attachment.class);
14494119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-1", a1, a1Get);
14504119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.moveToNext();
14514119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            Attachment a2Get = EmailContent.getContent(c, Attachment.class);
14524119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-2", a2, a2Get);
14534119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        } finally {
14544119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler            c.close();
14554119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler        }
14564119218e2fd64341ac946fb8f2cbdb796a444cb8Andrew Stadler    }
145754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
145854c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler    /**
14596c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     * Test deleting attachments by message ID (using EmailContent.Attachment.MESSAGE_ID_URI)
14606c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler     */
14616c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    public void testDeleteAttachmentByMessageIdUri() {
14626c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ContentResolver mockResolver = mMockContext.getContentResolver();
14636c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14646c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Note, we don't strictly need accounts, mailboxes or messages to run this test.
14656c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ProviderTestUtils.setupAttachment(1, "a1", 100, true, mMockContext);
14666c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        ProviderTestUtils.setupAttachment(1, "a2", 200, true, mMockContext);
14676c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Attachment a3 = ProviderTestUtils.setupAttachment(2, "a3", 300, true, mMockContext);
14686c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Attachment a4 = ProviderTestUtils.setupAttachment(2, "a4", 400, true, mMockContext);
14696c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14706c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Delete all attachments for message id=1
14716c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Uri uri = ContentUris.withAppendedId(Attachment.MESSAGE_ID_URI, 1);
14726c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        mockResolver.delete(uri, null, null);
14736c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14746c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // Read back all attachments and confirm that we have the expected remaining attachments
14756c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        // (the attachments that are set for message id=2).  Note order-by size to simplify test.
14766c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        Cursor c = mockResolver.query(Attachment.CONTENT_URI, Attachment.CONTENT_PROJECTION,
14776c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler                null, null, Attachment.SIZE);
14786c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        assertEquals(2, c.getCount());
14796c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14806c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        try {
14816c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            c.moveToFirst();
14826c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            Attachment a3Get = EmailContent.getContent(c, Attachment.class);
14836c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-3", a3, a3Get);
14846c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            c.moveToNext();
14856c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            Attachment a4Get = EmailContent.getContent(c, Attachment.class);
14866c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            ProviderTestUtils.assertAttachmentEqual("getAttachByUri-4", a4, a4Get);
14876c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        } finally {
14886c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler            c.close();
14896c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler        }
14906c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    }
14916c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler
14926c21942ec45f561d711b3d74ecca8e62afb735c4Andrew Stadler    /**
149354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * Tests of default account behavior
1494758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank     *
149554c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * 1.  Simple set/get
149654c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * 2.  Moving default between 3 accounts
149754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     * 3.  Delete default, make sure another becomes default
149854c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler     */
149954c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler    public void testSetGetDefaultAccount() {
150054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        // There should be no default account if there are no accounts
150154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long defaultAccountId = Account.getDefaultAccountId(mMockContext);
150254c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        assertEquals(-1, defaultAccountId);
150354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
150454c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        Account account1 = ProviderTestUtils.setupAccount("account-default-1", true, mMockContext);
150554c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long account1Id = account1.mId;
150654c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        Account account2 = ProviderTestUtils.setupAccount("account-default-2", true, mMockContext);
150754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long account2Id = account2.mId;
150854c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        Account account3 = ProviderTestUtils.setupAccount("account-default-3", true, mMockContext);
150954c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        long account3Id = account3.mId;
151054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
15119e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        // With three accounts, but none marked default, confirm that some default account
15129e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        // is returned.  Which one is undefined here.
151354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        defaultAccountId = Account.getDefaultAccountId(mMockContext);
15149e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        assertTrue(defaultAccountId == account1Id
15159e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler                    || defaultAccountId == account2Id
15169e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler                    || defaultAccountId == account3Id);
151754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
15189e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        updateIsDefault(account1, true);
151954c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        defaultAccountId = Account.getDefaultAccountId(mMockContext);
15209e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        assertEquals(account1Id, defaultAccountId);
152154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1522531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        updateIsDefault(account2, true);
1523531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1524531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account2Id, defaultAccountId);
1525531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank
1526531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        updateIsDefault(account3, true);
1527531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1528531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account3Id, defaultAccountId);
152954c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
153054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        // Now delete a non-default account and confirm no change
153154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        Uri uri = ContentUris.withAppendedId(Account.CONTENT_URI, account1Id);
153254c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
153354c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1534531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1535531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account3Id, defaultAccountId);
153654c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
153754c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        // Now confirm deleting the default account and it switches to another one
153854c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        uri = ContentUris.withAppendedId(Account.CONTENT_URI, account3Id);
153954c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
154054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
1541531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        defaultAccountId = Account.getDefaultAccountId(mMockContext);
1542531ae9d25f4310e4774e136ed74ed9749f940861Marc Blank        assertEquals(account2Id, defaultAccountId);
1543758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
15449e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        // Now delete the final account and confirm there are no default accounts again
15459e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        uri = ContentUris.withAppendedId(Account.CONTENT_URI, account2Id);
15469e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        mMockContext.getContentResolver().delete(uri, null, null);
15479e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler
154854c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler        defaultAccountId = Account.getDefaultAccountId(mMockContext);
15499e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        assertEquals(-1, defaultAccountId);
155054c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler    }
155154c1f2bf9a6574240b7c9af253f83a2b566442abAndrew Stadler
15529e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler    private void updateIsDefault(Account account, boolean newState) {
15539e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        account.setDefaultAccount(newState);
15549e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        ContentValues cv = new ContentValues();
15559e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        cv.put(AccountColumns.IS_DEFAULT, account.mIsDefault);
15569e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler        account.update(mMockContext, cv);
15579e2c6bd5f21f2d19eef7ebfe30e6fdf94ede0857Andrew Stadler    }
1558758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1559758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    public static Message setupUnreadMessage(String name, long accountId, long mailboxId,
1560758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank            boolean addBody, boolean saveIt, Context context) {
1561758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message msg =
1562758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank            ProviderTestUtils.setupMessage(name, accountId, mailboxId, addBody, false, context);
1563758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        msg.mFlagRead = false;
1564758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        if (saveIt) {
1565758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank            msg.save(context);
1566758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        }
1567758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        return msg;
1568758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    }
1569758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1570758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    public void testUnreadCountTriggers() {
1571758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Start with one account and three mailboxes
1572758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Account account = ProviderTestUtils.setupAccount("triggers", true, mMockContext);
1573758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Mailbox boxA = ProviderTestUtils.setupMailbox("boxA", account.mId, true, mMockContext);
1574758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Mailbox boxB = ProviderTestUtils.setupMailbox("boxB", account.mId, true, mMockContext);
1575758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Mailbox boxC = ProviderTestUtils.setupMailbox("boxC", account.mId, true, mMockContext);
1576758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1577758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Make sure there are no unreads
1578758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1579758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxB.mId));
1580758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxC.mId));
1581758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1582758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Create 4 unread messages (only 3 named) in boxA
1583758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message message1 = setupUnreadMessage("message1", account.mId, boxA.mId,
1584758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank                false, true, mMockContext);
1585758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message message2= setupUnreadMessage("message2", account.mId, boxA.mId,
1586758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank                false, true, mMockContext);
1587758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Message message3 =  setupUnreadMessage("message3", account.mId, boxA.mId,
1588758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank                false, true, mMockContext);
1589758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        setupUnreadMessage("message4", account.mId, boxC.mId, false, true, mMockContext);
1590758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1591758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Make sure the unreads are where we expect them
1592758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(3, getUnreadCount(boxA.mId));
1593758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxB.mId));
1594758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1595758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1596758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // After deleting message 1, the count in box A should be decremented (to 2)
1597758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ContentResolver cr = mMockContext.getContentResolver();
1598758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        Uri uri = ContentUris.withAppendedId(Message.CONTENT_URI, message1.mId);
1599758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.delete(uri, null, null);
1600758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(2, getUnreadCount(boxA.mId));
1601758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxB.mId));
1602758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1603758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1604758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Move message 2 to box B, leaving 1 in box A and 1 in box B
1605758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        message2.mMailboxKey = boxB.mId;
1606758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        ContentValues cv = new ContentValues();
1607758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.MAILBOX_KEY, boxB.mId);
1608758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message2.mId), cv, null, null);
1609758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxA.mId));
1610758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1611758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1612758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1613758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Mark message 3 (from box A) read, leaving 0 in box A
1614758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.clear();
1615758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.FLAG_READ, 1);
1616758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message3.mId), cv, null, null);
1617758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1618758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1619758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1620758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1621758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Move message 3 to box C; should be no change (it's read)
1622758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        message3.mMailboxKey = boxC.mId;
1623758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.clear();
1624758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.MAILBOX_KEY, boxC.mId);
1625758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message3.mId), cv, null, null);
1626758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1627758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1628758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxC.mId));
1629758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank
1630758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        // Mark message 3 unread; it's now in box C, so that box's count should go up to 3
1631758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.clear();
1632758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cv.put(MessageColumns.FLAG_READ, 0);
1633758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        cr.update(ContentUris.withAppendedId(Message.CONTENT_URI, message3.mId), cv, null, null);
1634758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(0, getUnreadCount(boxA.mId));
1635758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(1, getUnreadCount(boxB.mId));
1636758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank        assertEquals(2, getUnreadCount(boxC.mId));
1637758a532fce2f672673d38b2daa5f67eb757b118bMarc Blank    }
16389627d014e16235eadf981b9165807dc72a14a383Mihai Preda
16399627d014e16235eadf981b9165807dc72a14a383Mihai Preda    /**
16409627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Test for EmailProvider.createIndex().
16419627d014e16235eadf981b9165807dc72a14a383Mihai Preda     * Check that it returns exacly the same string as the one used previously for index creation.
16429627d014e16235eadf981b9165807dc72a14a383Mihai Preda     */
16439627d014e16235eadf981b9165807dc72a14a383Mihai Preda    public void testCreateIndex() {
16449627d014e16235eadf981b9165807dc72a14a383Mihai Preda        String oldStr = "create index message_" + MessageColumns.TIMESTAMP
16459627d014e16235eadf981b9165807dc72a14a383Mihai Preda            + " on " + Message.TABLE_NAME + " (" + MessageColumns.TIMESTAMP + ");";
16469627d014e16235eadf981b9165807dc72a14a383Mihai Preda        String newStr = EmailProvider.createIndex(Message.TABLE_NAME, MessageColumns.TIMESTAMP);
16479627d014e16235eadf981b9165807dc72a14a383Mihai Preda        assertEquals(newStr, oldStr);
16489627d014e16235eadf981b9165807dc72a14a383Mihai Preda    }
1649c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank
1650c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank    public void testIdAddToField() {
1651c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        ContentResolver cr = mMockContext.getContentResolver();
1652c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        ContentValues cv = new ContentValues();
1653c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank
1654c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        // Try changing the newMessageCount of an account
1655c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        Account account = ProviderTestUtils.setupAccount("field-add", true, mMockContext);
1656c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        int startCount = account.mNewMessageCount;
1657c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        // "field" and "add" are the two required elements
1658c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        cv.put(EmailContent.FIELD_COLUMN_NAME, AccountColumns.NEW_MESSAGE_COUNT);
1659c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        cv.put(EmailContent.ADD_COLUMN_NAME, 17);
1660c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        cr.update(ContentUris.withAppendedId(Account.ADD_TO_FIELD_URI, account.mId),
1661c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank                cv, null, null);
1662c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        Account restoredAccount = Account.restoreAccountWithId(mMockContext, account.mId);
1663c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        assertEquals(17 + startCount, restoredAccount.mNewMessageCount);
1664c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        cv.put(EmailContent.ADD_COLUMN_NAME, -11);
1665c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        cr.update(ContentUris.withAppendedId(Account.ADD_TO_FIELD_URI, account.mId),
1666c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank                cv, null, null);
1667c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        restoredAccount = Account.restoreAccountWithId(mMockContext, account.mId);
1668c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        assertEquals(17 - 11 + startCount, restoredAccount.mNewMessageCount);
1669c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank
1670c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        // Now try with a mailbox
1671c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        Mailbox boxA = ProviderTestUtils.setupMailbox("boxA", account.mId, true, mMockContext);
1672c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        assertEquals(0, boxA.mUnreadCount);
1673c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        cv.put(EmailContent.FIELD_COLUMN_NAME, MailboxColumns.UNREAD_COUNT);
1674c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        cv.put(EmailContent.ADD_COLUMN_NAME, 11);
1675c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        cr.update(ContentUris.withAppendedId(Mailbox.ADD_TO_FIELD_URI, boxA.mId), cv, null, null);
1676c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        Mailbox restoredBoxA = Mailbox.restoreMailboxWithId(mMockContext, boxA.mId);
1677c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank        assertEquals(11, restoredBoxA.mUnreadCount);
1678c0c9c33322deecace00a32766e0a1b355aad4b31Marc Blank    }
16790e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16800e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    public void testDatabaseCorruptionRecovery() {
16810e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final ContentResolver resolver = mMockContext.getContentResolver();
16820e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final Context context = mMockContext;
16830e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16840e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create account and two mailboxes
16850e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Account acct = ProviderTestUtils.setupAccount("acct1", true, context);
16860e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
16870e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16880e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create 4 messages in box1 with bodies
16890e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, true, true, context);
16900e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, true, true, context);
16910e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, true, true, context);
16920e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, true, true, context);
16930e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
16940e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four messages
16950e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        int count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
16960e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
16970e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four bodies
16980e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
16990e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
17000e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17010e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProvider.db file
17020e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        File dbFile = mMockContext.getDatabasePath(EmailProvider.DATABASE_NAME);
17030e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProvider.db database should exist (the provider creates it automatically)
17040e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
17050e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
17060e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Delete it, and confirm it is gone
17070e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.delete());
17080e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertFalse(dbFile.exists());
17090e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17100e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProviderBody.db file
17110e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        dbFile = mMockContext.getDatabasePath(EmailProvider.BODY_DATABASE_NAME);
17120e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProviderBody.db database should still exist
17130e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
17140e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
17150e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17160e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // URI to uncache the databases
17170e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // This simulates the Provider starting up again (otherwise, it will still be pointing to
17180e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the already opened files)
17190e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Note that we only have access to the EmailProvider via the ContentResolver; therefore,
17200e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // we cannot directly call into the provider and use a URI for this
17210e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        resolver.update(EmailProvider.INTEGRITY_CHECK_URI, null, null, null);
17220e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17230e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // TODO We should check for the deletion of attachment files once this is implemented in
17240e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the provider
1725bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
17260e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Explanation for what happens below...
17270e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The next time the database is created by the provider, it will notice that there's
17280e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // already a EmailProviderBody.db file.  In this case, it will delete that database to
17290e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // ensure that both are in sync (and empty)
17300e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17310e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no bodies
17320e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
17330e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
17340e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17350e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no messages
17360e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
17370e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
17380e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    }
17390e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17400e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    public void testBodyDatabaseCorruptionRecovery() {
17410e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final ContentResolver resolver = mMockContext.getContentResolver();
17420e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        final Context context = mMockContext;
17430e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17440e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create account and two mailboxes
17450e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Account acct = ProviderTestUtils.setupAccount("acct1", true, context);
17460e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        Mailbox box1 = ProviderTestUtils.setupMailbox("box1", acct.mId, true, context);
17470e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17480e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Create 4 messages in box1 with bodies
17490e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message1", acct.mId, box1.mId, true, true, context);
17500e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message2", acct.mId, box1.mId, true, true, context);
17510e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message3", acct.mId, box1.mId, true, true, context);
17520e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        ProviderTestUtils.setupMessage("message4", acct.mId, box1.mId, true, true, context);
17530e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17540e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four messages
17550e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        int count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
17560e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
17570e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are four bodies
17580e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
17590e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(4, count);
17600e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17610e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProviderBody.db file
17620e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        File dbFile = mMockContext.getDatabasePath(EmailProvider.BODY_DATABASE_NAME);
17630e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProviderBody.db database should exist (the provider creates it automatically)
17640e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
17650e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
17660e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Delete it, and confirm it is gone
17670e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.delete());
17680e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertFalse(dbFile.exists());
17690e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17700e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Find the EmailProvider.db file
17710e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        dbFile = mMockContext.getDatabasePath(EmailProvider.DATABASE_NAME);
17720e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The EmailProviderBody.db database should still exist
17730e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile != null);
17740e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertTrue(dbFile.exists());
17750e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17760e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // URI to uncache the databases
17770e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // This simulates the Provider starting up again (otherwise, it will still be pointing to
17780e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the already opened files)
17790e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Note that we only have access to the EmailProvider via the ContentResolver; therefore,
17800e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // we cannot directly call into the provider and use a URI for this
17810e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        resolver.update(EmailProvider.INTEGRITY_CHECK_URI, null, null, null);
17820e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17830e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // TODO We should check for the deletion of attachment files once this is implemented in
17840e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // the provider
17850e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17860e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Explanation for what happens below...
17870e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // The next time the body database is created by the provider, it will notice that there's
17880e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // already a populated EmailProvider.db file.  In this case, it will delete that database to
17890e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // ensure that both are in sync (and empty)
17900e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17910e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no messages
17920e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Message.CONTENT_URI, null, null);
17930e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
17940e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank
17950e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        // Confirm there are no bodies
17960e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        count = EmailContent.count(mMockContext, Body.CONTENT_URI, null, null);
17970e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank        assertEquals(0, count);
17980e1595c177e40428b267a8696dfc05d015ce6a2fMarc Blank    }
1799694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1800694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank    public void testFindMailboxOfType() {
1801694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        final Context context = mMockContext;
1802694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1803694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        // Create two accounts and a variety of mailbox types
1804694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Account acct1 = ProviderTestUtils.setupAccount("acct1", true, context);
1805694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Inbox =
1806694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Inbox1", acct1.mId, true, context, Mailbox.TYPE_INBOX);
1807694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Calendar
1808694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        = ProviderTestUtils.setupMailbox("Cal1", acct1.mId, true, context, Mailbox.TYPE_CALENDAR);
1809694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Contacts =
1810694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Con1", acct1.mId, true, context, Mailbox.TYPE_CONTACTS);
1811694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Account acct2 = ProviderTestUtils.setupAccount("acct1", true, context);
1812694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Inbox =
1813694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Inbox2", acct2.mId, true, context, Mailbox.TYPE_INBOX);
1814694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Calendar =
1815694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Cal2", acct2.mId, true, context, Mailbox.TYPE_CALENDAR);
1816694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Contacts =
1817694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Con2", acct2.mId, true, context, Mailbox.TYPE_CONTACTS);
1818694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1819694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        // Check that we can find them by type
1820694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct1Inbox.mId,
1821694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_INBOX));
1822694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct2Inbox.mId,
1823694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct2.mId, Mailbox.TYPE_INBOX));
1824694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct1Calendar.mId,
1825694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_CALENDAR));
1826694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct2Calendar.mId,
1827694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct2.mId, Mailbox.TYPE_CALENDAR));
1828694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct1Contacts.mId,
1829694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct1.mId, Mailbox.TYPE_CONTACTS));
1830694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        assertEquals(acct2Contacts.mId,
1831694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.findMailboxOfType(context, acct2.mId, Mailbox.TYPE_CONTACTS));
1832694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank    }
1833694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1834694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank    public void testRestoreMailboxOfType() {
1835694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        final Context context = mMockContext;
1836694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1837694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        // Create two accounts and a variety of mailbox types
1838694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Account acct1 = ProviderTestUtils.setupAccount("acct1", true, context);
1839694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Inbox =
1840694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Inbox1", acct1.mId, true, context, Mailbox.TYPE_INBOX);
1841694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Calendar
1842694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        = ProviderTestUtils.setupMailbox("Cal1", acct1.mId, true, context, Mailbox.TYPE_CALENDAR);
1843694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct1Contacts =
1844694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Con1", acct1.mId, true, context, Mailbox.TYPE_CONTACTS);
1845694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Account acct2 = ProviderTestUtils.setupAccount("acct1", true, context);
1846694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Inbox =
1847694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Inbox2", acct2.mId, true, context, Mailbox.TYPE_INBOX);
1848694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Calendar =
1849694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Cal2", acct2.mId, true, context, Mailbox.TYPE_CALENDAR);
1850694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        Mailbox acct2Contacts =
1851694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank            ProviderTestUtils.setupMailbox("Con2", acct2.mId, true, context, Mailbox.TYPE_CONTACTS);
1852694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank
1853694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        // Check that we can find them by type
1854694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct1Inbox,
1855694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct1.mId, Mailbox.TYPE_INBOX));
1856694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct2Inbox,
1857694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct2.mId, Mailbox.TYPE_INBOX));
1858694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct1Calendar,
1859694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct1.mId, Mailbox.TYPE_CALENDAR));
1860694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct2Calendar,
1861694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct2.mId, Mailbox.TYPE_CALENDAR));
1862694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct1Contacts,
1863694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct1.mId, Mailbox.TYPE_CONTACTS));
1864694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank        ProviderTestUtils.assertMailboxEqual("testRestoreMailboxOfType", acct2Contacts,
1865694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank                Mailbox.restoreMailboxOfType(context, acct2.mId, Mailbox.TYPE_CONTACTS));
1866694257cb7e7a191b3314cb209b6c38a8a07583efMarc Blank    }
1867bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1868bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki    public void testAccountIsSecurityHold() {
1869bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        final Context context = mMockContext;
1870bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account acct1 = ProviderTestUtils.setupAccount("acct1", true, context);
1871bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1872bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account acct2 = ProviderTestUtils.setupAccount("acct2", false, context);
1873bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        acct2.mFlags |= Account.FLAGS_SECURITY_HOLD;
1874bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        acct2.save(context);
1875bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1876bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertFalse(Account.isSecurityHold(context, acct1.mId));
1877bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertTrue(Account.isSecurityHold(context, acct2.mId));
1878bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertFalse(Account.isSecurityHold(context, 9999999)); // No such account
1879bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki   }
1880bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1881bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki    public void testClearAccountHoldFlags() {
1882bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a1 = ProviderTestUtils.setupAccount("holdflag-1", false, mMockContext);
1883bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a1.mFlags = Account.FLAGS_NOTIFY_NEW_MAIL;
1884bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a1.save(mMockContext);
1885bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a2 = ProviderTestUtils.setupAccount("holdflag-2", false, mMockContext);
1886bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a2.mFlags = Account.FLAGS_VIBRATE_ALWAYS | Account.FLAGS_SECURITY_HOLD;
1887bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        a2.save(mMockContext);
1888bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1889bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        // bulk clear
1890bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account.clearSecurityHoldOnAllAccounts(mMockContext);
1891bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki
1892bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        // confirm new values as expected - no hold flags; other flags unmolested
1893bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a1a = Account.restoreAccountWithId(mMockContext, a1.mId);
1894bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertEquals(Account.FLAGS_NOTIFY_NEW_MAIL, a1a.mFlags);
1895bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        Account a2a = Account.restoreAccountWithId(mMockContext, a2.mId);
1896bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki        assertEquals(Account.FLAGS_VIBRATE_ALWAYS, a2a.mFlags);
1897bcf32320e2600e96c8a9e997a8903bfc3893b35eMakoto Onuki    }
1898574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1899574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    /**
1900574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki     * @return the number of messages in a mailbox.
1901574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki     */
1902574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    private int getMessageCount(long mailboxId) {
1903574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        Mailbox b = Mailbox.restoreMailboxWithId(mMockContext, mailboxId);
1904574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        return b.mMessageCount;
1905574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    }
1906574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1907574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    /** Set -1 to the message count of all mailboxes for the recalculateMessageCount test. */
1908574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    private void setMinusOneToMessageCounts() {
1909574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        ContentValues values = new ContentValues();
1910574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        values.put(MailboxColumns.MESSAGE_COUNT, -1);
1911574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
19125b0c2c7f344e72915ac63ff45cf3d65885373a39Makoto Onuki        // EmailProvider.update() doesn't allow updating messageCount, so directly use the DB.
19135b0c2c7f344e72915ac63ff45cf3d65885373a39Makoto Onuki        SQLiteDatabase db = getProvider().getDatabase(mMockContext);
19145b0c2c7f344e72915ac63ff45cf3d65885373a39Makoto Onuki        db.update(Mailbox.TABLE_NAME, values, null, null);
1915574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    }
1916574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1917574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    /**
1918833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     * Test for the message count triggers (insert/delete/move mailbox), and also
1919574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki     * {@link EmailProvider#recalculateMessageCount}.
1920833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     *
1921833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     * It also covers:
1922833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     * - {@link Mailbox#getMessageCountByMailboxType(Context, int)}
1923833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     * - {@link Mailbox#getUnreadCountByMailboxType(Context, int)}
1924833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki     * - {@link Message#getFavoriteMessageCount(Context)}
1925574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki     */
1926574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    public void testMessageCount() {
1927574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        final Context c = mMockContext;
1928574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1929574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Create 2 accounts
1930574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        Account a1 = ProviderTestUtils.setupAccount("holdflag-1", true, c);
1931574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        Account a2 = ProviderTestUtils.setupAccount("holdflag-2", true, c);
1932574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1933574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Create 2 mailboxes for each account
1934833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a1.mId, true, c, Mailbox.TYPE_INBOX);
1935833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a1.mId, true, c, Mailbox.TYPE_OUTBOX);
1936833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Mailbox b3 = ProviderTestUtils.setupMailbox("box3", a2.mId, true, c, Mailbox.TYPE_INBOX);
1937833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Mailbox b4 = ProviderTestUtils.setupMailbox("box4", a2.mId, true, c, Mailbox.TYPE_OUTBOX);
1938574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1939574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // 0. Check the initial values, just in case.
1940574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1941574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b1.mId));
1942574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b2.mId));
1943574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b3.mId));
1944574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b4.mId));
1945574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1946833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(0, Message.getFavoriteMessageCount(c));
1947833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByMailboxType(c, Mailbox.TYPE_INBOX));
1948833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(0, Mailbox.getUnreadCountByMailboxType(c, Mailbox.TYPE_OUTBOX));
1949833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(0, Mailbox.getMessageCountByMailboxType(c, Mailbox.TYPE_INBOX));
1950833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(0, Mailbox.getMessageCountByMailboxType(c, Mailbox.TYPE_OUTBOX));
1951833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki
1952574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // 1. Test for insert triggers.
1953574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1954574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Create some messages
1955833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        // b1: 1 message
1956833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Message m11 = createMessage(c, b1, true, false);
1957574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1958833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        // b2: 2 message
1959833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Message m21 = createMessage(c, b2, false, false);
1960833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Message m22 = createMessage(c, b2, true, true);
1961574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1962833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        // b3: 3 message
1963833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Message m31 = createMessage(c, b3, false, false);
1964833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Message m32 = createMessage(c, b3, false, false);
1965833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        Message m33 = createMessage(c, b3, true, true);
1966574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1967574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // b4 has no messages.
1968574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1969574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Check message counts
1970574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b1.mId));
1971574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(2, getMessageCount(b2.mId));
1972574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(3, getMessageCount(b3.mId));
1973574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b4.mId));
1974574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1975833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        // Check the simple counting methods.
1976833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(3, Message.getFavoriteMessageCount(c));
1977833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(3, Mailbox.getUnreadCountByMailboxType(c, Mailbox.TYPE_INBOX));
1978833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(1, Mailbox.getUnreadCountByMailboxType(c, Mailbox.TYPE_OUTBOX));
1979833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(4, Mailbox.getMessageCountByMailboxType(c, Mailbox.TYPE_INBOX));
1980833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        assertEquals(2, Mailbox.getMessageCountByMailboxType(c, Mailbox.TYPE_OUTBOX));
1981833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki
1982574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // 2. test for recalculateMessageCount.
1983574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1984574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // First, invalidate the message counts.
1985574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        setMinusOneToMessageCounts();
1986574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(-1, getMessageCount(b1.mId));
1987574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(-1, getMessageCount(b2.mId));
1988574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(-1, getMessageCount(b3.mId));
1989574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(-1, getMessageCount(b4.mId));
1990574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1991574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Batch update.
1992574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        SQLiteDatabase db = getProvider().getDatabase(mMockContext);
1993574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        EmailProvider.recalculateMessageCount(db);
1994574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
1995574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Check message counts
1996574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b1.mId));
1997574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(2, getMessageCount(b2.mId));
1998574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(3, getMessageCount(b3.mId));
1999574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b4.mId));
2000574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2001574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // 3. Check the "move mailbox" trigger.
2002574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2003574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Move m32 (in mailbox 3) to mailbox 4.
2004574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        ContentValues values = new ContentValues();
2005574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        values.put(MessageColumns.MAILBOX_KEY, b4.mId);
2006574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2007574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        getProvider().update(Message.CONTENT_URI, values, EmailContent.ID_SELECTION,
2008574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki                new String[] {"" + m32.mId});
2009574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2010574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Check message counts
2011574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b1.mId));
2012574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(2, getMessageCount(b2.mId));
2013574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(2, getMessageCount(b3.mId));
2014574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b4.mId));
2015574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2016574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // 4. Check the delete trigger.
2017574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2018574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Delete m11 (in mailbox 1)
2019574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        getProvider().delete(Message.CONTENT_URI, EmailContent.ID_SELECTION,
2020574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki                new String[] {"" + m11.mId});
2021574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Delete m21 (in mailbox 2)
2022574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        getProvider().delete(Message.CONTENT_URI, EmailContent.ID_SELECTION,
2023574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki                new String[] {"" + m21.mId});
2024574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki
2025574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        // Check message counts
2026574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(0, getMessageCount(b1.mId));
2027574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b2.mId));
2028574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(2, getMessageCount(b3.mId));
2029574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki        assertEquals(1, getMessageCount(b4.mId));
2030d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki
2031d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        // No such mailbox type.
2032d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        assertEquals(0, Mailbox.getMessageCountByMailboxType(c, 99999));
2033d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        assertEquals(0, Mailbox.getUnreadCountByMailboxType(c, 99999));
2034574854b528163f3bf1a7cb974aa80082d1768edfMakoto Onuki    }
2035833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki
2036833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki    private static Message createMessage(Context c, Mailbox b, boolean starred, boolean read) {
2037833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki        return ProviderTestUtils.setupMessage("1", b.mAccountKey, b.mId, true, true, c, starred,
2038833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki                read);
2039833fe73b99e62ad9cf6e80c782717c7de1ff12e4Makoto Onuki    }
20406d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki
20415247ab8cae802272b1e29e81d3b31a1c4e710da5Makoto Onuki    public void testAccountIsEasAccount() {
20426d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki        Account account = new Account();
204325144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        // No hostauth
20445247ab8cae802272b1e29e81d3b31a1c4e710da5Makoto Onuki        assertFalse(account.isEasAccount(mMockContext));
20456d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki
204625144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount(null, false);
204725144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount("", false);
204825144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount("x", false);
204925144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        checkAccountIsEasAccount("eas", true);
205025144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki    }
20516d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki
205225144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki    private void checkAccountIsEasAccount(String protocol, boolean expected) {
205325144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        Account account = ProviderTestUtils.setupAccount("account", false, mMockContext);
205425144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        account.mHostAuthRecv = ProviderTestUtils.setupHostAuth(protocol, "account-hostauth-recv",
205525144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki                account.mId, false, mMockContext);
205625144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        account.save(mMockContext);
205725144e2b7990c50bb3650faf1aec341837c05348Makoto Onuki        assertEquals(expected, account.isEasAccount(mMockContext));
20586d8bfa67c438ee18921d13d8bfba876aacaa9ff6Makoto Onuki    }
2059bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank
2060bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank    public void testGetKeyColumnLong() {
2061bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        final Context c = mMockContext;
2062bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Account a = ProviderTestUtils.setupAccount("acct", true, c);
2063bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a.mId, true, c, Mailbox.TYPE_MAIL);
2064bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a.mId, true, c, Mailbox.TYPE_MAIL);
2065bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Message m1 = createMessage(c, b1, false, false);
2066bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Message m2 = createMessage(c, b2, false, false);
2067bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(a.mId, Message.getKeyColumnLong(c, m1.mId, MessageColumns.ACCOUNT_KEY));
2068bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(a.mId, Message.getKeyColumnLong(c, m2.mId, MessageColumns.ACCOUNT_KEY));
2069bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(b1.mId, Message.getKeyColumnLong(c, m1.mId, MessageColumns.MAILBOX_KEY));
2070bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        assertEquals(b2.mId, Message.getKeyColumnLong(c, m2.mId, MessageColumns.MAILBOX_KEY));
2071bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank    }
2072bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank
2073bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank    public void testGetAccountMailboxFromMessageId() {
2074bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        final Context c = mMockContext;
2075bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Account a = ProviderTestUtils.setupAccount("acct", true, c);
2076bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a.mId, true, c, Mailbox.TYPE_MAIL);
2077bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Mailbox b2 = ProviderTestUtils.setupMailbox("box2", a.mId, true, c, Mailbox.TYPE_MAIL);
2078bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Message m1 = createMessage(c, b1, false, false);
2079bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        Message m2 = createMessage(c, b2, false, false);
2080bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        ProviderTestUtils.assertAccountEqual("x", a, Account.getAccountForMessageId(c, m1.mId));
2081bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        ProviderTestUtils.assertAccountEqual("x", a, Account.getAccountForMessageId(c, m2.mId));
2082bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        // Restore the mailboxes, since the unread & total counts will have changed
2083bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        b1 = Mailbox.restoreMailboxWithId(c, b1.mId);
2084bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        b2 = Mailbox.restoreMailboxWithId(c, b2.mId);
2085bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        ProviderTestUtils.assertMailboxEqual("x", b1, Mailbox.getMailboxForMessageId(c, m1.mId));
2086bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank        ProviderTestUtils.assertMailboxEqual("x", b2, Mailbox.getMailboxForMessageId(c, m2.mId));
2087bca4e6e70b53ca7db0ac14522f0d26a7b465cf24Marc Blank    }
2088e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2089e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki    public void testGetAccountGetInboxIdTest() {
2090e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        final Context c = mMockContext;
2091e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2092e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        // Prepare some data with red-herrings.
2093e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Account a1 = ProviderTestUtils.setupAccount("acct1", true, c);
2094e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Account a2 = ProviderTestUtils.setupAccount("acct2", true, c);
2095e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox b1i = ProviderTestUtils.setupMailbox("b1i", a1.mId, true, c, Mailbox.TYPE_INBOX);
2096e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox b2a = ProviderTestUtils.setupMailbox("b2a", a2.mId, true, c, Mailbox.TYPE_MAIL);
2097e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox b2i = ProviderTestUtils.setupMailbox("b2b", a2.mId, true, c, Mailbox.TYPE_INBOX);
2098e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2099e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertEquals(b2i.mId, Account.getInboxId(c, a2.mId));
2100d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki
2101d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        // No account found.
2102d25d87c7ba8bbbbcad771695a7085f227bac8a1bMakoto Onuki        assertEquals(-1, Account.getInboxId(c, 999999));
2103e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki    }
2104e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2105a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki    public void testGetMailboxType() {
2106a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        final Context c = mMockContext;
2107a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki
2108a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        Account a = ProviderTestUtils.setupAccount("acct1", true, c);
2109a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        Mailbox bi = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_INBOX);
2110a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        Mailbox bm = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_MAIL);
2111a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki
2112a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        assertEquals(Mailbox.TYPE_INBOX, Mailbox.getMailboxType(c, bi.mId));
2113a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        assertEquals(Mailbox.TYPE_MAIL, Mailbox.getMailboxType(c, bm.mId));
2114a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        assertEquals(-1, Mailbox.getMailboxType(c, 999999)); // mailbox not found
2115a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki    }
2116a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki
2117e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki    public void testMailboxIsRefreshable() {
2118e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        final Context c = mMockContext;
2119e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2120e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Account a = ProviderTestUtils.setupAccount("acct1", true, c);
2121e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox bi = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_INBOX);
2122e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox bm = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_MAIL);
2123e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox bd = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_DRAFTS);
2124e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        Mailbox bo = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_OUTBOX);
2125e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2126e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertTrue(Mailbox.isRefreshable(c, bi.mId));
2127e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertTrue(Mailbox.isRefreshable(c, bm.mId));
2128e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertFalse(Mailbox.isRefreshable(c, bd.mId));
2129e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertFalse(Mailbox.isRefreshable(c, bo.mId));
2130e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2131e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        // No such mailbox
2132a25aa613f79a94d0dea395234ba383de63d03727Makoto Onuki        assertFalse(Mailbox.isRefreshable(c, 9999999));
2133e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki
2134e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        // Magic mailboxes can't be refreshed.
2135e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertFalse(Mailbox.isRefreshable(c, Mailbox.QUERY_ALL_DRAFTS));
2136e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki        assertFalse(Mailbox.isRefreshable(c, Mailbox.QUERY_ALL_INBOXES));
2137e357f5879187124c7af5c2ece5d7d3e4f60f07d2Makoto Onuki    }
2138767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki
2139767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki    public void testMailboxCanMoveFrom() {
2140767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        final Context c = mMockContext;
2141767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki
2142767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        Account a = ProviderTestUtils.setupAccount("acct1", true, c);
2143767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        Mailbox bi = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_INBOX);
2144767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        Mailbox bm = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_MAIL);
2145767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        Mailbox bd = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_DRAFTS);
2146767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        Mailbox bo = ProviderTestUtils.setupMailbox("b1", a.mId, true, c, Mailbox.TYPE_OUTBOX);
2147767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki
2148767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        assertTrue(Mailbox.canMoveFrom(c, bi.mId));
2149767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        assertTrue(Mailbox.canMoveFrom(c, bm.mId));
2150767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        assertFalse(Mailbox.canMoveFrom(c, bd.mId));
2151767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki        assertFalse(Mailbox.canMoveFrom(c, bo.mId));
2152767f9fe2ebcca7eee20f2a048f33a96ad4bf53daMakoto Onuki    }
2153261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2154261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki    /**
2155261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki     * Check if update to {@link Account#RESET_NEW_MESSAGE_COUNT_URI} resets the new message count.
2156261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki     */
2157261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki    public void testResetNewMessageCount() {
2158261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        final Context c = mMockContext;
2159261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        final ContentResolver cr = c.getContentResolver();
2160261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2161261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // Prepare test data
2162261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a1 = ProviderTestUtils.setupAccount("acct1", false, c);
2163261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a1.mNewMessageCount = 1;
2164261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a1.save(c);
2165261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a2 = ProviderTestUtils.setupAccount("acct2", false, c);
2166261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a2.mNewMessageCount = 2;
2167261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a2.save(c);
2168261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a3 = ProviderTestUtils.setupAccount("acct3", false, c);
2169261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a3.mNewMessageCount = 3;
2170261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a3.save(c);
2171261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a4 = ProviderTestUtils.setupAccount("acct4", false, c);
2172261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a4.mNewMessageCount = 4;
2173261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a4.save(c);
2174261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        Account a5 = ProviderTestUtils.setupAccount("acct5", false, c);
2175261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a5.mNewMessageCount = 5;
2176261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        a5.save(c);
2177261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2178261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // With ID in URI, no selection
2179261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(ContentUris.withAppendedId(Account.RESET_NEW_MESSAGE_COUNT_URI, a1.mId),
2180261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki                null, null, null);
2181261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
2182261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(2, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
2183261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(3, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
2184261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(4, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
2185261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(5, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
2186261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2187261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // No ID in URI, with selection
2188261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(Account.RESET_NEW_MESSAGE_COUNT_URI, null,
2189261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki                EmailContent.ID_SELECTION, new String[] {Long.toString(a2.mId)});
2190261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
2191261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
2192261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(3, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
2193261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(4, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
2194261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(5, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
2195261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2196261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // With ID, with selection
2197261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(ContentUris.withAppendedId(Account.RESET_NEW_MESSAGE_COUNT_URI, a3.mId), null,
2198261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki                EmailContent.ID_SELECTION, new String[] {Long.toString(a3.mId)});
2199261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
2200261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
2201261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
2202261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(4, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
2203261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(5, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
2204261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki
2205261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        // No ID in URI, no selection
2206261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        cr.update(Account.RESET_NEW_MESSAGE_COUNT_URI, null, null, null);
2207261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a1.mId).mNewMessageCount);
2208261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a2.mId).mNewMessageCount);
2209261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a3.mId).mNewMessageCount);
2210261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a4.mId).mNewMessageCount);
2211261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki        assertEquals(0, Account.restoreAccountWithId(c, a5.mId).mNewMessageCount);
2212261d6c3f0c97a12256519a2c3b131a56e57ab45fMakoto Onuki    }
2213899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2214899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki    private static Message createMessageWithTimestamp(Context c, Mailbox b, long timestamp) {
2215899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m = ProviderTestUtils.setupMessage("1", b.mAccountKey, b.mId, true, false, c, false,
2216899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki                false);
2217899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        m.mTimeStamp = timestamp;
2218899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        m.save(c);
2219899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        return m;
2220899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki    }
2221899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2222899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki    public void testMessageGetLatestMessage() {
2223899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        final Context c = mMockContext;
2224899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2225899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        // Create 2 accounts with a inbox.
2226899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Account a1 = ProviderTestUtils.setupAccount("a1", true, c);
2227899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Account a2 = ProviderTestUtils.setupAccount("a2", true, c);
2228899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2229899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Mailbox b1 = ProviderTestUtils.setupMailbox("box1", a1.mId, true, c, Mailbox.TYPE_INBOX);
2230899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Mailbox b2 = ProviderTestUtils.setupMailbox("box3", a2.mId, true, c, Mailbox.TYPE_INBOX);
2231899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2232899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        // Create some messages
2233899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m11 = createMessageWithTimestamp(c, b1, 33);
2234899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m12 = createMessageWithTimestamp(c, b1, 10);
2235899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m13 = createMessageWithTimestamp(c, b1, 1000);
2236899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2237899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m21 = createMessageWithTimestamp(c, b2, 99);
2238899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m22 = createMessageWithTimestamp(c, b2, 1);
2239899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        Message m23 = createMessageWithTimestamp(c, b2, 2);
2240899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2241899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        // Check!
2242899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        assertEquals(m13.mId, Message.getLatestMessage(c, a1.mId).mId);
2243899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        assertEquals(m21.mId, Message.getLatestMessage(c, a2.mId).mId);
2244899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki
2245899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        // No such account
2246899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki        assertEquals(null, Message.getLatestMessage(c, 9999999L));
2247899c5b866192a4c4a12413446d10e5d98dbf94faMakoto Onuki    }
22487143d969dde180b7a44bdc42ade6ca2878d0760dAndrew Stadler}
2249