|
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