/* * Copyright (C) 2015 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.dvr; import android.test.suitebuilder.annotation.SmallTest; import com.android.tv.testing.dvr.RecordingTestUtils; import junit.framework.TestCase; import java.util.ArrayList; import java.util.List; /** * Tests for {@link DvrDataManagerImpl} */ @SmallTest public class DvrDataManagerImplTest extends TestCase { private static final int CHANNEL_ID = 273; public void testGetNextScheduledStartTimeAfter() throws Exception { long id = 1; List scheduledRecordings = new ArrayList<>(); assertNextStartTime(scheduledRecordings, 0L, DvrDataManager.NEXT_START_TIME_NOT_FOUND); scheduledRecordings.add(RecordingTestUtils .createTestRecordingWithIdAndPeriod(id++, CHANNEL_ID, 10L, 20L)); assertNextStartTime(scheduledRecordings, 9L, 10L); assertNextStartTime(scheduledRecordings, 10L, DvrDataManager.NEXT_START_TIME_NOT_FOUND); scheduledRecordings.add(RecordingTestUtils .createTestRecordingWithIdAndPeriod(id++, CHANNEL_ID, 20L, 30L)); assertNextStartTime(scheduledRecordings, 9L, 10L); assertNextStartTime(scheduledRecordings, 10L, 20L); assertNextStartTime(scheduledRecordings, 20L, DvrDataManager.NEXT_START_TIME_NOT_FOUND); scheduledRecordings.add(RecordingTestUtils .createTestRecordingWithIdAndPeriod(id++, CHANNEL_ID, 30L, 40L)); assertNextStartTime(scheduledRecordings, 9L, 10L); assertNextStartTime(scheduledRecordings, 10L, 20L); assertNextStartTime(scheduledRecordings, 20L, 30L); assertNextStartTime(scheduledRecordings, 30L, DvrDataManager.NEXT_START_TIME_NOT_FOUND); scheduledRecordings.clear(); scheduledRecordings.add(RecordingTestUtils .createTestRecordingWithIdAndPeriod(id++, CHANNEL_ID, 10L, 20L)); scheduledRecordings.add(RecordingTestUtils .createTestRecordingWithIdAndPeriod(id++, CHANNEL_ID, 10L, 20L)); scheduledRecordings.add(RecordingTestUtils .createTestRecordingWithIdAndPeriod(id++, CHANNEL_ID, 10L, 20L)); assertNextStartTime(scheduledRecordings, 9L, 10L); assertNextStartTime(scheduledRecordings, 10L, DvrDataManager.NEXT_START_TIME_NOT_FOUND); } private void assertNextStartTime(List scheduledRecordings, long startTime, long expected) { assertEquals("getNextScheduledStartTimeAfter()", expected, DvrDataManagerImpl.getNextStartTimeAfter(scheduledRecordings, startTime)); } }