diff options
author | Xin Li <delphij@google.com> | 2018-08-06 16:51:26 -0700 |
---|---|---|
committer | Xin Li <delphij@google.com> | 2018-08-06 16:51:26 -0700 |
commit | aca265722281fe082995a71fd35401f766afac3e (patch) | |
tree | 28eac0d8752df3b094f50103a9ebb6d6340f4cc8 /tests/common/src/com/android/tv/testing/testdata/TestData.java | |
parent | 5fdc24aa6cc0acfd6a2d5939862e6edbe14f1ef6 (diff) | |
parent | c56e1892201e0b31f3043e37a32d779b4055cb34 (diff) | |
download | TV-aca265722281fe082995a71fd35401f766afac3e.tar.gz |
Merge Android Pie into masterandroid-o-mr1-iot-release-smart-display-r3android-o-mr1-iot-release-1.0.5android-o-mr1-iot-release-1.0.4android-o-mr1-iot-release-1.0.3oreo-mr1-1.2-iot-releasemaster-cuttlefish-testing-release
Bug: 112104996
Change-Id: Iec32f622f0bb1bc1583aefcbf6d115ad05baa693
Diffstat (limited to 'tests/common/src/com/android/tv/testing/testdata/TestData.java')
-rw-r--r-- | tests/common/src/com/android/tv/testing/testdata/TestData.java | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/tests/common/src/com/android/tv/testing/testdata/TestData.java b/tests/common/src/com/android/tv/testing/testdata/TestData.java new file mode 100644 index 00000000..e7e52348 --- /dev/null +++ b/tests/common/src/com/android/tv/testing/testdata/TestData.java @@ -0,0 +1,86 @@ +/* + * Copyright (C) 2018 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.tv.testing.testdata; + +import android.content.Context; +import android.media.tv.TvInputInfo; +import com.android.tv.common.util.Clock; +import com.android.tv.testing.data.ChannelInfo; +import com.android.tv.testing.data.ChannelUtils; +import com.android.tv.testing.data.ProgramUtils; +import com.android.tv.testing.utils.TestUtils; +import java.util.List; + +/** + * A set of test data. + * + * <p>contains: + * + * <ul> + * <li>InputID + * <li>Channel List + * </ul> + * + * Call {@link #init(Context)}, to update the TvProvider data base with the given values. + */ +public abstract class TestData { + private List<ChannelInfo> channelList; + + protected abstract List<ChannelInfo> createChannels(Context context); + + public void init(Context context, Clock clock, long durationMs) { + channelList = createChannels(context); + ChannelUtils.updateChannels(context, getInputId(), channelList); + ProgramUtils.updateProgramForAllChannelsOf(context, getInputId(), clock, durationMs); + } + + public abstract TvInputInfo getTvInputInfo(); + + public final String getInputId() { + return getTvInputInfo().getId(); + } + + public static final TestData DEFAULT_10_CHANNELS = + new TestData() { + private TvInputInfo mTvInputInfo = createTvInputInfo(); + + private TvInputInfo createTvInputInfo() { + try { + return TestUtils.createTvInputInfo( + TestUtils.createResolveInfo( + "com.android.tv.testing.testdata", + "com.android.tv.testing.testdata.Default10Channels"), + "com.android.tv.testing.testdata/.Default10Channels", + null, + TvInputInfo.TYPE_TUNER, + true); + } catch (Exception e) { + throw new RuntimeException(e); + } + } + + @Override + protected List<ChannelInfo> createChannels(Context context) { + return ChannelUtils.createChannelInfos(context, 10); + } + + @Override + public TvInputInfo getTvInputInfo() { + return mTvInputInfo; + } + }; +} |