/**
* 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.schedulers;
import static org.junit.Assert.*;
import java.util.concurrent.TimeUnit;
import org.junit.Test;
import io.reactivex.Scheduler.Worker;
import io.reactivex.internal.disposables.EmptyDisposable;
import io.reactivex.internal.functions.Functions;
import io.reactivex.schedulers.Schedulers;
public class TrampolineSchedulerInternalTest {
@Test
public void scheduleDirectInterrupt() {
Thread.currentThread().interrupt();
final int[] calls = { 0 };
assertSame(EmptyDisposable.INSTANCE, Schedulers.trampoline().scheduleDirect(new Runnable() {
@Override
public void run() {
calls[0]++;
}
}, 1, TimeUnit.SECONDS));
assertTrue(Thread.interrupted());
assertEquals(0, calls[0]);
}
@Test
public void dispose() {
Worker w = Schedulers.trampoline().createWorker();
assertFalse(w.isDisposed());
w.dispose();
assertTrue(w.isDisposed());
assertEquals(EmptyDisposable.INSTANCE, w.schedule(Functions.EMPTY_RUNNABLE));
}
@Test
public void reentrantScheduleDispose() {
final Worker w = Schedulers.trampoline().createWorker();
try {
final int[] calls = { 0, 0 };
w.schedule(new Runnable() {
@Override
public void run() {
calls[0]++;
w.schedule(new Runnable() {
@Override
public void run() {
calls[1]++;
}
})
.dispose();
}
});
assertEquals(1, calls[0]);
assertEquals(0, calls[1]);
} finally {
w.dispose();
}
}
@Test
public void reentrantScheduleShutdown() {
final Worker w = Schedulers.trampoline().createWorker();
try {
final int[] calls = { 0, 0 };
w.schedule(new Runnable() {
@Override
public void run() {
calls[0]++;
w.schedule(new Runnable() {
@Override
public void run() {
calls[1]++;
}
}, 1, TimeUnit.MILLISECONDS);
w.dispose();
}
});
assertEquals(1, calls[0]);
assertEquals(0, calls[1]);
} finally {
w.dispose();
}
}
@Test
public void reentrantScheduleShutdown2() {
final Worker w = Schedulers.trampoline().createWorker();
try {
final int[] calls = { 0, 0 };
w.schedule(new Runnable() {
@Override
public void run() {
calls[0]++;
w.dispose();
assertSame(EmptyDisposable.INSTANCE, w.schedule(new Runnable() {
@Override
public void run() {
calls[1]++;
}
}, 1, TimeUnit.MILLISECONDS));
}
});
assertEquals(1, calls[0]);
assertEquals(0, calls[1]);
} finally {
w.dispose();
}
}
@Test(timeout = 5000)
public void reentrantScheduleInterrupt() {
final Worker w = Schedulers.trampoline().createWorker();
try {
final int[] calls = { 0 };
Thread.currentThread().interrupt();
w.schedule(new Runnable() {
@Override
public void run() {
calls[0]++;
}
}, 1, TimeUnit.DAYS);
assertTrue(Thread.interrupted());
assertEquals(0, calls[0]);
} finally {
w.dispose();
}
}
}