diff options
Diffstat (limited to 'tests/src/com/android/gallery3d/data/RealDataTest.java')
-rw-r--r-- | tests/src/com/android/gallery3d/data/RealDataTest.java | 110 |
1 files changed, 110 insertions, 0 deletions
diff --git a/tests/src/com/android/gallery3d/data/RealDataTest.java b/tests/src/com/android/gallery3d/data/RealDataTest.java new file mode 100644 index 000000000..526cfe357 --- /dev/null +++ b/tests/src/com/android/gallery3d/data/RealDataTest.java @@ -0,0 +1,110 @@ +/* + * Copyright (C) 2010 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.gallery3d.data; + +import com.android.gallery3d.app.GalleryApp; +import com.android.gallery3d.picasasource.PicasaSource; + +import android.os.Looper; +import android.test.AndroidTestCase; +import android.test.suitebuilder.annotation.LargeTest; +import android.util.Log; + +import java.util.ArrayList; +import java.util.HashSet; + +// This test reads real data directly and dump information out in the log. +public class RealDataTest extends AndroidTestCase { + private static final String TAG = "RealDataTest"; + + private HashSet<Path> mUsedId = new HashSet<Path>(); + private GalleryApp mApplication; + private DataManager mDataManager; + + @LargeTest + public void testRealData() { + mUsedId.clear(); + mApplication = new GalleryAppMock( + mContext, + mContext.getContentResolver(), + Looper.myLooper()); + mDataManager = mApplication.getDataManager(); + mDataManager.addSource(new LocalSource(mApplication)); + mDataManager.addSource(new PicasaSource(mApplication)); + new TestLocalImage().run(); + new TestLocalVideo().run(); + new TestPicasa().run(); + } + + class TestLocalImage { + public void run() { + MediaSet set = mDataManager.getMediaSet("/local/image"); + set.reload(); + Log.v(TAG, "LocalAlbumSet (Image)"); + dumpMediaSet(set, ""); + } + } + + class TestLocalVideo { + public void run() { + MediaSet set = mDataManager.getMediaSet("/local/video"); + set.reload(); + Log.v(TAG, "LocalAlbumSet (Video)"); + dumpMediaSet(set, ""); + } + } + + class TestPicasa implements Runnable { + public void run() { + MediaSet set = mDataManager.getMediaSet("/picasa"); + set.reload(); + Log.v(TAG, "PicasaAlbumSet"); + dumpMediaSet(set, ""); + } + } + + void dumpMediaSet(MediaSet set, String prefix) { + Log.v(TAG, "getName() = " + set.getName()); + Log.v(TAG, "getPath() = " + set.getPath()); + Log.v(TAG, "getMediaItemCount() = " + set.getMediaItemCount()); + Log.v(TAG, "getSubMediaSetCount() = " + set.getSubMediaSetCount()); + Log.v(TAG, "getTotalMediaItemCount() = " + set.getTotalMediaItemCount()); + assertNewId(set.getPath()); + for (int i = 0, n = set.getSubMediaSetCount(); i < n; i++) { + MediaSet sub = set.getSubMediaSet(i); + Log.v(TAG, prefix + "got set " + i); + dumpMediaSet(sub, prefix + " "); + } + for (int i = 0, n = set.getMediaItemCount(); i < n; i += 10) { + ArrayList<MediaItem> list = set.getMediaItem(i, 10); + Log.v(TAG, prefix + "got item " + i + " (+" + list.size() + ")"); + for (MediaItem item : list) { + dumpMediaItem(item, prefix + ".."); + } + } + } + + void dumpMediaItem(MediaItem item, String prefix) { + assertNewId(item.getPath()); + Log.v(TAG, prefix + "getPath() = " + item.getPath()); + } + + void assertNewId(Path key) { + assertFalse(key + " has already appeared.", mUsedId.contains(key)); + mUsedId.add(key); + } +} |