cry-ebus2 3.1.23 → 3.2.0
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/EbusClientEvents.d.mts +5 -0
- package/dist/EbusClientEvents.d.mts.map +1 -0
- package/dist/EbusClientEvents.mjs +2 -0
- package/dist/EbusClientEvents.mjs.map +1 -0
- package/dist/EbusConfiguration.d.mts +17 -0
- package/dist/EbusConfiguration.d.mts.map +1 -0
- package/dist/EbusConfiguration.mjs +2 -0
- package/dist/EbusConfiguration.mjs.map +1 -0
- package/dist/EbusReject.d.mts +11 -0
- package/dist/EbusReject.d.mts.map +1 -0
- package/dist/EbusReject.mjs +12 -0
- package/dist/EbusReject.mjs.map +1 -0
- package/dist/EbusRejectReason.d.mts +2 -0
- package/dist/EbusRejectReason.d.mts.map +1 -0
- package/dist/EbusRejectReason.mjs +2 -0
- package/dist/EbusRejectReason.mjs.map +1 -0
- package/dist/EbusRequestOptions.d.mts +8 -0
- package/dist/EbusRequestOptions.d.mts.map +1 -0
- package/dist/EbusRequestOptions.mjs +2 -0
- package/dist/EbusRequestOptions.mjs.map +1 -0
- package/dist/EbusUnpackedResult.d.mts +10 -0
- package/dist/EbusUnpackedResult.d.mts.map +1 -0
- package/dist/EbusUnpackedResult.mjs +19 -0
- package/dist/EbusUnpackedResult.mjs.map +1 -0
- package/dist/block.d.mts +2 -0
- package/dist/block.d.mts.map +1 -0
- package/dist/block.mjs +6 -0
- package/dist/block.mjs.map +1 -0
- package/dist/broker.d.mts +42 -0
- package/dist/broker.d.mts.map +1 -0
- package/dist/broker.mjs +288 -0
- package/dist/broker.mjs.map +1 -0
- package/dist/client.d.mts +2 -0
- package/dist/client.d.mts.map +1 -0
- package/dist/client.mjs +2 -0
- package/dist/client.mjs.map +1 -0
- package/dist/clientBlocking.d.mts +27 -0
- package/dist/clientBlocking.d.mts.map +1 -0
- package/dist/clientBlocking.mjs +173 -0
- package/dist/clientBlocking.mjs.map +1 -0
- package/dist/clientNonBlocking.d.mts +46 -0
- package/dist/clientNonBlocking.d.mts.map +1 -0
- package/dist/clientNonBlocking.mjs +275 -0
- package/dist/clientNonBlocking.mjs.map +1 -0
- package/dist/consts.d.mts +3 -0
- package/dist/consts.d.mts.map +1 -0
- package/dist/consts.mjs +17 -0
- package/dist/consts.mjs.map +1 -0
- package/dist/deferredPromise.d.mts +36 -0
- package/dist/deferredPromise.d.mts.map +1 -0
- package/dist/deferredPromise.mjs +57 -0
- package/dist/deferredPromise.mjs.map +1 -0
- package/dist/delayWorker.d.mts +10 -0
- package/dist/delayWorker.d.mts.map +1 -0
- package/dist/delayWorker.mjs +17 -0
- package/dist/delayWorker.mjs.map +1 -0
- package/dist/echoWorker.d.mts +6 -0
- package/dist/echoWorker.d.mts.map +1 -0
- package/dist/echoWorker.mjs +15 -0
- package/dist/echoWorker.mjs.map +1 -0
- package/dist/errorWorker.d.mts +11 -0
- package/dist/errorWorker.d.mts.map +1 -0
- package/dist/errorWorker.mjs +14 -0
- package/dist/errorWorker.mjs.map +1 -0
- package/dist/index.d.mts +19 -0
- package/dist/index.d.mts.map +1 -0
- package/dist/index.mjs +16 -0
- package/dist/index.mjs.map +1 -0
- package/dist/loadConfiguration.d.mts +3 -0
- package/dist/loadConfiguration.d.mts.map +1 -0
- package/dist/loadConfiguration.mjs +9 -0
- package/dist/loadConfiguration.mjs.map +1 -0
- package/dist/pub.d.mts +11 -0
- package/dist/pub.d.mts.map +1 -0
- package/dist/pub.mjs +22 -0
- package/dist/pub.mjs.map +1 -0
- package/dist/rejectWorker.d.mts +11 -0
- package/dist/rejectWorker.d.mts.map +1 -0
- package/dist/rejectWorker.mjs +14 -0
- package/dist/rejectWorker.mjs.map +1 -0
- package/dist/run/all.d.mts +2 -0
- package/dist/run/all.d.mts.map +1 -0
- package/dist/run/all.mjs +13 -0
- package/dist/run/all.mjs.map +1 -0
- package/dist/run/broker.mjs +1 -1
- package/dist/run/broker.mjs.map +1 -1
- package/dist/run/call.d.mts +2 -0
- package/dist/run/call.d.mts.map +1 -0
- package/dist/run/call.mjs +77 -0
- package/dist/run/call.mjs.map +1 -0
- package/dist/run/calling.d.mts +2 -0
- package/dist/run/calling.d.mts.map +1 -0
- package/dist/run/calling.mjs +94 -0
- package/dist/run/calling.mjs.map +1 -0
- package/dist/run/callingBurst.d.mts +2 -0
- package/dist/run/callingBurst.d.mts.map +1 -0
- package/dist/run/callingBurst.mjs +41 -0
- package/dist/run/callingBurst.mjs.map +1 -0
- package/dist/run/delay.mjs +1 -1
- package/dist/run/delay.mjs.map +1 -1
- package/dist/run/echo.mjs +1 -1
- package/dist/run/echo.mjs.map +1 -1
- package/dist/run/error.mjs +1 -1
- package/dist/run/error.mjs.map +1 -1
- package/dist/run/ping.mjs +1 -1
- package/dist/run/ping.mjs.map +1 -1
- package/dist/run/pub.d.mts +2 -0
- package/dist/run/pub.d.mts.map +1 -0
- package/dist/run/pub.mjs +28 -0
- package/dist/run/pub.mjs.map +1 -0
- package/dist/run/reject.d.mts +2 -0
- package/dist/run/reject.d.mts.map +1 -0
- package/dist/run/reject.mjs +5 -0
- package/dist/run/reject.mjs.map +1 -0
- package/dist/run/sub.d.mts +2 -0
- package/dist/run/sub.d.mts.map +1 -0
- package/dist/run/sub.mjs +88 -0
- package/dist/run/sub.mjs.map +1 -0
- package/dist/run/termimalCommands.d.mts +33 -0
- package/dist/run/termimalCommands.d.mts.map +1 -0
- package/dist/run/termimalCommands.mjs +33 -0
- package/dist/run/termimalCommands.mjs.map +1 -0
- package/dist/run/workers.d.mts +2 -0
- package/dist/run/workers.d.mts.map +1 -0
- package/dist/run/workers.mjs +36 -0
- package/dist/run/workers.mjs.map +1 -0
- package/dist/serialize.d.mts +4 -0
- package/dist/serialize.d.mts.map +1 -0
- package/dist/serialize.mjs +26 -0
- package/dist/serialize.mjs.map +1 -0
- package/dist/service.d.mts +23 -0
- package/dist/service.d.mts.map +1 -0
- package/dist/service.mjs +108 -0
- package/dist/service.mjs.map +1 -0
- package/dist/sleep.d.mts +2 -0
- package/dist/sleep.d.mts.map +1 -0
- package/dist/sleep.mjs +6 -0
- package/dist/sleep.mjs.map +1 -0
- package/dist/sub.d.mts +24 -0
- package/dist/sub.d.mts.map +1 -0
- package/dist/sub.mjs +68 -0
- package/dist/sub.mjs.map +1 -0
- package/dist/test/config.d.mts +2 -0
- package/dist/test/config.d.mts.map +1 -0
- package/dist/test/config.mjs +23 -0
- package/dist/test/config.mjs.map +1 -0
- package/dist/test/echo.d.mts +2 -0
- package/dist/test/echo.d.mts.map +1 -0
- package/dist/test/echo.mjs +54 -0
- package/dist/test/echo.mjs.map +1 -0
- package/dist/test/index.d.mts +2 -0
- package/dist/test/index.d.mts.map +1 -0
- package/dist/test/index.mjs +47 -0
- package/dist/test/index.mjs.map +1 -0
- package/dist/test/pack.d.mts +2 -0
- package/dist/test/pack.d.mts.map +1 -0
- package/dist/test/pack.mjs +1444 -0
- package/dist/test/pack.mjs.map +1 -0
- package/dist/test/performance.d.mts +2 -0
- package/dist/test/performance.d.mts.map +1 -0
- package/dist/test/performance.mjs +44 -0
- package/dist/test/performance.mjs.map +1 -0
- package/dist/test/pub.d.mts +2 -0
- package/dist/test/pub.d.mts.map +1 -0
- package/dist/test/pub.mjs +57 -0
- package/dist/test/pub.mjs.map +1 -0
- package/dist/test/pub2.d.mts +2 -0
- package/dist/test/pub2.d.mts.map +1 -0
- package/dist/test/pub2.mjs +23 -0
- package/dist/test/pub2.mjs.map +1 -0
- package/dist/test/reject.d.mts +2 -0
- package/dist/test/reject.d.mts.map +1 -0
- package/dist/test/reject.mjs +33 -0
- package/dist/test/reject.mjs.map +1 -0
- package/dist/test/services.d.mts +2 -0
- package/dist/test/services.d.mts.map +1 -0
- package/dist/test/services.mjs +44 -0
- package/dist/test/services.mjs.map +1 -0
- package/dist/test/stress.d.mts +2 -0
- package/dist/test/stress.d.mts.map +1 -0
- package/dist/test/stress.mjs +26 -0
- package/dist/test/stress.mjs.map +1 -0
- package/dist/test/timing.d.mts +2 -0
- package/dist/test/timing.d.mts.map +1 -0
- package/dist/test/timing.mjs +68 -0
- package/dist/test/timing.mjs.map +1 -0
- package/dist/types.d.mts +23 -0
- package/dist/types.d.mts.map +1 -0
- package/dist/types.mjs +25 -0
- package/dist/types.mjs.map +1 -0
- package/dist/worker.d.mts +27 -0
- package/dist/worker.d.mts.map +1 -0
- package/dist/worker.mjs +219 -0
- package/dist/worker.mjs.map +1 -0
- package/package.json +3 -4
- package/src/{EbusReject.ts → EbusReject.mts} +1 -1
- package/src/{EbusUnpackedResult.ts → EbusUnpackedResult.mts} +3 -3
- package/src/{broker.ts → broker.mts} +6 -6
- package/src/{client.ts → client.mts} +1 -1
- package/src/{clientBlocking.ts → clientBlocking.mts} +8 -8
- package/src/{clientNonBlocking.ts → clientNonBlocking.mts} +9 -9
- package/src/{consts.ts → consts.mts} +1 -1
- package/src/{delayWorker.ts → delayWorker.mts} +3 -3
- package/src/{echoWorker.ts → echoWorker.mts} +2 -2
- package/src/{errorWorker.ts → errorWorker.mts} +3 -3
- package/src/index.mts +19 -0
- package/src/{loadConfiguration.ts → loadConfiguration.mts} +2 -2
- package/src/{pub.ts → pub.mts} +3 -3
- package/src/{rejectWorker.ts → rejectWorker.mts} +3 -3
- package/src/run/all.mts +14 -0
- package/src/run/broker.mts +1 -1
- package/src/run/{call.ts → call.mts} +2 -2
- package/src/run/{calling.ts → calling.mts} +2 -2
- package/src/run/{callingBurst.ts → callingBurst.mts} +2 -2
- package/src/run/delay.mts +1 -1
- package/src/run/echo.mts +1 -1
- package/src/run/error.mts +1 -1
- package/src/run/ping.mts +2 -2
- package/src/run/{pub.ts → pub.mts} +1 -1
- package/src/run/{reject.ts → reject.mts} +1 -1
- package/src/run/{sub.ts → sub.mts} +2 -2
- package/src/run/{workers.ts → workers.mts} +1 -1
- package/src/{serialize.ts → serialize.mts} +1 -1
- package/src/{service.ts → service.mts} +1 -1
- package/src/{sub.ts → sub.mts} +3 -3
- package/src/test/{config.ts → config.mts} +3 -3
- package/src/test/{echo.ts → echo.mts} +4 -4
- package/src/test/{pack.ts → pack.mts} +1 -1
- package/src/test/{performance.ts → performance.mts} +4 -4
- package/src/test/{pub.ts → pub.mts} +6 -6
- package/src/test/{pub2.ts → pub2.mts} +4 -4
- package/src/test/{reject.ts → reject.mts} +4 -4
- package/src/test/{services.ts → services.mts} +3 -3
- package/src/test/{stress.ts → stress.mts} +2 -2
- package/src/test/{timing.ts → timing.mts} +5 -5
- package/src/{worker.ts → worker.mts} +7 -7
- package/src/index.ts +0 -19
- package/src/run/all.ts +0 -14
- /package/src/{EbusClientEvents.ts → EbusClientEvents.mts} +0 -0
- /package/src/{EbusConfiguration.ts → EbusConfiguration.mts} +0 -0
- /package/src/{EbusRejectReason.ts → EbusRejectReason.mts} +0 -0
- /package/src/{EbusRequestOptions.ts → EbusRequestOptions.mts} +0 -0
- /package/src/{block.ts → block.mts} +0 -0
- /package/src/{deferredPromise.ts → deferredPromise.mts} +0 -0
- /package/src/run/{termimalCommands.ts → termimalCommands.mts} +0 -0
- /package/src/{sleep.ts → sleep.mts} +0 -0
- /package/src/src/{notepack.d.ts → notepack.d.mts} +0 -0
- /package/src/test/{index.ts → index.mts} +0 -0
- /package/src/{types.ts → types.mts} +0 -0
package/dist/sub.mjs
ADDED
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { Log } from "cry-helpers";
|
|
2
|
+
import { TypedEmitter } from "tiny-typed-emitter";
|
|
3
|
+
import { Subscriber } from "zeromq";
|
|
4
|
+
import { loadConfiguration } from "./loadConfiguration.mjs";
|
|
5
|
+
import { unpack } from "./serialize.mjs";
|
|
6
|
+
const prefixes = ["EBUS_SUB", "EBUS"];
|
|
7
|
+
const log = new Log(prefixes);
|
|
8
|
+
export class Sub extends TypedEmitter {
|
|
9
|
+
constructor(config = {}) {
|
|
10
|
+
super();
|
|
11
|
+
this.configuration = loadConfiguration(prefixes, config);
|
|
12
|
+
this.address = this.configuration.pubAddress;
|
|
13
|
+
this.subscriptions = new Set();
|
|
14
|
+
}
|
|
15
|
+
async connect() {
|
|
16
|
+
if (this.sock && !this.sock.closed) {
|
|
17
|
+
try {
|
|
18
|
+
this.sock.close();
|
|
19
|
+
}
|
|
20
|
+
catch (_a) { }
|
|
21
|
+
}
|
|
22
|
+
this.sock = new Subscriber;
|
|
23
|
+
this.sock.events.on("connect", () => this.onConnect());
|
|
24
|
+
this.sock.events.on("disconnect", () => this.onDisconnect());
|
|
25
|
+
this.sock.reconnectInterval = 100;
|
|
26
|
+
await this.sock.connect(this.address);
|
|
27
|
+
log.status("subscriber started on", this.address);
|
|
28
|
+
for await (let sub of this.subscriptions) {
|
|
29
|
+
await this.sock.subscribe(sub);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
async subscribe(channel) {
|
|
33
|
+
this.subscriptions.add(channel);
|
|
34
|
+
if (this.sock)
|
|
35
|
+
await this.sock.subscribe(channel);
|
|
36
|
+
log.status("subscribed to ", channel);
|
|
37
|
+
}
|
|
38
|
+
async startReceiving() {
|
|
39
|
+
for (;;) {
|
|
40
|
+
await this.connect();
|
|
41
|
+
log.status("subscribe startReceiving()");
|
|
42
|
+
for await (const [channel, messagePacked] of this.sock) {
|
|
43
|
+
this.processMessage(messagePacked, channel);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
processMessage(messagePacked, channel) {
|
|
48
|
+
let message = unpack(messagePacked, {});
|
|
49
|
+
log.debug(`sub message received on ${channel}`, message);
|
|
50
|
+
this.emit("message", [channel.toString(), message]);
|
|
51
|
+
if (channel.toString() === "ebus/stop") {
|
|
52
|
+
log.status("sub closing because ebus went offline");
|
|
53
|
+
this.sock.close();
|
|
54
|
+
}
|
|
55
|
+
return message;
|
|
56
|
+
}
|
|
57
|
+
onConnect() {
|
|
58
|
+
log.status("subscriber connected");
|
|
59
|
+
this.emit("message", ["ebus/start", "connect"]);
|
|
60
|
+
this.emit("connect");
|
|
61
|
+
}
|
|
62
|
+
onDisconnect() {
|
|
63
|
+
log.status("subscriber disconnected");
|
|
64
|
+
this.emit("message", ["ebus/stop", "disconnect"]);
|
|
65
|
+
this.emit("disconnect");
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=sub.mjs.map
|
package/dist/sub.mjs.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sub.mjs","sourceRoot":"","sources":["../src/sub.mts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.d.mts","sourceRoot":"","sources":["../../src/test/config.mts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { expect } from "chai";
|
|
2
|
+
import { Client } from "../client.mjs";
|
|
3
|
+
import { EchoWorker } from "../echoWorker.mjs";
|
|
4
|
+
import { Broker } from "../index.mjs";
|
|
5
|
+
describe('services', async function () {
|
|
6
|
+
this.timeout(4000);
|
|
7
|
+
process.env.ebus_server = "tcp://localhost";
|
|
8
|
+
process.env.ebus_port = "4444";
|
|
9
|
+
let broker = new Broker();
|
|
10
|
+
broker.start();
|
|
11
|
+
let worker = new EchoWorker();
|
|
12
|
+
worker.start();
|
|
13
|
+
let client = new Client();
|
|
14
|
+
it('should be at right port', async () => {
|
|
15
|
+
expect(broker.configuration.address).to.match(/:4444$/);
|
|
16
|
+
expect(worker.configuration.address).to.match(/:4444$/);
|
|
17
|
+
expect(client.configuration.address).to.match(/:4444$/);
|
|
18
|
+
});
|
|
19
|
+
it('exists', () => {
|
|
20
|
+
process.exit();
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
//# sourceMappingURL=config.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.mjs","sourceRoot":"","sources":["../../src/test/config.mts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC9B,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAe,MAAM,cAAc,CAAC;AAEnD,QAAQ,CAAC,UAAU,EAAE,KAAK;IAEtB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IAElB,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,iBAAiB,CAAA;IAC3C,OAAO,CAAC,GAAG,CAAC,SAAS,GAAG,MAAM,CAAA;IAE9B,IAAI,MAAM,GAAG,IAAI,MAAM,EAAE,CAAA;IACzB,MAAM,CAAC,KAAK,EAAE,CAAA;IACd,IAAI,MAAM,GAAG,IAAI,UAAU,EAAE,CAAA;IAC7B,MAAM,CAAC,KAAK,EAAE,CAAA;IACd,IAAI,MAAM,GAAG,IAAI,MAAM,EAAE,CAAA;IAGzB,EAAE,CAAC,yBAAyB,EAAE,KAAK,IAAI,EAAE;QACrC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QACvD,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QACvD,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;IAC3D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;QACd,OAAO,CAAC,IAAI,EAAE,CAAA;IAClB,CAAC,CAAC,CAAA;AAEN,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"echo.d.mts","sourceRoot":"","sources":["../../src/test/echo.mts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { expect } from "chai";
|
|
2
|
+
import { Client } from "../client.mjs";
|
|
3
|
+
import { EchoWorker } from "../echoWorker.mjs";
|
|
4
|
+
import { Broker, DelayWorker, unpack, pack } from "../index.mjs";
|
|
5
|
+
describe('echo worker', async function () {
|
|
6
|
+
this.timeout(60000);
|
|
7
|
+
new Broker().start();
|
|
8
|
+
new EchoWorker().start();
|
|
9
|
+
new DelayWorker().start();
|
|
10
|
+
let client = new Client();
|
|
11
|
+
it('should return passed-in object', async () => {
|
|
12
|
+
let rep = await client.request("echo", {
|
|
13
|
+
delay: 50,
|
|
14
|
+
}, { receiveTimeout: 120000 });
|
|
15
|
+
expect(rep === null || rep === void 0 ? void 0 : rep.delay).to.eq(50);
|
|
16
|
+
});
|
|
17
|
+
it('should return passed-in object zipped', async () => {
|
|
18
|
+
let rep = await client.request("delay", { delay: 50 }, { zip: true, receiveTimeout: 120000 });
|
|
19
|
+
expect(rep === null || rep === void 0 ? void 0 : rep.delay).to.eq(50);
|
|
20
|
+
});
|
|
21
|
+
it('should return passed-in object raw', async () => {
|
|
22
|
+
let load = Buffer.from("ABC");
|
|
23
|
+
let rep = await client.request("echo", load, { raw: true });
|
|
24
|
+
expect(rep === null || rep === void 0 ? void 0 : rep.toString()).to.eq("ABC");
|
|
25
|
+
});
|
|
26
|
+
it('should return passed-in object raw and zipped', async () => {
|
|
27
|
+
let load = Buffer.from("ABC");
|
|
28
|
+
let rep = await client.request("echo", load, { raw: true, zip: true });
|
|
29
|
+
expect(Buffer.from(rep).toString()).to.eq("ABC");
|
|
30
|
+
});
|
|
31
|
+
it('should return unpacked object', async () => {
|
|
32
|
+
let load = Buffer.from("ABC");
|
|
33
|
+
let res = (await client.requestUpacked("echo", load, { raw: true, zip: true, }));
|
|
34
|
+
let rep = unpack(res.data, res.opts);
|
|
35
|
+
expect(Buffer.from(rep).toString()).to.eq("ABC");
|
|
36
|
+
});
|
|
37
|
+
it('should accept externally prepacked object', async () => {
|
|
38
|
+
let load = { a: { b: 2 } };
|
|
39
|
+
let loadPrepacked = pack(load, { zip: true });
|
|
40
|
+
let rep = (await client.request("echo", loadPrepacked, { prepacked: true, zip: true, receiveTimeout: 30000 }));
|
|
41
|
+
expect(rep.a.b).to.eq(2);
|
|
42
|
+
});
|
|
43
|
+
it('should accept externally prepacked object', async () => {
|
|
44
|
+
let load = { a: { b: 2 } };
|
|
45
|
+
let loadPrepacked = pack(load, { zip: true });
|
|
46
|
+
let res = (await client.requestUpacked("echo", loadPrepacked, { prepacked: true, zip: true, receiveTimeout: 30000 }));
|
|
47
|
+
let rep = unpack(res.data, res.opts);
|
|
48
|
+
expect(rep.a.b).to.eq(2);
|
|
49
|
+
});
|
|
50
|
+
it('exists', () => {
|
|
51
|
+
process.exit();
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
//# sourceMappingURL=echo.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"echo.mjs","sourceRoot":"","sources":["../../src/test/echo.mts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAA;AAC7B,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAEjE,QAAQ,CAAC,aAAa,EAAE,KAAK;IAEzB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IAEnB,IAAI,MAAM,EAAE,CAAC,KAAK,EAAE,CAAA;IACpB,IAAI,UAAU,EAAE,CAAC,KAAK,EAAE,CAAA;IACxB,IAAI,WAAW,EAAE,CAAC,KAAK,EAAE,CAAA;IAEzB,IAAI,MAAM,GAAG,IAAI,MAAM,EAAE,CAAA;IAEzB,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAC5C,IAAI,GAAG,GAAG,MAAM,MAAM,CAAC,OAAO,CAAoB,MAAM,EAAE;YACtD,KAAK,EAAE,EAAE;SACZ,EAAE,EAAE,cAAc,EAAE,MAAM,EAAE,CAAC,CAAA;QAC9B,MAAM,CAAC,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACnD,IAAI,GAAG,GAAG,MAAM,MAAM,CAAC,OAAO,CAAoB,OAAO,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,CAAC,CAAA;QAChH,MAAM,CAAC,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAA;IAChC,CAAC,CAAC,CAAC;IAGH,EAAE,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAChD,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAC7B,IAAI,GAAG,GAAG,MAAM,MAAM,CAAC,OAAO,CAAoB,MAAM,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAA;QAC9E,MAAM,CAAC,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,CAAA;IACxC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC3D,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAC7B,IAAI,GAAG,GAAG,MAAM,MAAM,CAAC,OAAO,CAAoB,MAAM,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAA;QACzF,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAU,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,CAAA;IAC3D,CAAC,CAAC,CAAC;IAGH,EAAE,CAAC,+BAA+B,EAAE,KAAK,IAAI,EAAE;QAC3C,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAC7B,IAAI,GAAG,GAAG,CAAC,MAAM,MAAM,CAAC,cAAc,CAAoB,MAAM,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,CAAC,CAA0C,CAAA;QAC5I,IAAI,GAAG,GAAG,MAAM,CAAS,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,CAAA;QAC5C,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAU,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,CAAA;IAC3D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;QACvD,IAAI,IAAI,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAA;QAC1B,IAAI,aAAa,GAAG,IAAI,CAAC,IAAI,EAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAA;QAC5C,IAAI,GAAG,GAAG,CAAC,MAAM,MAAM,CAAC,OAAO,CAAiB,MAAM,EAAE,aAAa,EAAE,EAAE,SAAS,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAG,cAAc,EAAC,KAAK,EAAE,CAAC,CAAC,CAAA;QAC7H,MAAM,CAAC,GAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;IAC7B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;QACvD,IAAI,IAAI,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAA;QAC1B,IAAI,aAAa,GAAG,IAAI,CAAC,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAA;QAC7C,IAAI,GAAG,GAAG,CAAC,MAAM,MAAM,CAAC,cAAc,CAAkB,MAAM,EAAE,aAAa,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC,CAAmD,CAAA;QACxL,IAAI,GAAG,GAAG,MAAM,CAAoB,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,CAAA;QACvD,MAAM,CAAC,GAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;IAC7B,CAAC,CAAC,CAAC;IAIH,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;QACd,OAAO,CAAC,IAAI,EAAE,CAAA;IAClB,CAAC,CAAC,CAAA;AAEN,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.mts","sourceRoot":"","sources":["../../src/test/index.mts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
// import { Broker } from "../broker"
|
|
2
|
+
// import { Client } from "../client"
|
|
3
|
+
// import { Worker } from "../worker"
|
|
4
|
+
export {};
|
|
5
|
+
// async function sleep(msec: number) {
|
|
6
|
+
// return new Promise(resolve => setTimeout(resolve, msec))
|
|
7
|
+
// }
|
|
8
|
+
// class TeaWorker extends Worker {
|
|
9
|
+
// service = "tea"
|
|
10
|
+
// async process(msg: Buffer): Promise<string> {
|
|
11
|
+
// await sleep(Math.random() * 100)
|
|
12
|
+
// return msg.toString()
|
|
13
|
+
// }
|
|
14
|
+
// }
|
|
15
|
+
// class CoffeeWorker extends Worker {
|
|
16
|
+
// service = "coffee"
|
|
17
|
+
// async process(msgs: Buffer): Promise<string> {
|
|
18
|
+
// await sleep(Math.random() * 200)
|
|
19
|
+
// return msgs.toString()
|
|
20
|
+
// }
|
|
21
|
+
// }
|
|
22
|
+
// const broker = new Broker()
|
|
23
|
+
// const workers = [new TeaWorker(), /* new CoffeeWorker(), new TeaWorker() */]
|
|
24
|
+
// let client = new Client()
|
|
25
|
+
// async function main() {
|
|
26
|
+
// for (const worker of workers) worker.start()
|
|
27
|
+
// broker.start()
|
|
28
|
+
// /* Requests are issued in parallel. */
|
|
29
|
+
// await Promise.all([
|
|
30
|
+
// client.request("soda", "cola", { zip: true, receiveTimeout:1 } ),
|
|
31
|
+
// client.request("tea", "oolong", { zip: true }),
|
|
32
|
+
// client.request("tea", "sencha"),
|
|
33
|
+
// client.request("tea", "earl grey"),
|
|
34
|
+
// client.request("tea", "jasmine"),
|
|
35
|
+
// client.request("coffee", "cappuccino"),
|
|
36
|
+
// client.request("coffee", "latte"),
|
|
37
|
+
// client.request("coffee", "espresso"),
|
|
38
|
+
// client.request("coffee", "irish coffee"),
|
|
39
|
+
// ])
|
|
40
|
+
// for (const worker of workers) worker.stop()
|
|
41
|
+
// broker.stop()
|
|
42
|
+
// }
|
|
43
|
+
// main().catch(err => {
|
|
44
|
+
// console.error(err)
|
|
45
|
+
// process.exit(1)
|
|
46
|
+
// })
|
|
47
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sourceRoot":"","sources":["../../src/test/index.mts"],"names":[],"mappings":"AAAA,qCAAqC;AACrC,qCAAqC;AACrC,qCAAqC;;AAErC,uCAAuC;AACvC,+DAA+D;AAC/D,IAAI;AAEJ,mCAAmC;AACnC,sBAAsB;AAEtB,oDAAoD;AACpD,2CAA2C;AAC3C,gCAAgC;AAChC,QAAQ;AACR,IAAI;AAEJ,sCAAsC;AACtC,yBAAyB;AAEzB,qDAAqD;AACrD,2CAA2C;AAC3C,iCAAiC;AACjC,QAAQ;AACR,IAAI;AAEJ,8BAA8B;AAC9B,+EAA+E;AAE/E,4BAA4B;AAE5B,0BAA0B;AAC1B,mDAAmD;AACnD,qBAAqB;AAErB,6CAA6C;AAC7C,0BAA0B;AAC1B,4EAA4E;AAC5E,0DAA0D;AAC1D,2CAA2C;AAC3C,8CAA8C;AAC9C,4CAA4C;AAC5C,kDAAkD;AAClD,6CAA6C;AAC7C,gDAAgD;AAChD,oDAAoD;AACpD,SAAS;AAET,kDAAkD;AAClD,oBAAoB;AACpB,IAAI;AAEJ,wBAAwB;AACxB,yBAAyB;AACzB,sBAAsB;AACtB,KAAK"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pack.d.mts","sourceRoot":"","sources":["../../src/test/pack.mts"],"names":[],"mappings":""}
|