Skip to content

Commit

Permalink
Merge pull request ReactiveX#220 from johngmyers/takewhile-predicate
Browse files Browse the repository at this point in the history
TakeWhile protect calls to predicate
  • Loading branch information
benjchristensen committed Apr 1, 2013
2 parents ce51735 + da27629 commit 0ed6a79
Showing 1 changed file with 38 additions and 1 deletion.
39 changes: 38 additions & 1 deletion rxjava-core/src/main/java/rx/operators/OperationTakeWhile.java
Original file line number Diff line number Diff line change
Expand Up @@ -123,7 +123,15 @@ public void onError(Exception e) {

@Override
public void onNext(T args) {
if (predicate.call(args, counter.getAndIncrement())) {
Boolean isSelected;
try {
isSelected = predicate.call(args, counter.getAndIncrement());
}
catch (Exception e) {
observer.onError(e);
return;
}
if (isSelected) {
observer.onNext(args);
} else {
observer.onCompleted();
Expand Down Expand Up @@ -238,6 +246,35 @@ public Boolean call(String s)
})).last();
}

@Test
public void testTakeWhileProtectsPredicateCall() {
TestObservable source = new TestObservable(mock(Subscription.class), "one");
final RuntimeException testException = new RuntimeException("test exception");

@SuppressWarnings("unchecked")
Observer<String> aObserver = mock(Observer.class);
Observable<String> take = Observable.create(takeWhile(source, new Func1<String, Boolean>()
{
@Override
public Boolean call(String s)
{
throw testException;
}
}));
take.subscribe(aObserver);

// wait for the Observable to complete
try {
source.t.join();
} catch (Exception e) {
e.printStackTrace();
fail(e.getMessage());
}

verify(aObserver, never()).onNext(any(String.class));
verify(aObserver, times(1)).onError(testException);
}

@Test
public void testUnsubscribeAfterTake() {
Subscription s = mock(Subscription.class);
Expand Down

0 comments on commit 0ed6a79

Please sign in to comment.