1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
|
import unittest
import reactivex
from reactivex import operators as ops
from reactivex.testing import ReactiveTest, TestScheduler
on_next = ReactiveTest.on_next
on_completed = ReactiveTest.on_completed
on_error = ReactiveTest.on_error
subscribe = ReactiveTest.subscribe
subscribed = ReactiveTest.subscribed
disposed = ReactiveTest.disposed
created = ReactiveTest.created
class RxException(Exception):
pass
# Helper function for raising exceptions within lambdas
def _raise(ex):
raise RxException(ex)
class TestGenerate(unittest.TestCase):
def test_generate_finite(self):
scheduler = TestScheduler()
def create():
return reactivex.generate(
0,
lambda x: x <= 3,
lambda x: x + 1,
)
results = scheduler.start(create)
assert results.messages == [
on_next(200, 0),
on_next(200, 1),
on_next(200, 2),
on_next(200, 3),
on_completed(200),
]
def test_generate_throw_condition(self):
scheduler = TestScheduler()
ex = "ex"
def create():
return reactivex.generate(
0,
lambda x: _raise("ex"),
lambda x: x + 1,
)
results = scheduler.start(create)
assert results.messages == [on_error(200, ex)]
def test_generate_throw_iterate(self):
scheduler = TestScheduler()
ex = "ex"
def create():
return reactivex.generate(
0,
lambda x: True,
lambda x: _raise(ex),
)
results = scheduler.start(create)
assert results.messages == [on_next(200, 0), on_error(200, ex)]
def test_generate_dispose(self):
scheduler = TestScheduler()
ex = "ex"
def create():
return reactivex.generate(
0,
lambda x: True,
lambda x: x + 1,
)
results = scheduler.start(create, disposed=200)
assert results.messages == []
def test_generate_repeat(self):
scheduler = TestScheduler()
def create():
return reactivex.generate(
0,
lambda x: x <= 3,
lambda x: x + 1,
).pipe(ops.repeat(2))
results = scheduler.start(create)
assert results.messages == [
on_next(200, 0),
on_next(200, 1),
on_next(200, 2),
on_next(200, 3),
on_next(200, 0),
on_next(200, 1),
on_next(200, 2),
on_next(200, 3),
on_completed(200),
]
|