/** * Copyright (c) 2016-present, RxJava Contributors. * * 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 io.reactivex.internal.operators.observable; import static org.junit.Assert.*; import static org.mockito.Mockito.*; import java.util.ArrayList; import java.util.concurrent.atomic.*; import org.junit.Test; import io.reactivex.*; import io.reactivex.functions.Consumer; import io.reactivex.internal.fuseable.QueueDisposable; import io.reactivex.observers.*; public class ObservableRangeTest { @Test public void testRangeStartAt2Count3() { Observer<Integer> observer = TestHelper.mockObserver(); Observable.range(2, 3).subscribe(observer); verify(observer, times(1)).onNext(2); verify(observer, times(1)).onNext(3); verify(observer, times(1)).onNext(4); verify(observer, never()).onNext(5); verify(observer, never()).onError(any(Throwable.class)); verify(observer, times(1)).onComplete(); } @Test public void testRangeUnsubscribe() { Observer<Integer> observer = TestHelper.mockObserver(); final AtomicInteger count = new AtomicInteger(); Observable.range(1, 1000).doOnNext(new Consumer<Integer>() { @Override public void accept(Integer t1) { count.incrementAndGet(); } }) .take(3).subscribe(observer); verify(observer, times(1)).onNext(1); verify(observer, times(1)).onNext(2); verify(observer, times(1)).onNext(3); verify(observer, never()).onNext(4); verify(observer, never()).onError(any(Throwable.class)); verify(observer, times(1)).onComplete(); assertEquals(3, count.get()); } @Test public void testRangeWithZero() { Observable.range(1, 0); } @Test public void testRangeWithOverflow2() { Observable.range(Integer.MAX_VALUE, 0); } @Test public void testRangeWithOverflow3() { Observable.range(1, Integer.MAX_VALUE); } @Test(expected = IllegalArgumentException.class) public void testRangeWithOverflow4() { Observable.range(2, Integer.MAX_VALUE); } @Test public void testRangeWithOverflow5() { assertFalse(Observable.range(Integer.MIN_VALUE, 0).blockingIterable().iterator().hasNext()); } @Test public void testNoBackpressure() { ArrayList<Integer> list = new ArrayList<Integer>(Flowable.bufferSize() * 2); for (int i = 1; i <= Flowable.bufferSize() * 2 + 1; i++) { list.add(i); } Observable<Integer> o = Observable.range(1, list.size()); TestObserver<Integer> ts = new TestObserver<Integer>(); o.subscribe(ts); ts.assertValueSequence(list); ts.assertTerminated(); } @Test public void testEmptyRangeSendsOnCompleteEagerlyWithRequestZero() { final AtomicBoolean completed = new AtomicBoolean(false); Observable.range(1, 0).subscribe(new DefaultObserver<Integer>() { @Override public void onStart() { // request(0); } @Override public void onComplete() { completed.set(true); } @Override public void onError(Throwable e) { } @Override public void onNext(Integer t) { }}); assertTrue(completed.get()); } @Test(timeout = 1000) public void testNearMaxValueWithoutBackpressure() { TestObserver<Integer> ts = new TestObserver<Integer>(); Observable.range(Integer.MAX_VALUE - 1, 2).subscribe(ts); ts.assertComplete(); ts.assertNoErrors(); ts.assertValues(Integer.MAX_VALUE - 1, Integer.MAX_VALUE); } @Test public void negativeCount() { try { Observable.range(1, -1); fail("Should have thrown IllegalArgumentException"); } catch (IllegalArgumentException ex) { assertEquals("count >= 0 required but it was -1", ex.getMessage()); } } @Test public void requestWrongFusion() { TestObserver<Integer> to = ObserverFusion.newTest(QueueDisposable.ASYNC); Observable.range(1, 5) .subscribe(to); ObserverFusion.assertFusion(to, QueueDisposable.NONE) .assertResult(1, 2, 3, 4, 5); } }