diff options
Diffstat (limited to 'android/support/media/tv/ChannelLogoUtilsTest.java')
-rw-r--r-- | android/support/media/tv/ChannelLogoUtilsTest.java | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/android/support/media/tv/ChannelLogoUtilsTest.java b/android/support/media/tv/ChannelLogoUtilsTest.java new file mode 100644 index 00000000..ea315ab3 --- /dev/null +++ b/android/support/media/tv/ChannelLogoUtilsTest.java @@ -0,0 +1,99 @@ +/* + * Copyright (C) 2017 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 android.support.media.tv; + +import static android.support.test.InstrumentationRegistry.getContext; + +import static org.junit.Assert.assertNotNull; +import static org.junit.Assert.assertNull; +import static org.junit.Assert.assertTrue; + +import android.content.ContentResolver; +import android.content.ContentUris; +import android.content.ContentValues; +import android.content.res.Resources; +import android.graphics.Bitmap; +import android.graphics.BitmapFactory; +import android.media.tv.TvContract; +import android.net.Uri; +import android.os.SystemClock; +import android.support.media.tv.test.R; +import android.support.test.filters.MediumTest; +import android.support.test.filters.Suppress; +import android.support.test.runner.AndroidJUnit4; + +import org.junit.After; +import org.junit.Before; +import org.junit.Test; +import org.junit.runner.RunWith; + +@Suppress // Test is failing b/70905391 +@MediumTest +@RunWith(AndroidJUnit4.class) +public class ChannelLogoUtilsTest { + private static final String FAKE_INPUT_ID = "ChannelLogoUtils.test"; + + private ContentResolver mContentResolver; + private Uri mChannelUri; + private long mChannelId; + + @Before + public void setUp() throws Exception { + mContentResolver = getContext().getContentResolver(); + ContentValues contentValues = new Channel.Builder() + .setInputId(FAKE_INPUT_ID) + .setType(TvContractCompat.Channels.TYPE_OTHER).build().toContentValues(); + mChannelUri = mContentResolver.insert(TvContract.Channels.CONTENT_URI, contentValues); + mChannelId = ContentUris.parseId(mChannelUri); + } + + @After + public void tearDown() throws Exception { + mContentResolver.delete(mChannelUri, null, null); + } + + @Test + public void testStoreChannelLogo_fromBitmap() { + assertNull(ChannelLogoUtils.loadChannelLogo(getContext(), mChannelId)); + Bitmap logo = BitmapFactory.decodeResource(getContext().getResources(), + R.drawable.test_icon); + assertNotNull(logo); + assertTrue(ChannelLogoUtils.storeChannelLogo(getContext(), mChannelId, logo)); + // Workaround: the file status is not consistent between openInputStream/openOutputStream, + // wait 10 secs to make sure that the logo file is written into the disk. + SystemClock.sleep(10000); + assertNotNull(ChannelLogoUtils.loadChannelLogo(getContext(), mChannelId)); + } + + @Test + public void testStoreChannelLogo_fromResUri() { + assertNull(ChannelLogoUtils.loadChannelLogo(getContext(), mChannelId)); + int resId = R.drawable.test_icon; + Resources res = getContext().getResources(); + Uri logoUri = new Uri.Builder() + .scheme(ContentResolver.SCHEME_ANDROID_RESOURCE) + .authority(res.getResourcePackageName(resId)) + .appendPath(res.getResourceTypeName(resId)) + .appendPath(res.getResourceEntryName(resId)) + .build(); + assertTrue(ChannelLogoUtils.storeChannelLogo(getContext(), mChannelId, logoUri)); + // Workaround: the file status is not consistent between openInputStream/openOutputStream, + // wait 10 secs to make sure that the logo file is written into the disk. + SystemClock.sleep(10000); + assertNotNull(ChannelLogoUtils.loadChannelLogo(getContext(), mChannelId)); + } +} |