diff options
author | Brandon Maxwell <maxwelb@google.com> | 2016-02-24 01:16:09 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2016-02-24 01:16:10 +0000 |
commit | f7d748077c3ef424eab2c7740e6868ba6ad3e4b9 (patch) | |
tree | 7eb7abf0de605df850036890dba4b85fe7316fc5 /tests | |
parent | 82557da65e5b16ac9d95e2bb5b73c2e5c1e88a89 (diff) | |
parent | 7fa52722af646f1aa39afc0fcbcb9d956510c067 (diff) |
Merge "Added tests for FilteredNumAsyncQueryHandler" into nyc-dev
Diffstat (limited to 'tests')
-rw-r--r-- | tests/src/com/android/dialer/database/FilteredNumberAsyncQueryHandlerTest.java | 172 |
1 files changed, 172 insertions, 0 deletions
diff --git a/tests/src/com/android/dialer/database/FilteredNumberAsyncQueryHandlerTest.java b/tests/src/com/android/dialer/database/FilteredNumberAsyncQueryHandlerTest.java new file mode 100644 index 000000000..fd60d731a --- /dev/null +++ b/tests/src/com/android/dialer/database/FilteredNumberAsyncQueryHandlerTest.java @@ -0,0 +1,172 @@ +/* + * Copyright (C) 2016 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.android.dialer.database; + +import android.content.pm.ProviderInfo; +import android.net.Uri; +import android.test.InstrumentationTestCase; +import android.test.mock.MockContentResolver; + +import com.android.contacts.common.test.mocks.MockContentProvider; +import com.android.contacts.common.test.mocks.MockContentProvider.Query; +import com.android.dialer.database.FilteredNumberAsyncQueryHandler.OnCheckBlockedListener; +import com.android.dialer.database.FilteredNumberAsyncQueryHandler.OnHasBlockedNumbersListener; +import com.android.dialer.database.FilteredNumberContract.FilteredNumberColumns; +import com.android.dialer.database.FilteredNumberContract.FilteredNumberTypes; + +import java.util.concurrent.CountDownLatch; +import java.util.concurrent.TimeUnit; + +public class FilteredNumberAsyncQueryHandlerTest extends InstrumentationTestCase { + + private static final String E164_NUMBER = "+16502530000"; + private static final String NUMBER = "6502530000"; + private static final String COUNTRY_ISO = "US"; + private static final Integer ID = 1; + private static final Uri BLOCKED_NUMBER_URI = + Uri.withAppendedPath(FilteredNumberContract.AUTHORITY_URI, "filtered_numbers_table"); + + private final MockContentResolver mContentResolver = new MockContentResolver(); + private final MockContentProvider mContentProvider = new MockContentProvider(); + + @Override + public void setUp() throws Exception { + super.setUp(); + setUpProviderForAuthority(mContentProvider, FilteredNumberContract.AUTHORITY, + mContentResolver); + } + + private void setUpProviderForAuthority(MockContentProvider provider, String authority, + MockContentResolver contentResolver) { + ProviderInfo providerInfo = new ProviderInfo(); + providerInfo.authority = authority; + provider.attachInfo(null, providerInfo); + contentResolver.addProvider(authority, provider); + } + + public void testIsBlockedNumber_NoResults() throws Throwable { + newIsBlockedNumberExpectedQueryM().returnEmptyCursor(); + final CheckBlockedListener listener = new CheckBlockedListener(); + + runTestOnUiThread(new Runnable() { + @Override + public void run() { + new FilteredNumberAsyncQueryHandler(mContentResolver) + .isBlockedNumber(listener, NUMBER, COUNTRY_ISO); + } + }); + assertNull(listener.waitForCallback()); + mContentProvider.verify(); + } + + public void testIsBlockedNumber() throws Throwable { + newIsBlockedNumberExpectedQueryM().returnRow(ID, FilteredNumberTypes.BLOCKED_NUMBER); + final CheckBlockedListener listener = new CheckBlockedListener(); + runTestOnUiThread(new Runnable() { + @Override + public void run() { + new FilteredNumberAsyncQueryHandler(mContentResolver) + .isBlockedNumber(listener, NUMBER, COUNTRY_ISO); + } + }); + assertEquals(ID, listener.waitForCallback()); + mContentProvider.verify(); + } + + public void testHasBlockedNumbers_NoResults() throws Throwable { + newHasBlockedNumbersExpectedQueryM().returnEmptyCursor(); + final HasBlockedNumbersListener listener = new HasBlockedNumbersListener(); + runTestOnUiThread(new Runnable() { + @Override + public void run() { + new FilteredNumberAsyncQueryHandler(mContentResolver).hasBlockedNumbers(listener); + } + }); + assertFalse(listener.waitForCallback()); + mContentProvider.verify(); + } + + public void testHasBlockedNumbers() throws Throwable { + newHasBlockedNumbersExpectedQueryM().returnRow(ID); + final HasBlockedNumbersListener listener = new HasBlockedNumbersListener(); + runTestOnUiThread(new Runnable() { + @Override + public void run() { + new FilteredNumberAsyncQueryHandler(mContentResolver).hasBlockedNumbers(listener); + } + }); + assertTrue(listener.waitForCallback()); + mContentProvider.verify(); + } + + private Query newIsBlockedNumberExpectedQueryM() { + return mContentProvider.expectQuery(BLOCKED_NUMBER_URI) + .withProjection(FilteredNumberColumns._ID, FilteredNumberColumns.TYPE) + .withSelection(FilteredNumberColumns.NORMALIZED_NUMBER + " = ?", E164_NUMBER); + } + + private Query newHasBlockedNumbersExpectedQueryM() { + return mContentProvider.expectQuery(BLOCKED_NUMBER_URI).withProjection( + FilteredNumberColumns._ID) + .withSelection(FilteredNumberColumns.TYPE + "=" + + FilteredNumberTypes.BLOCKED_NUMBER); + } + + private class CheckBlockedListener implements OnCheckBlockedListener { + public final CountDownLatch onCheckCompleteCalled; + public Integer id; + + public CheckBlockedListener() { + onCheckCompleteCalled = new CountDownLatch(1); + } + + @Override + public void onCheckComplete(Integer id) { + this.id = id; + onCheckCompleteCalled.countDown(); + } + + public Integer waitForCallback() throws InterruptedException { + if (!onCheckCompleteCalled.await(5000, TimeUnit.MILLISECONDS)) { + throw new IllegalStateException("Waiting on callback timed out."); + } + return id; + } + } + + private class HasBlockedNumbersListener implements OnHasBlockedNumbersListener { + public final CountDownLatch onHasBlockedNumbersCalled; + public boolean hasBlockedNumbers; + + public HasBlockedNumbersListener() { + onHasBlockedNumbersCalled = new CountDownLatch(1); + } + + @Override + public void onHasBlockedNumbers(boolean hasBlockedNumbers) { + this.hasBlockedNumbers = hasBlockedNumbers; + onHasBlockedNumbersCalled.countDown(); + } + + public boolean waitForCallback() throws InterruptedException { + if (!onHasBlockedNumbersCalled.await(5000, TimeUnit.MILLISECONDS)) { + throw new IllegalStateException("Waiting on callback timed out."); + } + return hasBlockedNumbers; + } + } +} |