on-zero 0.4.25 → 0.4.27
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/createUseQuery.cjs +28 -16
- package/dist/cjs/createUseQuery.native.js +42 -30
- package/dist/cjs/createUseQuery.native.js.map +1 -1
- package/dist/cjs/createZeroClient.cjs +13 -1
- package/dist/cjs/createZeroClient.native.js +13 -1
- package/dist/cjs/createZeroClient.native.js.map +1 -1
- package/dist/cjs/httpPull/auth.test.cjs +197 -0
- package/dist/cjs/httpPull/auth.test.native.js +279 -0
- package/dist/cjs/httpPull/auth.test.native.js.map +1 -0
- package/dist/cjs/httpPull/churn.test.cjs +132 -0
- package/dist/cjs/httpPull/churn.test.native.js +155 -0
- package/dist/cjs/httpPull/churn.test.native.js.map +1 -0
- package/dist/cjs/httpPull/fixtureSchema.cjs +76 -0
- package/dist/cjs/httpPull/fixtureSchema.native.js +82 -0
- package/dist/cjs/httpPull/fixtureSchema.native.js.map +1 -0
- package/dist/cjs/httpPull/fixtureServer.cjs +340 -0
- package/dist/cjs/httpPull/fixtureServer.native.js +534 -0
- package/dist/cjs/httpPull/fixtureServer.native.js.map +1 -0
- package/dist/cjs/httpPull/integration.test.cjs +53 -0
- package/dist/cjs/httpPull/integration.test.native.js +60 -0
- package/dist/cjs/httpPull/integration.test.native.js.map +1 -0
- package/dist/cjs/httpPull/rebase.test.cjs +360 -0
- package/dist/cjs/httpPull/rebase.test.native.js +420 -0
- package/dist/cjs/httpPull/rebase.test.native.js.map +1 -0
- package/dist/cjs/httpPull/relations.test.cjs +107 -0
- package/dist/cjs/httpPull/relations.test.native.js +119 -0
- package/dist/cjs/httpPull/relations.test.native.js.map +1 -0
- package/dist/cjs/httpPull/testHarness.cjs +100 -0
- package/dist/cjs/httpPull/testHarness.native.js +112 -0
- package/dist/cjs/httpPull/testHarness.native.js.map +1 -0
- package/dist/cjs/httpPull/transport.test.cjs +568 -0
- package/dist/cjs/httpPull/transport.test.native.js +655 -0
- package/dist/cjs/httpPull/transport.test.native.js.map +1 -0
- package/dist/cjs/httpPullTransport.cjs +432 -0
- package/dist/cjs/httpPullTransport.native.js +695 -0
- package/dist/cjs/httpPullTransport.native.js.map +1 -0
- package/dist/cjs/index.cjs +1 -0
- package/dist/cjs/index.native.js +1 -0
- package/dist/cjs/index.native.js.map +1 -1
- package/dist/cjs/multiInstanceNested.test.cjs +26 -0
- package/dist/cjs/multiInstanceNested.test.native.js +34 -0
- package/dist/cjs/multiInstanceNested.test.native.js.map +1 -1
- package/dist/esm/createUseQuery.mjs +28 -16
- package/dist/esm/createUseQuery.mjs.map +1 -1
- package/dist/esm/createUseQuery.native.js +42 -30
- package/dist/esm/createUseQuery.native.js.map +1 -1
- package/dist/esm/createZeroClient.mjs +13 -1
- package/dist/esm/createZeroClient.mjs.map +1 -1
- package/dist/esm/createZeroClient.native.js +13 -1
- package/dist/esm/createZeroClient.native.js.map +1 -1
- package/dist/esm/httpPull/auth.test.mjs +198 -0
- package/dist/esm/httpPull/auth.test.mjs.map +1 -0
- package/dist/esm/httpPull/auth.test.native.js +277 -0
- package/dist/esm/httpPull/auth.test.native.js.map +1 -0
- package/dist/esm/httpPull/churn.test.mjs +133 -0
- package/dist/esm/httpPull/churn.test.mjs.map +1 -0
- package/dist/esm/httpPull/churn.test.native.js +153 -0
- package/dist/esm/httpPull/churn.test.native.js.map +1 -0
- package/dist/esm/httpPull/fixtureSchema.mjs +50 -0
- package/dist/esm/httpPull/fixtureSchema.mjs.map +1 -0
- package/dist/esm/httpPull/fixtureSchema.native.js +53 -0
- package/dist/esm/httpPull/fixtureSchema.native.js.map +1 -0
- package/dist/esm/httpPull/fixtureServer.mjs +315 -0
- package/dist/esm/httpPull/fixtureServer.mjs.map +1 -0
- package/dist/esm/httpPull/fixtureServer.native.js +506 -0
- package/dist/esm/httpPull/fixtureServer.native.js.map +1 -0
- package/dist/esm/httpPull/integration.test.mjs +54 -0
- package/dist/esm/httpPull/integration.test.mjs.map +1 -0
- package/dist/esm/httpPull/integration.test.native.js +58 -0
- package/dist/esm/httpPull/integration.test.native.js.map +1 -0
- package/dist/esm/httpPull/rebase.test.mjs +361 -0
- package/dist/esm/httpPull/rebase.test.mjs.map +1 -0
- package/dist/esm/httpPull/rebase.test.native.js +418 -0
- package/dist/esm/httpPull/rebase.test.native.js.map +1 -0
- package/dist/esm/httpPull/relations.test.mjs +108 -0
- package/dist/esm/httpPull/relations.test.mjs.map +1 -0
- package/dist/esm/httpPull/relations.test.native.js +117 -0
- package/dist/esm/httpPull/relations.test.native.js.map +1 -0
- package/dist/esm/httpPull/testHarness.mjs +72 -0
- package/dist/esm/httpPull/testHarness.mjs.map +1 -0
- package/dist/esm/httpPull/testHarness.native.js +81 -0
- package/dist/esm/httpPull/testHarness.native.js.map +1 -0
- package/dist/esm/httpPull/transport.test.mjs +569 -0
- package/dist/esm/httpPull/transport.test.mjs.map +1 -0
- package/dist/esm/httpPull/transport.test.native.js +653 -0
- package/dist/esm/httpPull/transport.test.native.js.map +1 -0
- package/dist/esm/httpPullTransport.mjs +406 -0
- package/dist/esm/httpPullTransport.mjs.map +1 -0
- package/dist/esm/httpPullTransport.native.js +666 -0
- package/dist/esm/httpPullTransport.native.js.map +1 -0
- package/dist/esm/index.js +1 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/index.mjs +1 -0
- package/dist/esm/index.mjs.map +1 -1
- package/dist/esm/index.native.js +1 -0
- package/dist/esm/index.native.js.map +1 -1
- package/dist/esm/multiInstanceNested.test.mjs +27 -1
- package/dist/esm/multiInstanceNested.test.mjs.map +1 -1
- package/dist/esm/multiInstanceNested.test.native.js +35 -1
- package/dist/esm/multiInstanceNested.test.native.js.map +1 -1
- package/package.json +2 -2
- package/src/createUseQuery.tsx +40 -22
- package/src/createZeroClient.tsx +19 -0
- package/src/httpPull/auth.test.ts +208 -0
- package/src/httpPull/churn.test.ts +147 -0
- package/src/httpPull/fixtureSchema.ts +82 -0
- package/src/httpPull/fixtureServer.ts +391 -0
- package/src/httpPull/integration.test.ts +57 -0
- package/src/httpPull/rebase.test.ts +368 -0
- package/src/httpPull/relations.test.ts +135 -0
- package/src/httpPull/testHarness.ts +95 -0
- package/src/httpPull/transport.test.ts +577 -0
- package/src/httpPullTransport.ts +559 -0
- package/src/index.ts +1 -0
- package/src/multiInstanceNested.test.tsx +25 -1
- package/types/createUseQuery.d.ts.map +1 -1
- package/types/createZeroClient.d.ts +3 -1
- package/types/createZeroClient.d.ts.map +1 -1
- package/types/httpPull/auth.test.d.ts +2 -0
- package/types/httpPull/auth.test.d.ts.map +1 -0
- package/types/httpPull/churn.test.d.ts +2 -0
- package/types/httpPull/churn.test.d.ts.map +1 -0
- package/types/httpPull/fixtureSchema.d.ts +111 -0
- package/types/httpPull/fixtureSchema.d.ts.map +1 -0
- package/types/httpPull/fixtureServer.d.ts +14 -0
- package/types/httpPull/fixtureServer.d.ts.map +1 -0
- package/types/httpPull/integration.test.d.ts +2 -0
- package/types/httpPull/integration.test.d.ts.map +1 -0
- package/types/httpPull/rebase.test.d.ts +2 -0
- package/types/httpPull/rebase.test.d.ts.map +1 -0
- package/types/httpPull/relations.test.d.ts +2 -0
- package/types/httpPull/relations.test.d.ts.map +1 -0
- package/types/httpPull/testHarness.d.ts +32 -0
- package/types/httpPull/testHarness.d.ts.map +1 -0
- package/types/httpPull/transport.test.d.ts +2 -0
- package/types/httpPull/transport.test.d.ts.map +1 -0
- package/types/httpPullTransport.d.ts +13 -0
- package/types/httpPullTransport.d.ts.map +1 -0
- package/types/index.d.ts +1 -0
- package/types/index.d.ts.map +1 -1
|
@@ -0,0 +1,279 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var import_vitest = require("vitest");
|
|
4
|
+
var import_testHarness = require("./testHarness.native.js");
|
|
5
|
+
var harness;
|
|
6
|
+
(0, import_vitest.afterEach)(async function () {
|
|
7
|
+
await (harness === null || harness === void 0 ? void 0 : harness.close());
|
|
8
|
+
harness = void 0;
|
|
9
|
+
});
|
|
10
|
+
(0, import_vitest.describe)("zero-http auth parity", function () {
|
|
11
|
+
(0, import_vitest.test)("real clients only emit rows visible to their auth token", async function () {
|
|
12
|
+
harness = await (0, import_testHarness.startZeroHttpHarness)({
|
|
13
|
+
seed: {
|
|
14
|
+
user: [{
|
|
15
|
+
id: "u1",
|
|
16
|
+
name: "ada"
|
|
17
|
+
}, {
|
|
18
|
+
id: "u2",
|
|
19
|
+
name: "ben"
|
|
20
|
+
}],
|
|
21
|
+
project: [{
|
|
22
|
+
id: "p-u1",
|
|
23
|
+
ownerId: "u1",
|
|
24
|
+
name: "u1 private"
|
|
25
|
+
}, {
|
|
26
|
+
id: "p-u2",
|
|
27
|
+
ownerId: "u2",
|
|
28
|
+
name: "u2 private"
|
|
29
|
+
}, {
|
|
30
|
+
id: "p-shared",
|
|
31
|
+
ownerId: "u2",
|
|
32
|
+
name: "shared"
|
|
33
|
+
}],
|
|
34
|
+
member: [{
|
|
35
|
+
id: "m-u1-owner",
|
|
36
|
+
projectId: "p-u1",
|
|
37
|
+
userId: "u1"
|
|
38
|
+
}, {
|
|
39
|
+
id: "m-u2-owner",
|
|
40
|
+
projectId: "p-u2",
|
|
41
|
+
userId: "u2"
|
|
42
|
+
}, {
|
|
43
|
+
id: "m-shared-u1",
|
|
44
|
+
projectId: "p-shared",
|
|
45
|
+
userId: "u1"
|
|
46
|
+
}, {
|
|
47
|
+
id: "m-shared-u2",
|
|
48
|
+
projectId: "p-shared",
|
|
49
|
+
userId: "u2"
|
|
50
|
+
}]
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
var u1 = harness.createZero("u1");
|
|
54
|
+
var u2 = harness.createZero("u2");
|
|
55
|
+
var u1Users = u1.query.user.materialize();
|
|
56
|
+
var u1Projects = u1.query.project.related("members").materialize();
|
|
57
|
+
var u2Users = u2.query.user.materialize();
|
|
58
|
+
var u2Projects = u2.query.project.related("members").materialize();
|
|
59
|
+
var u1UserEmissions = [];
|
|
60
|
+
var u1ProjectEmissions = [];
|
|
61
|
+
var u2UserEmissions = [];
|
|
62
|
+
var u2ProjectEmissions = [];
|
|
63
|
+
var stops = [captureRows(u1Users, u1UserEmissions, normalizeUsers), captureRows(u1Projects, u1ProjectEmissions, normalizeProjects), captureRows(u2Users, u2UserEmissions, normalizeUsers), captureRows(u2Projects, u2ProjectEmissions, normalizeProjects)];
|
|
64
|
+
try {
|
|
65
|
+
var [u1UsersComplete, u1ProjectsComplete, u2UsersComplete, u2ProjectsComplete] = await Promise.all([(0, import_testHarness.waitForComplete)(u1Users), (0, import_testHarness.waitForComplete)(u1Projects), (0, import_testHarness.waitForComplete)(u2Users), (0, import_testHarness.waitForComplete)(u2Projects)]);
|
|
66
|
+
(0, import_vitest.expect)(normalizeUsers(u1UsersComplete)).toEqual([{
|
|
67
|
+
id: "u1",
|
|
68
|
+
name: "ada"
|
|
69
|
+
}]);
|
|
70
|
+
(0, import_vitest.expect)(normalizeProjects(u1ProjectsComplete)).toEqual([{
|
|
71
|
+
id: "p-shared",
|
|
72
|
+
ownerId: "u2",
|
|
73
|
+
name: "shared",
|
|
74
|
+
members: [{
|
|
75
|
+
id: "m-shared-u1",
|
|
76
|
+
projectId: "p-shared",
|
|
77
|
+
userId: "u1"
|
|
78
|
+
}, {
|
|
79
|
+
id: "m-shared-u2",
|
|
80
|
+
projectId: "p-shared",
|
|
81
|
+
userId: "u2"
|
|
82
|
+
}]
|
|
83
|
+
}, {
|
|
84
|
+
id: "p-u1",
|
|
85
|
+
ownerId: "u1",
|
|
86
|
+
name: "u1 private",
|
|
87
|
+
members: [{
|
|
88
|
+
id: "m-u1-owner",
|
|
89
|
+
projectId: "p-u1",
|
|
90
|
+
userId: "u1"
|
|
91
|
+
}]
|
|
92
|
+
}]);
|
|
93
|
+
(0, import_vitest.expect)(normalizeUsers(u2UsersComplete)).toEqual([{
|
|
94
|
+
id: "u2",
|
|
95
|
+
name: "ben"
|
|
96
|
+
}]);
|
|
97
|
+
(0, import_vitest.expect)(normalizeProjects(u2ProjectsComplete)).toEqual([{
|
|
98
|
+
id: "p-shared",
|
|
99
|
+
ownerId: "u2",
|
|
100
|
+
name: "shared",
|
|
101
|
+
members: [{
|
|
102
|
+
id: "m-shared-u1",
|
|
103
|
+
projectId: "p-shared",
|
|
104
|
+
userId: "u1"
|
|
105
|
+
}, {
|
|
106
|
+
id: "m-shared-u2",
|
|
107
|
+
projectId: "p-shared",
|
|
108
|
+
userId: "u2"
|
|
109
|
+
}]
|
|
110
|
+
}, {
|
|
111
|
+
id: "p-u2",
|
|
112
|
+
ownerId: "u2",
|
|
113
|
+
name: "u2 private",
|
|
114
|
+
members: [{
|
|
115
|
+
id: "m-u2-owner",
|
|
116
|
+
projectId: "p-u2",
|
|
117
|
+
userId: "u2"
|
|
118
|
+
}]
|
|
119
|
+
}]);
|
|
120
|
+
assertNoUserEmission(u1UserEmissions, "u2");
|
|
121
|
+
assertNoProjectEmission(u1ProjectEmissions, "p-u2", "m-u2-owner");
|
|
122
|
+
assertNoUserEmission(u2UserEmissions, "u1");
|
|
123
|
+
assertNoProjectEmission(u2ProjectEmissions, "p-u1", "m-u1-owner");
|
|
124
|
+
await harness.transport.pull();
|
|
125
|
+
await (0, import_testHarness.sleep)(50);
|
|
126
|
+
assertNoUserEmission(u1UserEmissions, "u2");
|
|
127
|
+
assertNoProjectEmission(u1ProjectEmissions, "p-u2", "m-u2-owner");
|
|
128
|
+
assertNoUserEmission(u2UserEmissions, "u1");
|
|
129
|
+
assertNoProjectEmission(u2ProjectEmissions, "p-u1", "m-u1-owner");
|
|
130
|
+
} finally {
|
|
131
|
+
var _iteratorNormalCompletion = true,
|
|
132
|
+
_didIteratorError = false,
|
|
133
|
+
_iteratorError = void 0;
|
|
134
|
+
try {
|
|
135
|
+
for (var _iterator = stops[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
|
136
|
+
var stop = _step.value;
|
|
137
|
+
stop();
|
|
138
|
+
}
|
|
139
|
+
} catch (err) {
|
|
140
|
+
_didIteratorError = true;
|
|
141
|
+
_iteratorError = err;
|
|
142
|
+
} finally {
|
|
143
|
+
try {
|
|
144
|
+
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
145
|
+
_iterator.return();
|
|
146
|
+
}
|
|
147
|
+
} finally {
|
|
148
|
+
if (_didIteratorError) {
|
|
149
|
+
throw _iteratorError;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
u1Users.destroy();
|
|
154
|
+
u1Projects.destroy();
|
|
155
|
+
u2Users.destroy();
|
|
156
|
+
u2Projects.destroy();
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
(0, import_vitest.test)("unknown token 401 reaches needs-auth without materializing data", async function () {
|
|
160
|
+
harness = await (0, import_testHarness.startZeroHttpHarness)({
|
|
161
|
+
seed: {
|
|
162
|
+
user: [{
|
|
163
|
+
id: "u1",
|
|
164
|
+
name: "ada"
|
|
165
|
+
}],
|
|
166
|
+
project: [{
|
|
167
|
+
id: "p-u1",
|
|
168
|
+
ownerId: "u1",
|
|
169
|
+
name: "u1 private"
|
|
170
|
+
}],
|
|
171
|
+
member: [{
|
|
172
|
+
id: "m-u1-owner",
|
|
173
|
+
projectId: "p-u1",
|
|
174
|
+
userId: "u1"
|
|
175
|
+
}]
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
var unknown = harness.createZero("missing");
|
|
179
|
+
var projects = unknown.query.project.related("members").materialize();
|
|
180
|
+
var emissions = [];
|
|
181
|
+
var stop = captureRows(projects, emissions, normalizeProjects);
|
|
182
|
+
try {
|
|
183
|
+
await (0, import_testHarness.eventually)(function () {
|
|
184
|
+
return (0, import_vitest.expect)(unknown.connection.state.current.name).toBe("needs-auth");
|
|
185
|
+
});
|
|
186
|
+
await (0, import_testHarness.sleep)(50);
|
|
187
|
+
(0, import_vitest.expect)(projects.data).toEqual([]);
|
|
188
|
+
(0, import_vitest.expect)(emissions.every(function (emission) {
|
|
189
|
+
return emission.length === 0;
|
|
190
|
+
})).toBe(true);
|
|
191
|
+
} finally {
|
|
192
|
+
stop();
|
|
193
|
+
projects.destroy();
|
|
194
|
+
}
|
|
195
|
+
});
|
|
196
|
+
});
|
|
197
|
+
function captureRows(view, emissions, normalize) {
|
|
198
|
+
return view.addListener(function (data) {
|
|
199
|
+
emissions.push(normalize(data));
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
function assertNoUserEmission(emissions, privateUserID) {
|
|
203
|
+
var _iteratorNormalCompletion = true,
|
|
204
|
+
_didIteratorError = false,
|
|
205
|
+
_iteratorError = void 0;
|
|
206
|
+
try {
|
|
207
|
+
for (var _iterator = emissions[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
|
208
|
+
var emission = _step.value;
|
|
209
|
+
(0, import_vitest.expect)(emission.map(function (row) {
|
|
210
|
+
return row.id;
|
|
211
|
+
})).not.toContain(privateUserID);
|
|
212
|
+
}
|
|
213
|
+
} catch (err) {
|
|
214
|
+
_didIteratorError = true;
|
|
215
|
+
_iteratorError = err;
|
|
216
|
+
} finally {
|
|
217
|
+
try {
|
|
218
|
+
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
219
|
+
_iterator.return();
|
|
220
|
+
}
|
|
221
|
+
} finally {
|
|
222
|
+
if (_didIteratorError) {
|
|
223
|
+
throw _iteratorError;
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
function assertNoProjectEmission(emissions, privateProjectID, privateMemberID) {
|
|
229
|
+
var _iteratorNormalCompletion = true,
|
|
230
|
+
_didIteratorError = false,
|
|
231
|
+
_iteratorError = void 0;
|
|
232
|
+
try {
|
|
233
|
+
for (var _iterator = emissions[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
|
234
|
+
var emission = _step.value;
|
|
235
|
+
(0, import_vitest.expect)(emission.map(function (row) {
|
|
236
|
+
return row.id;
|
|
237
|
+
})).not.toContain(privateProjectID);
|
|
238
|
+
(0, import_vitest.expect)(emission.flatMap(function (row) {
|
|
239
|
+
return row.members.map(function (member) {
|
|
240
|
+
return member.id;
|
|
241
|
+
});
|
|
242
|
+
})).not.toContain(privateMemberID);
|
|
243
|
+
}
|
|
244
|
+
} catch (err) {
|
|
245
|
+
_didIteratorError = true;
|
|
246
|
+
_iteratorError = err;
|
|
247
|
+
} finally {
|
|
248
|
+
try {
|
|
249
|
+
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
250
|
+
_iterator.return();
|
|
251
|
+
}
|
|
252
|
+
} finally {
|
|
253
|
+
if (_didIteratorError) {
|
|
254
|
+
throw _iteratorError;
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
function normalizeUsers(users) {
|
|
260
|
+
return clone(users).sort(function (a, b) {
|
|
261
|
+
return a.id.localeCompare(b.id);
|
|
262
|
+
});
|
|
263
|
+
}
|
|
264
|
+
function normalizeProjects(projects) {
|
|
265
|
+
return clone(projects).map(function (project) {
|
|
266
|
+
return {
|
|
267
|
+
...project,
|
|
268
|
+
members: [...project.members].sort(function (a, b) {
|
|
269
|
+
return a.id.localeCompare(b.id);
|
|
270
|
+
})
|
|
271
|
+
};
|
|
272
|
+
}).sort(function (a, b) {
|
|
273
|
+
return a.id.localeCompare(b.id);
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
function clone(value) {
|
|
277
|
+
return JSON.parse(JSON.stringify(value));
|
|
278
|
+
}
|
|
279
|
+
//# sourceMappingURL=auth.test.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["import_vitest","require","import_testHarness","harness","afterEach","close","describe","test","startZeroHttpHarness","seed","user","id","name","project","ownerId","member","projectId","userId","u1","createZero","u2","u1Users","query","materialize","u1Projects","related","u2Users","u2Projects","u1UserEmissions","u1ProjectEmissions","u2UserEmissions","u2ProjectEmissions","stops","captureRows","normalizeUsers","normalizeProjects","u1UsersComplete","u1ProjectsComplete","u2UsersComplete","u2ProjectsComplete","Promise","all","waitForComplete","expect","toEqual","members"],"sources":["../../../src/httpPull/auth.test.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
var import_vitest = require("vitest");
|
|
2
|
+
var import_testHarness = require("./testHarness.cjs");
|
|
3
|
+
let harness;
|
|
4
|
+
(0, import_vitest.afterEach)(async () => {
|
|
5
|
+
await harness?.close();
|
|
6
|
+
harness = void 0;
|
|
7
|
+
});
|
|
8
|
+
(0, import_vitest.test)("mutation burst converges while explicit pulls churn", async () => {
|
|
9
|
+
let clientGroupID = "";
|
|
10
|
+
const pullErrors = [];
|
|
11
|
+
harness = await (0, import_testHarness.startZeroHttpHarness)({
|
|
12
|
+
seed: {
|
|
13
|
+
user: [{
|
|
14
|
+
id: "u1",
|
|
15
|
+
name: "ada"
|
|
16
|
+
}],
|
|
17
|
+
project: [],
|
|
18
|
+
member: []
|
|
19
|
+
},
|
|
20
|
+
interceptFetch: next => async (input, init) => {
|
|
21
|
+
const body = init?.body ? JSON.parse(String(init.body)) : void 0;
|
|
22
|
+
if (body?.clientGroupID) clientGroupID = body.clientGroupID;
|
|
23
|
+
return next(input, init);
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
const zero = harness.createZero("u1");
|
|
27
|
+
const view = zero.query.project.materialize();
|
|
28
|
+
await (0, import_testHarness.waitForComplete)(view);
|
|
29
|
+
const timer = setInterval(() => {
|
|
30
|
+
void harness?.transport.pull().catch(error => pullErrors.push(error));
|
|
31
|
+
}, 2);
|
|
32
|
+
try {
|
|
33
|
+
const mutations = Array.from({
|
|
34
|
+
length: 15
|
|
35
|
+
}, (_, index) => zero.mutate.project.create({
|
|
36
|
+
id: `p${index + 1}`,
|
|
37
|
+
ownerId: "u1",
|
|
38
|
+
name: `project ${index + 1}`
|
|
39
|
+
}));
|
|
40
|
+
await Promise.all(mutations.map(mutation => mutation.client));
|
|
41
|
+
await Promise.all(mutations.map(mutation => mutation.server));
|
|
42
|
+
await harness.transport.pull();
|
|
43
|
+
await (0, import_testHarness.eventually)(() => {
|
|
44
|
+
(0, import_vitest.expect)(projectIDs(view.data)).toEqual(Array.from({
|
|
45
|
+
length: 15
|
|
46
|
+
}, (_, index) => `p${index + 1}`).sort());
|
|
47
|
+
});
|
|
48
|
+
} finally {
|
|
49
|
+
clearInterval(timer);
|
|
50
|
+
}
|
|
51
|
+
(0, import_vitest.expect)(pullErrors).toEqual([]);
|
|
52
|
+
(0, import_vitest.expect)(zero.connection.state.current.name).toBe("connected");
|
|
53
|
+
(0, import_vitest.expect)(harness.server.rows("project").map(row => row.id).sort()).toEqual(Array.from({
|
|
54
|
+
length: 15
|
|
55
|
+
}, (_, index) => `p${index + 1}`).sort());
|
|
56
|
+
const pull = await rawPull(harness, clientGroupID);
|
|
57
|
+
(0, import_vitest.expect)(Object.values(pull.lastMutationIDChanges)).toContain(15);
|
|
58
|
+
view.destroy();
|
|
59
|
+
});
|
|
60
|
+
(0, import_vitest.test)("two clients sharing a client group converge without cookie fights", async () => {
|
|
61
|
+
const clientGroups = /* @__PURE__ */new Set();
|
|
62
|
+
const clientIDs = /* @__PURE__ */new Set();
|
|
63
|
+
harness = await (0, import_testHarness.startZeroHttpHarness)({
|
|
64
|
+
seed: {
|
|
65
|
+
user: [{
|
|
66
|
+
id: "u1",
|
|
67
|
+
name: "ada"
|
|
68
|
+
}],
|
|
69
|
+
project: [{
|
|
70
|
+
id: "p1",
|
|
71
|
+
ownerId: "u1",
|
|
72
|
+
name: "first"
|
|
73
|
+
}],
|
|
74
|
+
member: []
|
|
75
|
+
},
|
|
76
|
+
interceptFetch: next => async (input, init) => {
|
|
77
|
+
const body = init?.body ? JSON.parse(String(init.body)) : void 0;
|
|
78
|
+
if (body?.clientGroupID) clientGroups.add(body.clientGroupID);
|
|
79
|
+
if (body?.clientID) clientIDs.add(body.clientID);
|
|
80
|
+
return next(input, init);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
const sharedStorageKey = "zero-http-shared-client-group";
|
|
84
|
+
const zeroA = harness.createZero("u1", {
|
|
85
|
+
storageKey: sharedStorageKey
|
|
86
|
+
});
|
|
87
|
+
const zeroB = harness.createZero("u1", {
|
|
88
|
+
storageKey: sharedStorageKey
|
|
89
|
+
});
|
|
90
|
+
const viewA = zeroA.query.project.materialize();
|
|
91
|
+
const viewB = zeroB.query.project.materialize();
|
|
92
|
+
await (0, import_testHarness.waitForComplete)(viewA);
|
|
93
|
+
await (0, import_testHarness.waitForComplete)(viewB);
|
|
94
|
+
(0, import_vitest.expect)(harness.transport.connections).toBe(2);
|
|
95
|
+
(0, import_vitest.expect)(clientGroups.size).toBe(1);
|
|
96
|
+
(0, import_vitest.expect)(clientIDs.size).toBe(2);
|
|
97
|
+
const mutation = zeroA.mutate.project.create({
|
|
98
|
+
id: "p2",
|
|
99
|
+
ownerId: "u1",
|
|
100
|
+
name: "second"
|
|
101
|
+
});
|
|
102
|
+
await mutation.client;
|
|
103
|
+
await mutation.server;
|
|
104
|
+
await harness.transport.pull();
|
|
105
|
+
await (0, import_testHarness.eventually)(() => {
|
|
106
|
+
(0, import_vitest.expect)(projectIDs(viewA.data)).toEqual(["p1", "p2"]);
|
|
107
|
+
(0, import_vitest.expect)(projectIDs(viewB.data)).toEqual(["p1", "p2"]);
|
|
108
|
+
});
|
|
109
|
+
(0, import_vitest.expect)(zeroA.connection.state.current.name).toBe("connected");
|
|
110
|
+
(0, import_vitest.expect)(zeroB.connection.state.current.name).toBe("connected");
|
|
111
|
+
viewA.destroy();
|
|
112
|
+
viewB.destroy();
|
|
113
|
+
});
|
|
114
|
+
async function rawPull(harness2, clientGroupID) {
|
|
115
|
+
const response = await fetch(`${harness2.server.url}/pull`, {
|
|
116
|
+
method: "POST",
|
|
117
|
+
headers: {
|
|
118
|
+
authorization: "Bearer token-u1",
|
|
119
|
+
"content-type": "application/json"
|
|
120
|
+
},
|
|
121
|
+
body: JSON.stringify({
|
|
122
|
+
clientID: "raw-pull",
|
|
123
|
+
clientGroupID,
|
|
124
|
+
cookie: null
|
|
125
|
+
})
|
|
126
|
+
});
|
|
127
|
+
(0, import_vitest.expect)(response.status).toBe(200);
|
|
128
|
+
return response.json();
|
|
129
|
+
}
|
|
130
|
+
function projectIDs(rows) {
|
|
131
|
+
return rows.map(row => row.id).sort();
|
|
132
|
+
}
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var import_vitest = require("vitest");
|
|
4
|
+
var import_testHarness = require("./testHarness.native.js");
|
|
5
|
+
var harness;
|
|
6
|
+
(0, import_vitest.afterEach)(async function () {
|
|
7
|
+
await (harness === null || harness === void 0 ? void 0 : harness.close());
|
|
8
|
+
harness = void 0;
|
|
9
|
+
});
|
|
10
|
+
(0, import_vitest.test)("mutation burst converges while explicit pulls churn", async function () {
|
|
11
|
+
var clientGroupID = "";
|
|
12
|
+
var pullErrors = [];
|
|
13
|
+
harness = await (0, import_testHarness.startZeroHttpHarness)({
|
|
14
|
+
seed: {
|
|
15
|
+
user: [{
|
|
16
|
+
id: "u1",
|
|
17
|
+
name: "ada"
|
|
18
|
+
}],
|
|
19
|
+
project: [],
|
|
20
|
+
member: []
|
|
21
|
+
},
|
|
22
|
+
interceptFetch: function (next) {
|
|
23
|
+
return async function (input, init) {
|
|
24
|
+
var body = (init === null || init === void 0 ? void 0 : init.body) ? JSON.parse(String(init.body)) : void 0;
|
|
25
|
+
if (body === null || body === void 0 ? void 0 : body.clientGroupID) clientGroupID = body.clientGroupID;
|
|
26
|
+
return next(input, init);
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
var zero = harness.createZero("u1");
|
|
31
|
+
var view = zero.query.project.materialize();
|
|
32
|
+
await (0, import_testHarness.waitForComplete)(view);
|
|
33
|
+
var timer = setInterval(function () {
|
|
34
|
+
void (harness === null || harness === void 0 ? void 0 : harness.transport.pull().catch(function (error) {
|
|
35
|
+
return pullErrors.push(error);
|
|
36
|
+
}));
|
|
37
|
+
}, 2);
|
|
38
|
+
try {
|
|
39
|
+
var mutations = Array.from({
|
|
40
|
+
length: 15
|
|
41
|
+
}, function (_, index) {
|
|
42
|
+
return zero.mutate.project.create({
|
|
43
|
+
id: `p${index + 1}`,
|
|
44
|
+
ownerId: "u1",
|
|
45
|
+
name: `project ${index + 1}`
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
await Promise.all(mutations.map(function (mutation) {
|
|
49
|
+
return mutation.client;
|
|
50
|
+
}));
|
|
51
|
+
await Promise.all(mutations.map(function (mutation) {
|
|
52
|
+
return mutation.server;
|
|
53
|
+
}));
|
|
54
|
+
await harness.transport.pull();
|
|
55
|
+
await (0, import_testHarness.eventually)(function () {
|
|
56
|
+
(0, import_vitest.expect)(projectIDs(view.data)).toEqual(Array.from({
|
|
57
|
+
length: 15
|
|
58
|
+
}, function (_, index) {
|
|
59
|
+
return `p${index + 1}`;
|
|
60
|
+
}).sort());
|
|
61
|
+
});
|
|
62
|
+
} finally {
|
|
63
|
+
clearInterval(timer);
|
|
64
|
+
}
|
|
65
|
+
(0, import_vitest.expect)(pullErrors).toEqual([]);
|
|
66
|
+
(0, import_vitest.expect)(zero.connection.state.current.name).toBe("connected");
|
|
67
|
+
(0, import_vitest.expect)(harness.server.rows("project").map(function (row) {
|
|
68
|
+
return row.id;
|
|
69
|
+
}).sort()).toEqual(Array.from({
|
|
70
|
+
length: 15
|
|
71
|
+
}, function (_, index) {
|
|
72
|
+
return `p${index + 1}`;
|
|
73
|
+
}).sort());
|
|
74
|
+
var pull = await rawPull(harness, clientGroupID);
|
|
75
|
+
(0, import_vitest.expect)(Object.values(pull.lastMutationIDChanges)).toContain(15);
|
|
76
|
+
view.destroy();
|
|
77
|
+
});
|
|
78
|
+
(0, import_vitest.test)("two clients sharing a client group converge without cookie fights", async function () {
|
|
79
|
+
var clientGroups = /* @__PURE__ */new Set();
|
|
80
|
+
var clientIDs = /* @__PURE__ */new Set();
|
|
81
|
+
harness = await (0, import_testHarness.startZeroHttpHarness)({
|
|
82
|
+
seed: {
|
|
83
|
+
user: [{
|
|
84
|
+
id: "u1",
|
|
85
|
+
name: "ada"
|
|
86
|
+
}],
|
|
87
|
+
project: [{
|
|
88
|
+
id: "p1",
|
|
89
|
+
ownerId: "u1",
|
|
90
|
+
name: "first"
|
|
91
|
+
}],
|
|
92
|
+
member: []
|
|
93
|
+
},
|
|
94
|
+
interceptFetch: function (next) {
|
|
95
|
+
return async function (input, init) {
|
|
96
|
+
var body = (init === null || init === void 0 ? void 0 : init.body) ? JSON.parse(String(init.body)) : void 0;
|
|
97
|
+
if (body === null || body === void 0 ? void 0 : body.clientGroupID) clientGroups.add(body.clientGroupID);
|
|
98
|
+
if (body === null || body === void 0 ? void 0 : body.clientID) clientIDs.add(body.clientID);
|
|
99
|
+
return next(input, init);
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
var sharedStorageKey = "zero-http-shared-client-group";
|
|
104
|
+
var zeroA = harness.createZero("u1", {
|
|
105
|
+
storageKey: sharedStorageKey
|
|
106
|
+
});
|
|
107
|
+
var zeroB = harness.createZero("u1", {
|
|
108
|
+
storageKey: sharedStorageKey
|
|
109
|
+
});
|
|
110
|
+
var viewA = zeroA.query.project.materialize();
|
|
111
|
+
var viewB = zeroB.query.project.materialize();
|
|
112
|
+
await (0, import_testHarness.waitForComplete)(viewA);
|
|
113
|
+
await (0, import_testHarness.waitForComplete)(viewB);
|
|
114
|
+
(0, import_vitest.expect)(harness.transport.connections).toBe(2);
|
|
115
|
+
(0, import_vitest.expect)(clientGroups.size).toBe(1);
|
|
116
|
+
(0, import_vitest.expect)(clientIDs.size).toBe(2);
|
|
117
|
+
var mutation = zeroA.mutate.project.create({
|
|
118
|
+
id: "p2",
|
|
119
|
+
ownerId: "u1",
|
|
120
|
+
name: "second"
|
|
121
|
+
});
|
|
122
|
+
await mutation.client;
|
|
123
|
+
await mutation.server;
|
|
124
|
+
await harness.transport.pull();
|
|
125
|
+
await (0, import_testHarness.eventually)(function () {
|
|
126
|
+
(0, import_vitest.expect)(projectIDs(viewA.data)).toEqual(["p1", "p2"]);
|
|
127
|
+
(0, import_vitest.expect)(projectIDs(viewB.data)).toEqual(["p1", "p2"]);
|
|
128
|
+
});
|
|
129
|
+
(0, import_vitest.expect)(zeroA.connection.state.current.name).toBe("connected");
|
|
130
|
+
(0, import_vitest.expect)(zeroB.connection.state.current.name).toBe("connected");
|
|
131
|
+
viewA.destroy();
|
|
132
|
+
viewB.destroy();
|
|
133
|
+
});
|
|
134
|
+
async function rawPull(harness2, clientGroupID) {
|
|
135
|
+
var response = await fetch(`${harness2.server.url}/pull`, {
|
|
136
|
+
method: "POST",
|
|
137
|
+
headers: {
|
|
138
|
+
authorization: "Bearer token-u1",
|
|
139
|
+
"content-type": "application/json"
|
|
140
|
+
},
|
|
141
|
+
body: JSON.stringify({
|
|
142
|
+
clientID: "raw-pull",
|
|
143
|
+
clientGroupID,
|
|
144
|
+
cookie: null
|
|
145
|
+
})
|
|
146
|
+
});
|
|
147
|
+
(0, import_vitest.expect)(response.status).toBe(200);
|
|
148
|
+
return response.json();
|
|
149
|
+
}
|
|
150
|
+
function projectIDs(rows) {
|
|
151
|
+
return rows.map(function (row) {
|
|
152
|
+
return row.id;
|
|
153
|
+
}).sort();
|
|
154
|
+
}
|
|
155
|
+
//# sourceMappingURL=churn.test.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["import_vitest","require","import_testHarness","harness","afterEach","close","test","clientGroupID","pullErrors","startZeroHttpHarness","seed","user","id","name","project","member","interceptFetch","next","input","init","body","JSON","parse","String","zero","createZero","view","query","materialize","waitForComplete","timer","setInterval","transport","pull","catch","error","push","mutations","Array","from","length","_","index","mutate","create","ownerId","Promise","all","map","mutation","client","server","eventually","expect","projectIDs","data","toEqual","sort","clearInterval","connection","state","current","toBe","rows","row","rawPull","Object","values","lastMutationIDChanges","toContain","destroy","clientGroups","Set","clientIDs","add","clientID","sharedStorageKey","zeroA","storageKey","zeroB","viewA","viewB","connections"],"sources":["../../../src/httpPull/churn.test.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all) __defProp(target, name, {
|
|
7
|
+
get: all[name],
|
|
8
|
+
enumerable: true
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {
|
|
14
|
+
get: () => from[key],
|
|
15
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
|
|
21
|
+
value: true
|
|
22
|
+
}), mod);
|
|
23
|
+
var fixtureSchema_exports = {};
|
|
24
|
+
__export(fixtureSchema_exports, {
|
|
25
|
+
zeroHttpFixtureMutators: () => zeroHttpFixtureMutators,
|
|
26
|
+
zeroHttpFixtureSchema: () => zeroHttpFixtureSchema
|
|
27
|
+
});
|
|
28
|
+
module.exports = __toCommonJS(fixtureSchema_exports);
|
|
29
|
+
var import_zero = require("@rocicorp/zero");
|
|
30
|
+
const user = (0, import_zero.table)("user").columns({
|
|
31
|
+
id: (0, import_zero.string)(),
|
|
32
|
+
name: (0, import_zero.string)()
|
|
33
|
+
}).primaryKey("id");
|
|
34
|
+
const project = (0, import_zero.table)("project").columns({
|
|
35
|
+
id: (0, import_zero.string)(),
|
|
36
|
+
ownerId: (0, import_zero.string)(),
|
|
37
|
+
name: (0, import_zero.string)()
|
|
38
|
+
}).primaryKey("id");
|
|
39
|
+
const member = (0, import_zero.table)("member").columns({
|
|
40
|
+
id: (0, import_zero.string)(),
|
|
41
|
+
projectId: (0, import_zero.string)(),
|
|
42
|
+
userId: (0, import_zero.string)()
|
|
43
|
+
}).primaryKey("id");
|
|
44
|
+
const zeroHttpFixtureSchema = (0, import_zero.createSchema)({
|
|
45
|
+
tables: [user, project, member],
|
|
46
|
+
relationships: [(0, import_zero.relationships)(project, ({
|
|
47
|
+
many
|
|
48
|
+
}) => ({
|
|
49
|
+
members: many({
|
|
50
|
+
sourceField: ["id"],
|
|
51
|
+
destField: ["projectId"],
|
|
52
|
+
destSchema: member
|
|
53
|
+
})
|
|
54
|
+
}))],
|
|
55
|
+
enableLegacyQueries: true
|
|
56
|
+
});
|
|
57
|
+
const zeroHttpFixtureMutators = {
|
|
58
|
+
project: {
|
|
59
|
+
create: async (tx, args) => {
|
|
60
|
+
await tx.mutate.project.insert(args);
|
|
61
|
+
},
|
|
62
|
+
rename: async (tx, args) => {
|
|
63
|
+
await tx.mutate.project.update(args);
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
member: {
|
|
67
|
+
add: async (tx, args) => {
|
|
68
|
+
await tx.mutate.member.insert(args);
|
|
69
|
+
},
|
|
70
|
+
remove: async (tx, args) => {
|
|
71
|
+
await tx.mutate.member.delete({
|
|
72
|
+
id: args.id
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
};
|