Skip to content

Commit a2cb6ab

Browse files
authored
2.x: coverage, fixes and cleanup 10/11-2 (#4692)
1 parent 6ad74b3 commit a2cb6ab

File tree

61 files changed

+3765
-334
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

61 files changed

+3765
-334
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
/**
2+
* Copyright 2016 Netflix, Inc.
3+
*
4+
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in
5+
* compliance with the License. You may obtain a copy of the License at
6+
*
7+
* http://www.apache.org/licenses/LICENSE-2.0
8+
*
9+
* Unless required by applicable law or agreed to in writing, software distributed under the License is
10+
* distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See
11+
* the License for the specific language governing permissions and limitations under the License.
12+
*/
13+
14+
package io.reactivex.internal.observers;
15+
16+
import java.util.concurrent.atomic.AtomicReference;
17+
18+
import io.reactivex.SingleObserver;
19+
import io.reactivex.disposables.Disposable;
20+
import io.reactivex.internal.disposables.DisposableHelper;
21+
22+
/**
23+
* A SingleObserver implementation used for subscribing to the actual SingleSource
24+
* and replace the current Disposable in a parent AtomicReference.
25+
*
26+
* @param <T> the value type
27+
*/
28+
public final class ResumeSingleObserver<T> implements SingleObserver<T> {
29+
30+
final AtomicReference<Disposable> parent;
31+
32+
final SingleObserver<? super T> actual;
33+
34+
public ResumeSingleObserver(AtomicReference<Disposable> parent, SingleObserver<? super T> actual) {
35+
this.parent = parent;
36+
this.actual = actual;
37+
}
38+
39+
@Override
40+
public void onSubscribe(Disposable d) {
41+
DisposableHelper.replace(parent, d);
42+
}
43+
44+
@Override
45+
public void onSuccess(T value) {
46+
actual.onSuccess(value);
47+
}
48+
49+
@Override
50+
public void onError(Throwable e) {
51+
actual.onError(e);
52+
}
53+
}

src/main/java/io/reactivex/internal/operators/completable/CompletableDisposeOn.java

+55-22
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,9 @@
1414
package io.reactivex.internal.operators.completable;
1515

1616
import io.reactivex.*;
17-
import io.reactivex.disposables.*;
17+
import io.reactivex.disposables.Disposable;
18+
import io.reactivex.internal.disposables.DisposableHelper;
19+
import io.reactivex.plugins.RxJavaPlugins;
1820

1921
public final class CompletableDisposeOn extends Completable {
2022

@@ -29,34 +31,65 @@ public CompletableDisposeOn(CompletableSource source, Scheduler scheduler) {
2931

3032
@Override
3133
protected void subscribeActual(final CompletableObserver s) {
32-
source.subscribe(new CompletableObserver() {
34+
source.subscribe(new CompletableObserverImplementation(s, scheduler));
35+
}
36+
37+
static final class CompletableObserverImplementation implements CompletableObserver, Disposable, Runnable {
38+
final CompletableObserver s;
39+
40+
final Scheduler scheduler;
41+
42+
Disposable d;
43+
44+
volatile boolean disposed;
3345

34-
@Override
35-
public void onComplete() {
36-
s.onComplete();
46+
CompletableObserverImplementation(CompletableObserver s, Scheduler scheduler) {
47+
this.s = s;
48+
this.scheduler = scheduler;
49+
}
50+
51+
@Override
52+
public void onComplete() {
53+
if (disposed) {
54+
return;
3755
}
56+
s.onComplete();
57+
}
3858

39-
@Override
40-
public void onError(Throwable e) {
41-
s.onError(e);
59+
@Override
60+
public void onError(Throwable e) {
61+
if (disposed) {
62+
RxJavaPlugins.onError(e);
63+
return;
4264
}
65+
s.onError(e);
66+
}
67+
68+
@Override
69+
public void onSubscribe(final Disposable d) {
70+
if (DisposableHelper.validate(this.d, d)) {
71+
this.d = d;
4372

44-
@Override
45-
public void onSubscribe(final Disposable d) {
46-
s.onSubscribe(Disposables.fromRunnable(new Runnable() {
47-
@Override
48-
public void run() {
49-
scheduler.scheduleDirect(new Runnable() {
50-
@Override
51-
public void run() {
52-
d.dispose();
53-
}
54-
});
55-
}
56-
}));
73+
s.onSubscribe(this);
5774
}
75+
}
76+
77+
@Override
78+
public void dispose() {
79+
disposed = true;
80+
scheduler.scheduleDirect(this);
81+
}
82+
83+
@Override
84+
public boolean isDisposed() {
85+
return disposed;
86+
}
5887

59-
});
88+
@Override
89+
public void run() {
90+
d.dispose();
91+
d = DisposableHelper.DISPOSED;
92+
}
6093
}
6194

6295
}

src/main/java/io/reactivex/internal/operators/completable/CompletableDoOnEvent.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -52,7 +52,7 @@ public void onError(Throwable e) {
5252
onEvent.accept(e);
5353
} catch (Throwable ex) {
5454
Exceptions.throwIfFatal(ex);
55-
e = new CompositeException(ex, e);
55+
e = new CompositeException(e, ex);
5656
}
5757

5858
s.onError(e);

src/main/java/io/reactivex/internal/operators/completable/CompletableResumeNext.java

+1
Original file line numberDiff line numberDiff line change
@@ -37,6 +37,7 @@ public CompletableResumeNext(CompletableSource source,
3737
protected void subscribeActual(final CompletableObserver s) {
3838

3939
final SequentialDisposable sd = new SequentialDisposable();
40+
s.onSubscribe(sd);
4041
source.subscribe(new CompletableObserver() {
4142

4243
@Override

src/main/java/io/reactivex/internal/operators/completable/CompletableSubscribeOn.java

+13-10
Original file line numberDiff line numberDiff line change
@@ -32,35 +32,38 @@ public CompletableSubscribeOn(CompletableSource source, Scheduler scheduler) {
3232
@Override
3333
protected void subscribeActual(final CompletableObserver s) {
3434

35-
final SubscribeOnObserver parent = new SubscribeOnObserver(s);
35+
final SubscribeOnObserver parent = new SubscribeOnObserver(s, source);
3636
s.onSubscribe(parent);
3737

38-
Disposable f = scheduler.scheduleDirect(new Runnable() {
39-
@Override
40-
public void run() {
41-
source.subscribe(parent);
42-
}
43-
});
38+
Disposable f = scheduler.scheduleDirect(parent);
4439

4540
parent.task.replace(f);
4641

4742
}
4843

4944
static final class SubscribeOnObserver
5045
extends AtomicReference<Disposable>
51-
implements CompletableObserver, Disposable {
46+
implements CompletableObserver, Disposable, Runnable {
5247

5348
private static final long serialVersionUID = 7000911171163930287L;
5449

5550
final CompletableObserver actual;
5651

5752
final SequentialDisposable task;
5853

59-
SubscribeOnObserver(CompletableObserver actual) {
54+
final CompletableSource source;
55+
56+
SubscribeOnObserver(CompletableObserver actual, CompletableSource source) {
6057
this.actual = actual;
58+
this.source = source;
6159
this.task = new SequentialDisposable();
6260
}
6361

62+
@Override
63+
public void run() {
64+
source.subscribe(this);
65+
}
66+
6467
@Override
6568
public void onSubscribe(Disposable d) {
6669
DisposableHelper.setOnce(this, d);
@@ -84,7 +87,7 @@ public void dispose() {
8487

8588
@Override
8689
public boolean isDisposed() {
87-
return DisposableHelper.isDisposed(this);
90+
return DisposableHelper.isDisposed(get());
8891
}
8992
}
9093

0 commit comments

Comments
 (0)