This repository was archived by the owner on Apr 20, 2018. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
/
Copy pathsingleinstance.js
118 lines (96 loc) · 2.71 KB
/
singleinstance.js
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
113
114
115
116
117
118
(function () {
'use strict';
/* jshint undef: true, unused: true */
/* globals QUnit, test, Rx */
QUnit.module('singleInstance');
var TestScheduler = Rx.TestScheduler,
onNext = Rx.ReactiveTest.onNext,
onCompleted = Rx.ReactiveTest.onCompleted,
subscribe = Rx.ReactiveTest.subscribe,
created = Rx.ReactiveTest.created,
disposed = Rx.ReactiveTest.disposed,
subscribed = Rx.ReactiveTest.subscribed;
test('singleInstance basic', function () {
var scheduler = new TestScheduler();
var xs = scheduler.createColdObservable(
onNext(100, 1),
onNext(150, 2),
onNext(200, 3),
onCompleted(250)
);
var ys;
var results1 = scheduler.createObserver();
var results2 = scheduler.createObserver();
var disposable;
scheduler.scheduleAbsolute(null, created, function() {
ys = xs.singleInstance();
});
scheduler.scheduleAbsolute(null, subscribed, function() {
disposable = new Rx.CompositeDisposable(
ys.subscribe(results1),
ys.subscribe(results2)
);
});
scheduler.scheduleAbsolute(null, disposed, function() {
disposable.dispose();
});
scheduler.start();
results1.messages.assertEqual(
onNext(300, 1),
onNext(350, 2),
onNext(400, 3),
onCompleted(450)
);
results2.messages.assertEqual(
onNext(300, 1),
onNext(350, 2),
onNext(400, 3),
onCompleted(450)
);
xs.subscriptions.assertEqual(
subscribe(200, 450)
);
});
test('singleInstance can resubscribe after stopped', function () {
var scheduler = new TestScheduler();
var xs = scheduler.createColdObservable(
onNext(100, 1),
onNext(150, 2),
onNext(200, 3),
onCompleted(250)
);
var ys;
var results1 = scheduler.createObserver();
var results2 = scheduler.createObserver();
var disposable = new Rx.SerialDisposable();
scheduler.scheduleAbsolute(null, 100, function() {
ys = xs.singleInstance();
});
scheduler.scheduleAbsolute(null, 200, function() {
disposable.setDisposable(ys.subscribe(results1));
});
scheduler.scheduleAbsolute(null, 600, function() {
disposable.setDisposable(ys.subscribe(results2));
});
scheduler.scheduleAbsolute(null, 900, function(){
disposable.dispose();
});
scheduler.start();
results1.messages.assertEqual(
onNext(300, 1),
onNext(350, 2),
onNext(400, 3),
onCompleted(450)
);
results2.messages.assertEqual(
onNext(700, 1),
onNext(750, 2),
onNext(800, 3),
onCompleted(850)
);
xs.subscriptions.assertEqual(
subscribe(200, 450),
subscribe(600, 850)
);
});
}());