diff options
author | Paul Miller <paulmiller@google.com> | 2015-03-16 17:22:30 -0700 |
---|---|---|
committer | Paul Miller <paulmiller@google.com> | 2015-03-18 13:37:15 -0700 |
commit | 2ed4f50286b888c7c366923f35dd0f8e893d255e (patch) | |
tree | b9fb07de8b5fb24c85fcd8fc02d59453f3fc852f /tests/src/com/android/bookmarkstore/tests/utils/BP2TestCaseHelper.java | |
parent | 01a22a729f76117a9df1767fb484a24813478009 (diff) | |
download | android_packages_providers_BookmarkProvider-2ed4f50286b888c7c366923f35dd0f8e893d255e.tar.gz android_packages_providers_BookmarkProvider-2ed4f50286b888c7c366923f35dd0f8e893d255e.tar.bz2 android_packages_providers_BookmarkProvider-2ed4f50286b888c7c366923f35dd0f8e893d255e.zip |
Create BrowserProvider
BookmarkProvider is the provider code from the legacy Browser,
refactored into its own app. It can be used as a ContentProvider for
bookmarks.
BUG:19351071
Change-Id: I52a2581b4944859fa91fdc277440855c829c6c3e
Diffstat (limited to 'tests/src/com/android/bookmarkstore/tests/utils/BP2TestCaseHelper.java')
-rw-r--r-- | tests/src/com/android/bookmarkstore/tests/utils/BP2TestCaseHelper.java | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/tests/src/com/android/bookmarkstore/tests/utils/BP2TestCaseHelper.java b/tests/src/com/android/bookmarkstore/tests/utils/BP2TestCaseHelper.java new file mode 100644 index 0000000..57ce669 --- /dev/null +++ b/tests/src/com/android/bookmarkstore/tests/utils/BP2TestCaseHelper.java @@ -0,0 +1,99 @@ +/* + * Copyright (C) 2011 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.bookmarkprovider.tests.utils; + +import com.android.bookmarkprovider.BookmarkProvider; + +import java.io.File; +import java.io.FilenameFilter; + +import android.content.ContentValues; +import android.net.Uri; +import android.provider.BrowserContract; +import android.provider.BrowserContract.Bookmarks; + +/** + * This is a replacement for ProviderTestCase2 that can handle notifyChange testing. + * It also has helper methods specifically for testing BookmarkProvider + */ +public abstract class BP2TestCaseHelper extends ProviderTestCase3<BookmarkProvider> { + + // Tag for potential performance impacts + private static final String PERFTAG = "BP2-PerfCheck"; + + @Override + protected void setUp() throws Exception { + super.setUp(); + } + + public BP2TestCaseHelper() { + super(BookmarkProvider.class, + BrowserContract.AUTHORITY, BookmarkProvider.LEGACY_AUTHORITY); + } + + Uri mockInsert(Uri uri, ContentValues values) { + return getMockContentResolver().insert(uri, values); + } + + int mockUpdate(Uri uri, ContentValues values, String where, + String[] selectionArgs) { + return getMockContentResolver().update(uri, values, where, selectionArgs); + } + + public Uri insertBookmark(String url, String title) { + ContentValues values = new ContentValues(); + values.put(BrowserContract.Bookmarks.TITLE, title); + values.put(BrowserContract.Bookmarks.URL, url); + values.put(BrowserContract.Bookmarks.IS_FOLDER, 0); + return insertBookmark(values); + } + + public Uri insertBookmark(ContentValues values) { + return mockInsert(Bookmarks.CONTENT_URI, values); + } + + public boolean updateBookmark(Uri uri, String url, String title) { + ContentValues values = new ContentValues(); + values.put(BrowserContract.Bookmarks.TITLE, title); + values.put(BrowserContract.Bookmarks.URL, url); + return updateBookmark(uri, values); + } + + public boolean updateBookmark(Uri uri, ContentValues values) { + int modifyCount = mockUpdate(uri, values, null, null); + assertTrue("UpdatedBookmark modified too much! " + uri, modifyCount <= 1); + return modifyCount == 1; + } + + @Override + protected void tearDown() throws Exception { + super.tearDown(); + // Delete the test databases so that subsequent runs have a clean slate + File f = getMockContext().getDatabasePath("test"); + File dir = f.getParentFile(); + File testFiles[] = dir.listFiles(new FilenameFilter() { + + @Override + public boolean accept(File dir, String filename) { + return filename.startsWith(ProviderTestCase3.FILENAME_PREFIX); + } + }); + for (File testFile : testFiles) { + testFile.delete(); + } + } +} |