|
6 | 6 | import { initLogger } from './logger';
|
7 | 7 | initLogger();
|
8 | 8 |
|
9 |
| -import { finish, runner } from './common'; |
| 9 | +import { finish } from './common'; |
10 | 10 | import { readConfigurationFile } from './config';
|
11 |
| -import { Session } from '../src/api/session'; |
12 | 11 |
|
13 | 12 | import * as proto from 'protocol';
|
14 | 13 | import * as $ from 'platform/types/observe';
|
15 | 14 | import * as Types from '../src/protocol';
|
| 15 | +import * as runners from './runners'; |
16 | 16 |
|
17 | 17 | const config = readConfigurationFile().get().tests.protocol;
|
18 | 18 |
|
19 | 19 | describe('Protocol', function () {
|
20 | 20 | it(config.regular.list[1], function () {
|
21 |
| - return runner(config.regular, 1, async (logger, done, collector) => { |
| 21 | + return runners.noSession(config.regular, 1, async (logger, done) => { |
22 | 22 | {
|
23 | 23 | let origin = Types.toObserveOptions({
|
24 | 24 | origin: { File: ['somefile', $.Types.File.FileType.Text, 'path_to_file'] },
|
@@ -54,69 +54,53 @@ describe('Protocol', function () {
|
54 | 54 | });
|
55 | 55 | });
|
56 | 56 | it(config.regular.list[2], function () {
|
57 |
| - return runner(config.regular, 2, async (logger, done, collector) => { |
58 |
| - Session.create() |
59 |
| - .then((session: Session) => { |
60 |
| - // Set provider into debug mode |
61 |
| - session.debug(true); |
62 |
| - const MESSAGES_COUNT = 1000; |
63 |
| - { |
64 |
| - const meausere: { json: number; proto: number } = { json: 0, proto: 0 }; |
65 |
| - meausere.json = Date.now(); |
66 |
| - for (let i = MESSAGES_COUNT; i >= 0; i -= 1) { |
67 |
| - const msg = session.getNativeSession().testGrabElsAsJson(false); |
68 |
| - expect(msg instanceof Array).toBe(true); |
69 |
| - } |
70 |
| - meausere.json = Date.now() - meausere.json; |
71 |
| - meausere.proto = Date.now(); |
72 |
| - for (let i = MESSAGES_COUNT; i >= 0; i -= 1) { |
73 |
| - const msg = session.getNativeSession().testGrabElsAsProto(false); |
74 |
| - expect(msg instanceof Array).toBe(true); |
75 |
| - } |
76 |
| - meausere.proto = Date.now() - meausere.proto; |
77 |
| - console.log( |
78 |
| - `Receiving messages (no decoding) count: ${MESSAGES_COUNT}\nJSON: ${ |
79 |
| - meausere.json |
80 |
| - }ms (per msg ${(meausere.json / MESSAGES_COUNT).toFixed(2)});\nPROTO: ${ |
81 |
| - meausere.proto |
82 |
| - }ms (per msg ${(meausere.proto / MESSAGES_COUNT).toFixed(2)})`, |
83 |
| - ); |
84 |
| - } |
85 |
| - { |
86 |
| - const meausere: { json: number; proto: number } = { json: 0, proto: 0 }; |
87 |
| - meausere.json = Date.now(); |
88 |
| - for (let i = MESSAGES_COUNT; i >= 0; i -= 1) { |
89 |
| - const msg = session.getNativeSession().testGrabElsAsJson(); |
90 |
| - expect(msg instanceof Array).toBe(true); |
91 |
| - } |
92 |
| - meausere.json = Date.now() - meausere.json; |
93 |
| - meausere.proto = Date.now(); |
94 |
| - for (let i = MESSAGES_COUNT; i >= 0; i -= 1) { |
95 |
| - const msg = session.getNativeSession().testGrabElsAsProto(); |
96 |
| - expect(msg instanceof Array).toBe(true); |
97 |
| - } |
98 |
| - meausere.proto = Date.now() - meausere.proto; |
99 |
| - console.log( |
100 |
| - `Grabbing messages (with decoding) count: ${MESSAGES_COUNT}\nJSON: ${ |
101 |
| - meausere.json |
102 |
| - }ms (per msg ${(meausere.json / MESSAGES_COUNT).toFixed(2)});\nPROTO: ${ |
103 |
| - meausere.proto |
104 |
| - }ms (per msg ${(meausere.proto / MESSAGES_COUNT).toFixed(2)})`, |
105 |
| - ); |
106 |
| - } |
107 |
| - finish(session, done); |
108 |
| - }) |
109 |
| - .catch((err: Error) => { |
110 |
| - finish( |
111 |
| - undefined, |
112 |
| - done, |
113 |
| - new Error( |
114 |
| - `Fail to create session due error: ${ |
115 |
| - err instanceof Error ? err.message : err |
116 |
| - }`, |
117 |
| - ), |
118 |
| - ); |
119 |
| - }); |
| 57 | + return runners.withSession(config.regular, 2, async (logger, done, comps) => { |
| 58 | + const MESSAGES_COUNT = 1000; |
| 59 | + { |
| 60 | + const meausere: { json: number; proto: number } = { json: 0, proto: 0 }; |
| 61 | + meausere.json = Date.now(); |
| 62 | + for (let i = MESSAGES_COUNT; i >= 0; i -= 1) { |
| 63 | + const msg = comps.session.getNativeSession().testGrabElsAsJson(false); |
| 64 | + expect(msg instanceof Array).toBe(true); |
| 65 | + } |
| 66 | + meausere.json = Date.now() - meausere.json; |
| 67 | + meausere.proto = Date.now(); |
| 68 | + for (let i = MESSAGES_COUNT; i >= 0; i -= 1) { |
| 69 | + const msg = comps.session.getNativeSession().testGrabElsAsProto(false); |
| 70 | + expect(msg instanceof Array).toBe(true); |
| 71 | + } |
| 72 | + meausere.proto = Date.now() - meausere.proto; |
| 73 | + console.log( |
| 74 | + `Receiving messages (no decoding) count: ${MESSAGES_COUNT}\nJSON: ${ |
| 75 | + meausere.json |
| 76 | + }ms (per msg ${(meausere.json / MESSAGES_COUNT).toFixed(2)});\nPROTO: ${ |
| 77 | + meausere.proto |
| 78 | + }ms (per msg ${(meausere.proto / MESSAGES_COUNT).toFixed(2)})`, |
| 79 | + ); |
| 80 | + } |
| 81 | + { |
| 82 | + const meausere: { json: number; proto: number } = { json: 0, proto: 0 }; |
| 83 | + meausere.json = Date.now(); |
| 84 | + for (let i = MESSAGES_COUNT; i >= 0; i -= 1) { |
| 85 | + const msg = comps.session.getNativeSession().testGrabElsAsJson(); |
| 86 | + expect(msg instanceof Array).toBe(true); |
| 87 | + } |
| 88 | + meausere.json = Date.now() - meausere.json; |
| 89 | + meausere.proto = Date.now(); |
| 90 | + for (let i = MESSAGES_COUNT; i >= 0; i -= 1) { |
| 91 | + const msg = comps.session.getNativeSession().testGrabElsAsProto(); |
| 92 | + expect(msg instanceof Array).toBe(true); |
| 93 | + } |
| 94 | + meausere.proto = Date.now() - meausere.proto; |
| 95 | + console.log( |
| 96 | + `Grabbing messages (with decoding) count: ${MESSAGES_COUNT}\nJSON: ${ |
| 97 | + meausere.json |
| 98 | + }ms (per msg ${(meausere.json / MESSAGES_COUNT).toFixed(2)});\nPROTO: ${ |
| 99 | + meausere.proto |
| 100 | + }ms (per msg ${(meausere.proto / MESSAGES_COUNT).toFixed(2)})`, |
| 101 | + ); |
| 102 | + } |
| 103 | + finish(comps.session, done); |
120 | 104 | });
|
121 | 105 | });
|
122 | 106 | });
|
0 commit comments