jspurefix 1.2.0 → 2.0.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/.travis.yml +1 -1
- package/README.md +48 -2
- package/appveyor.yml +46 -11
- package/data/session/certs/ca/ca.crt +33 -0
- package/data/session/certs/ca/ca.key +54 -0
- package/data/session/certs/client/client.crt +31 -0
- package/data/session/certs/client/client.key +51 -0
- package/data/session/certs/server/server.crt +31 -0
- package/data/session/certs/server/server.key +51 -0
- package/data/session/genkey.ps1 +179 -0
- package/dist/a-session-msg-factory.d.ts +0 -0
- package/dist/a-session-msg-factory.js +1 -0
- package/dist/a-session-msg-factory.js.map +1 -0
- package/dist/ascii-encoder.test.d.ts +0 -0
- package/dist/ascii-encoder.test.js +1 -0
- package/dist/ascii-encoder.test.js.map +1 -0
- package/dist/ascii-parser.test.d.ts +0 -0
- package/dist/ascii-parser.test.js +1 -0
- package/dist/ascii-parser.test.js.map +1 -0
- package/dist/ascii-segment.test.d.ts +0 -0
- package/dist/ascii-segment.test.js +1 -0
- package/dist/ascii-segment.test.js.map +1 -0
- package/dist/ascii-store-replay.test.d.ts +0 -0
- package/dist/ascii-store-replay.test.js +1 -0
- package/dist/ascii-store-replay.test.js.map +1 -0
- package/dist/ascii-tag-pos.test.d.ts +0 -0
- package/dist/ascii-tag-pos.test.js +1 -0
- package/dist/ascii-tag-pos.test.js.map +1 -0
- package/dist/buffer/{ascii-chars.d.ts → ascii/ascii-chars.d.ts} +0 -0
- package/dist/buffer/{ascii-chars.js → ascii/ascii-chars.js} +0 -0
- package/dist/buffer/ascii/ascii-chars.js.map +1 -0
- package/dist/buffer/ascii/ascii-encoder.d.ts +5 -3
- package/dist/buffer/ascii/ascii-encoder.js +82 -48
- package/dist/buffer/ascii/ascii-encoder.js.map +1 -1
- package/dist/buffer/ascii/ascii-parser-state.d.ts +3 -10
- package/dist/buffer/ascii/ascii-parser-state.js +37 -25
- package/dist/buffer/ascii/ascii-parser-state.js.map +1 -1
- package/dist/buffer/ascii/ascii-parser.d.ts +7 -7
- package/dist/buffer/ascii/ascii-parser.js +50 -24
- package/dist/buffer/ascii/ascii-parser.js.map +1 -1
- package/dist/buffer/ascii/ascii-segment-parser.d.ts +2 -2
- package/dist/buffer/ascii/ascii-segment-parser.js +34 -13
- package/dist/buffer/ascii/ascii-segment-parser.js.map +1 -1
- package/dist/buffer/ascii/ascii-view.d.ts +2 -4
- package/dist/buffer/ascii/ascii-view.js +11 -15
- package/dist/buffer/ascii/ascii-view.js.map +1 -1
- package/dist/buffer/ascii/index.d.ts +1 -0
- package/dist/buffer/ascii/index.js +1 -0
- package/dist/buffer/ascii/index.js.map +1 -1
- package/dist/buffer/ascii/parse-state.d.ts +8 -0
- package/dist/buffer/ascii/parse-state.js +13 -0
- package/dist/buffer/ascii/parse-state.js.map +1 -0
- package/dist/buffer/ascii/time-formatter.js +1 -1
- package/dist/buffer/ascii/time-formatter.js.map +1 -1
- package/dist/buffer/elastic-buffer.js +29 -8
- package/dist/buffer/elastic-buffer.js.map +1 -1
- package/dist/buffer/encode-proxy.d.ts +1 -1
- package/dist/buffer/encode-proxy.js +16 -17
- package/dist/buffer/encode-proxy.js.map +1 -1
- package/dist/buffer/fixml/fixml-encoder.d.ts +2 -1
- package/dist/buffer/fixml/fixml-encoder.js +43 -20
- package/dist/buffer/fixml/fixml-encoder.js.map +1 -1
- package/dist/buffer/fixml/fixml-parser.js +47 -24
- package/dist/buffer/fixml/fixml-parser.js.map +1 -1
- package/dist/buffer/fixml/fixml-view.d.ts +2 -2
- package/dist/buffer/fixml/fixml-view.js +13 -13
- package/dist/buffer/fixml/fixml-view.js.map +1 -1
- package/dist/buffer/fixml/populated-attributes.d.ts +5 -0
- package/dist/buffer/fixml/populated-attributes.js +3 -0
- package/dist/buffer/fixml/populated-attributes.js.map +1 -0
- package/dist/buffer/index.d.ts +4 -8
- package/dist/buffer/index.js +4 -8
- package/dist/buffer/index.js.map +1 -1
- package/dist/buffer/msg-encoder.d.ts +2 -1
- package/dist/buffer/msg-encoder.js.map +1 -1
- package/dist/buffer/msg-view.d.ts +3 -3
- package/dist/buffer/msg-view.js +8 -5
- package/dist/buffer/msg-view.js.map +1 -1
- package/dist/buffer/segment/segment-description.d.ts +26 -0
- package/dist/buffer/segment/segment-description.js +72 -0
- package/dist/buffer/segment/segment-description.js.map +1 -0
- package/dist/buffer/segment/segment-summary.d.ts +13 -0
- package/dist/buffer/segment/segment-summary.js +20 -0
- package/dist/buffer/segment/segment-summary.js.map +1 -0
- package/dist/buffer/segment/segment-type.d.ts +8 -0
- package/dist/buffer/segment/segment-type.js +13 -0
- package/dist/buffer/segment/segment-type.js.map +1 -0
- package/dist/buffer/segment-description.d.ts +2 -9
- package/dist/buffer/segment-description.js +5 -13
- package/dist/buffer/segment-description.js.map +1 -1
- package/dist/buffer/segment-type.d.ts +8 -0
- package/dist/buffer/segment-type.js +13 -0
- package/dist/buffer/segment-type.js.map +1 -0
- package/dist/buffer/structure.d.ts +3 -3
- package/dist/buffer/structure.js +1 -1
- package/dist/buffer/structure.js.map +1 -1
- package/dist/buffer/tag/tag-pos.d.ts +12 -0
- package/dist/buffer/tag/tag-pos.js +55 -0
- package/dist/buffer/tag/tag-pos.js.map +1 -0
- package/dist/buffer/tag/tag-type.d.ts +13 -0
- package/dist/buffer/tag/tag-type.js +18 -0
- package/dist/buffer/tag/tag-type.js.map +1 -0
- package/dist/buffer/tag/tags.d.ts +21 -0
- package/dist/buffer/tag/tags.js +122 -0
- package/dist/buffer/tag/tags.js.map +1 -0
- package/dist/buffer/tag-type.d.ts +13 -0
- package/dist/buffer/tag-type.js +18 -0
- package/dist/buffer/tag-type.js.map +1 -0
- package/dist/buffer/tags.d.ts +3 -14
- package/dist/buffer/tags.js +23 -36
- package/dist/buffer/tags.js.map +1 -1
- package/dist/config/get-js-fx-logger.d.ts +4 -0
- package/dist/config/get-js-fx-logger.js +3 -0
- package/dist/config/get-js-fx-logger.js.map +1 -0
- package/dist/config/index.d.ts +1 -0
- package/dist/config/index.js +1 -0
- package/dist/config/index.js.map +1 -1
- package/dist/config/js-fix-config.d.ts +4 -1
- package/dist/config/js-fix-config.js +3 -3
- package/dist/config/js-fix-config.js.map +1 -1
- package/dist/config/js-fix-logger.d.ts +0 -3
- package/dist/config/js-fix-logger.js.map +1 -1
- package/dist/dict-parser.js +30 -25
- package/dist/dict-parser.js.map +1 -1
- package/dist/dictionary/compiler/compiler-type.js +7 -7
- package/dist/dictionary/compiler/compiler-type.js.map +1 -1
- package/dist/dictionary/compiler/enum-compiler.d.ts +1 -0
- package/dist/dictionary/compiler/enum-compiler.js +11 -1
- package/dist/dictionary/compiler/enum-compiler.js.map +1 -1
- package/dist/dictionary/compiler/msg-compiler.js +8 -6
- package/dist/dictionary/compiler/msg-compiler.js.map +1 -1
- package/dist/dictionary/contained/contained-component-field.js +2 -1
- package/dist/dictionary/contained/contained-component-field.js.map +1 -1
- package/dist/dictionary/contained/contained-field-dispatch.d.ts +1 -14
- package/dist/dictionary/contained/contained-field-dispatch.js +4 -4
- package/dist/dictionary/contained/contained-field-dispatch.js.map +1 -1
- package/dist/dictionary/contained/contained-field-dispatcher.d.ts +14 -0
- package/dist/dictionary/contained/contained-field-dispatcher.js +3 -0
- package/dist/dictionary/contained/contained-field-dispatcher.js.map +1 -0
- package/dist/dictionary/contained/contained-field-set.d.ts +1 -1
- package/dist/dictionary/contained/contained-field-set.js +12 -11
- package/dist/dictionary/contained/contained-field-set.js.map +1 -1
- package/dist/dictionary/contained/contained-field-type.d.ts +5 -0
- package/dist/dictionary/contained/contained-field-type.js +10 -0
- package/dist/dictionary/contained/contained-field-type.js.map +1 -0
- package/dist/dictionary/contained/contained-field.d.ts +1 -5
- package/dist/dictionary/contained/contained-field.js +1 -7
- package/dist/dictionary/contained/contained-field.js.map +1 -1
- package/dist/dictionary/contained/contained-group-field.js +2 -1
- package/dist/dictionary/contained/contained-group-field.js.map +1 -1
- package/dist/dictionary/contained/contained-simple-field.js +2 -1
- package/dist/dictionary/contained/contained-simple-field.js.map +1 -1
- package/dist/dictionary/{fields-dispatch.d.ts → contained/field-dispatcher.d.ts} +3 -2
- package/dist/dictionary/contained/field-dispatcher.js +3 -0
- package/dist/dictionary/contained/field-dispatcher.js.map +1 -0
- package/dist/dictionary/contained/fields-dispatch.d.ts +6 -0
- package/dist/dictionary/contained/fields-dispatch.js +42 -0
- package/dist/dictionary/contained/fields-dispatch.js.map +1 -0
- package/dist/dictionary/contained/index.d.ts +2 -0
- package/dist/dictionary/contained/index.js +2 -0
- package/dist/dictionary/contained/index.js.map +1 -1
- package/dist/dictionary/contained-set-type.d.ts +5 -0
- package/dist/dictionary/contained-set-type.js +10 -0
- package/dist/dictionary/contained-set-type.js.map +1 -0
- package/dist/dictionary/definition/component-field-definition.js +2 -2
- package/dist/dictionary/definition/component-field-definition.js.map +1 -1
- package/dist/dictionary/definition/fix-definitions.d.ts +2 -1
- package/dist/dictionary/definition/fix-definitions.js.map +1 -1
- package/dist/dictionary/definition/group-field-definition.js +2 -2
- package/dist/dictionary/definition/group-field-definition.js.map +1 -1
- package/dist/dictionary/definition/index.d.ts +0 -1
- package/dist/dictionary/definition/index.js +0 -1
- package/dist/dictionary/definition/index.js.map +1 -1
- package/dist/dictionary/definition/message-definition.js +2 -2
- package/dist/dictionary/definition/message-definition.js.map +1 -1
- package/dist/dictionary/definition/simple-field-definition.d.ts +1 -1
- package/dist/dictionary/definition/simple-field-definition.js +5 -4
- package/dist/dictionary/definition/simple-field-definition.js.map +1 -1
- package/dist/dictionary/dict-primitive.d.ts +0 -11
- package/dist/dictionary/dict-primitive.js +0 -7
- package/dist/dictionary/dict-primitive.js.map +1 -1
- package/dist/dictionary/fix-definition-source.d.ts +6 -0
- package/dist/dictionary/fix-definition-source.js +11 -0
- package/dist/dictionary/fix-definition-source.js.map +1 -0
- package/dist/dictionary/fix-versions.d.ts +0 -9
- package/dist/dictionary/fix-versions.js +1 -39
- package/dist/dictionary/fix-versions.js.map +1 -1
- package/dist/dictionary/index.d.ts +1 -5
- package/dist/dictionary/index.js +1 -5
- package/dist/dictionary/index.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/abbreviations-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/abbreviations-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/abbreviations-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/base-parser.d.ts +2 -4
- package/dist/dictionary/parser/fix-repository/base-parser.js +1 -2
- package/dist/dictionary/parser/fix-repository/base-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/components-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/components-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/components-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/data-types-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/data-types-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/data-types-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/enums-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/enums-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/enums-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/fields-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/fields-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/fields-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/messages-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/messages-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/messages-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/msg-contents-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/msg-contents-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/msg-contents-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/repository-abbreviation.d.ts +5 -0
- package/dist/dictionary/parser/fix-repository/repository-abbreviation.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-abbreviation.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-component.d.ts +10 -0
- package/dist/dictionary/parser/fix-repository/repository-component.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-component.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-data-type.d.ts +6 -0
- package/dist/dictionary/parser/fix-repository/repository-data-type.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-data-type.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-enum.d.ts +7 -0
- package/dist/{standard_header.js → dictionary/parser/fix-repository/repository-enum.js} +1 -1
- package/dist/dictionary/parser/fix-repository/repository-enum.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-field.d.ts +11 -0
- package/dist/dictionary/parser/fix-repository/repository-field.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-field.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-message.d.ts +11 -0
- package/dist/dictionary/parser/fix-repository/repository-message.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-message.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-msg-content.d.ts +9 -0
- package/dist/dictionary/parser/fix-repository/repository-msg-content.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-msg-content.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-msg.d.ts +0 -0
- package/dist/dictionary/parser/fix-repository/repository-msg.js +1 -0
- package/dist/dictionary/parser/fix-repository/repository-msg.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-type.d.ts +0 -53
- package/dist/dictionary/parser/fix-repository/repository-type.js +0 -2
- package/dist/dictionary/parser/fix-repository/repository-type.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/repository-xml-parser.js +10 -10
- package/dist/dictionary/parser/fix-repository/repository-xml-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/repository.d.ts +12 -1
- package/dist/dictionary/parser/fix-repository/repository.js +50 -28
- package/dist/dictionary/parser/fix-repository/repository.js.map +1 -1
- package/dist/dictionary/parser/fixml/components-parser.d.ts +1 -1
- package/dist/dictionary/parser/fixml/components-parser.js.map +1 -1
- package/dist/dictionary/parser/fixml/fields-parser.d.ts +1 -1
- package/dist/dictionary/parser/fixml/fields-parser.js.map +1 -1
- package/dist/dictionary/parser/fixml/fix-xsd-parser.js +3 -2
- package/dist/dictionary/parser/fixml/fix-xsd-parser.js.map +1 -1
- package/dist/dictionary/parser/fixml/include-graph.js.map +1 -1
- package/dist/dictionary/parser/fixml/xsd-parser.d.ts +1 -1
- package/dist/dictionary/parser/fixml/xsd-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/field-definition-parser.d.ts +4 -4
- package/dist/dictionary/parser/quickfix/field-definition-parser.js +3 -3
- package/dist/dictionary/parser/quickfix/field-definition-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/field-set-parser.d.ts +4 -4
- package/dist/dictionary/parser/quickfix/field-set-parser.js +3 -3
- package/dist/dictionary/parser/quickfix/field-set-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/message-parser.d.ts +4 -4
- package/dist/dictionary/parser/quickfix/message-parser.js +3 -3
- package/dist/dictionary/parser/quickfix/message-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/node-parser.d.ts +4 -5
- package/dist/dictionary/parser/quickfix/node-parser.js +4 -4
- package/dist/dictionary/parser/quickfix/node-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/parse-state.d.ts +8 -0
- package/dist/dictionary/parser/quickfix/parse-state.js +13 -0
- package/dist/dictionary/parser/quickfix/parse-state.js.map +1 -0
- package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.d.ts +1 -9
- package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js +28 -35
- package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js.map +1 -1
- package/dist/dictionary/sax-node.d.ts +6 -0
- package/dist/{header.js → dictionary/sax-node.js} +1 -1
- package/dist/dictionary/sax-node.js.map +1 -0
- package/dist/dictionary/set-reduce.d.ts +5 -12
- package/dist/dictionary/set-reduce.js +28 -26
- package/dist/dictionary/set-reduce.js.map +1 -1
- package/dist/dictionary/type-dispatcher.d.ts +12 -0
- package/dist/dictionary/type-dispatcher.js +3 -0
- package/dist/dictionary/type-dispatcher.js.map +1 -0
- package/dist/dictionary/version-util.d.ts +4 -0
- package/dist/dictionary/version-util.js +36 -0
- package/dist/dictionary/version-util.js.map +1 -0
- package/dist/execution-report.test.d.ts +0 -0
- package/dist/execution-report.test.js +1 -0
- package/dist/execution-report.test.js.map +1 -0
- package/dist/experiment.d.ts +0 -0
- package/dist/experiment.js +1 -0
- package/dist/experiment.js.map +1 -0
- package/dist/fix-repo-dict.test.d.ts +0 -0
- package/dist/fix-repo-dict.test.js +1 -0
- package/dist/fix-repo-dict.test.js.map +1 -0
- package/dist/fix-session-state-args.d.ts +0 -0
- package/dist/fix-session-state-args.js +1 -0
- package/dist/fix-session-state-args.js.map +1 -0
- package/dist/fix-session-state.d.ts +0 -0
- package/dist/fix-session-state.js +1 -0
- package/dist/fix-session-state.js.map +1 -0
- package/dist/fix-session.d.ts +0 -0
- package/dist/fix-session.js +1 -0
- package/dist/fix-session.js.map +1 -0
- package/dist/fix.txt +1 -1
- package/dist/fixml-alloc-parse.test.d.ts +0 -0
- package/dist/fixml-alloc-parse.test.js +1 -0
- package/dist/fixml-alloc-parse.test.js.map +1 -0
- package/dist/fixml-mkt-data-fut-parse.test.d.ts +0 -0
- package/dist/fixml-mkt-data-fut-parse.test.js +1 -0
- package/dist/fixml-mkt-data-fut-parse.test.js.map +1 -0
- package/dist/fixml-mkt-data-settle-parse.test.d.ts +0 -0
- package/dist/fixml-mkt-data-settle-parse.test.js +1 -0
- package/dist/fixml-mkt-data-settle-parse.test.js.map +1 -0
- package/dist/fixml-tc-bi-lateral-parse.test.d.ts +0 -0
- package/dist/fixml-tc-bi-lateral-parse.test.js +1 -0
- package/dist/fixml-tc-bi-lateral-parse.test.js.map +1 -0
- package/dist/includes.test.d.ts +0 -0
- package/dist/includes.test.js +1 -0
- package/dist/includes.test.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/jsfix-cmd.d.ts +5 -0
- package/dist/jsfix-cmd.js +28 -21
- package/dist/jsfix-cmd.js.map +1 -1
- package/dist/launcher.d.ts +0 -0
- package/dist/launcher.js +1 -0
- package/dist/launcher.js.map +1 -0
- package/dist/logon.test.d.ts +0 -0
- package/dist/logon.test.js +1 -0
- package/dist/logon.test.js.map +1 -0
- package/dist/make-fix-session.d.ts +0 -0
- package/dist/make-fix-session.js +1 -0
- package/dist/make-fix-session.js.map +1 -0
- package/dist/memory-store.test.d.ts +0 -0
- package/dist/memory-store.test.js +1 -0
- package/dist/memory-store.test.js.map +1 -0
- package/dist/object.json +473 -698
- package/dist/qf-full-msg.test.d.ts +0 -0
- package/dist/qf-full-msg.test.js +1 -0
- package/dist/qf-full-msg.test.js.map +1 -0
- package/dist/repo-full-ascii-msg.test.d.ts +0 -0
- package/dist/repo-full-ascii-msg.test.js +1 -0
- package/dist/repo-full-ascii-msg.test.js.map +1 -0
- package/dist/runtime/DITokens.d.ts +20 -0
- package/dist/runtime/DITokens.js +25 -0
- package/dist/runtime/DITokens.js.map +1 -0
- package/dist/runtime/app-launcher.d.ts +27 -0
- package/dist/runtime/app-launcher.js +131 -0
- package/dist/runtime/app-launcher.js.map +1 -0
- package/dist/runtime/di-tokens.d.ts +28 -0
- package/dist/runtime/di-tokens.js +33 -0
- package/dist/runtime/di-tokens.js.map +1 -0
- package/dist/runtime/engine-factory.d.ts +4 -0
- package/dist/runtime/engine-factory.js +3 -0
- package/dist/runtime/engine-factory.js.map +1 -0
- package/dist/runtime/index.d.ts +5 -0
- package/dist/runtime/index.js +18 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/launcher.d.ts +29 -0
- package/dist/runtime/launcher.js +131 -0
- package/dist/runtime/launcher.js.map +1 -0
- package/dist/runtime/make-config.d.ts +11 -0
- package/dist/runtime/make-config.js +57 -0
- package/dist/runtime/make-config.js.map +1 -0
- package/dist/runtime/session-container.d.ts +16 -0
- package/dist/runtime/session-container.js +168 -0
- package/dist/runtime/session-container.js.map +1 -0
- package/dist/runtime/session-launcher.d.ts +26 -0
- package/dist/runtime/session-launcher.js +131 -0
- package/dist/runtime/session-launcher.js.map +1 -0
- package/dist/sample/http/oms/app.d.ts +1 -1
- package/dist/sample/http/oms/app.js +16 -12
- package/dist/sample/http/oms/app.js.map +1 -1
- package/dist/sample/http/oms/http-client.js +22 -2
- package/dist/sample/http/oms/http-client.js.map +1 -1
- package/dist/sample/http/oms/http-server.js +21 -2
- package/dist/sample/http/oms/http-server.js.map +1 -1
- package/dist/sample/launcher.d.ts +21 -3
- package/dist/sample/launcher.js +88 -11
- package/dist/sample/launcher.js.map +1 -1
- package/dist/sample/tcp/qf-md/app.d.ts +1 -1
- package/dist/sample/tcp/qf-md/app.js +11 -11
- package/dist/sample/tcp/qf-md/app.js.map +1 -1
- package/dist/sample/tcp/qf-md/md-client.js +21 -2
- package/dist/sample/tcp/qf-md/md-client.js.map +1 -1
- package/dist/sample/tcp/qf-md/md-server.js +20 -2
- package/dist/sample/tcp/qf-md/md-server.js.map +1 -1
- package/dist/sample/tcp/recovering-skeleton/app.d.ts +1 -1
- package/dist/sample/tcp/recovering-skeleton/app.js +36 -16
- package/dist/sample/tcp/recovering-skeleton/app.js.map +1 -1
- package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.d.ts +3 -1
- package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js +30 -8
- package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js.map +1 -1
- package/dist/sample/tcp/recovering-skeleton/skeleton-client.d.ts +1 -1
- package/dist/sample/tcp/recovering-skeleton/skeleton-client.js +22 -3
- package/dist/sample/tcp/recovering-skeleton/skeleton-client.js.map +1 -1
- package/dist/sample/tcp/recovering-skeleton/skeleton-server.js +21 -2
- package/dist/sample/tcp/recovering-skeleton/skeleton-server.js.map +1 -1
- package/dist/sample/tcp/skeleton/app.d.ts +1 -1
- package/dist/sample/tcp/skeleton/app.js +8 -13
- package/dist/sample/tcp/skeleton/app.js.map +1 -1
- package/dist/sample/tcp/skeleton/skeleton-session.d.ts +5 -1
- package/dist/sample/tcp/skeleton/skeleton-session.js +45 -4
- package/dist/sample/tcp/skeleton/skeleton-session.js.map +1 -1
- package/dist/sample/tcp/tls-trade-capture/app.d.ts +1 -1
- package/dist/sample/tcp/tls-trade-capture/app.js +4 -24
- package/dist/sample/tcp/tls-trade-capture/app.js.map +1 -1
- package/dist/sample/tcp/trade-capture/app-launcher.d.ts +6 -0
- package/dist/sample/tcp/trade-capture/app-launcher.js +21 -0
- package/dist/sample/tcp/trade-capture/app-launcher.js.map +1 -0
- package/dist/sample/tcp/trade-capture/app-launher.d.ts +0 -0
- package/dist/sample/tcp/trade-capture/app-launher.js +1 -0
- package/dist/sample/tcp/trade-capture/app-launher.js.map +1 -0
- package/dist/sample/tcp/trade-capture/app.d.ts +1 -1
- package/dist/sample/tcp/trade-capture/app.js +4 -21
- package/dist/sample/tcp/trade-capture/app.js.map +1 -1
- package/dist/sample/tcp/trade-capture/jsfix.test_client.txt +11 -14
- package/dist/sample/tcp/trade-capture/jsfix.test_server.txt +10 -14
- package/dist/sample/tcp/trade-capture/trade-capture-client.d.ts +1 -0
- package/dist/sample/tcp/trade-capture/trade-capture-client.js +7 -3
- package/dist/sample/tcp/trade-capture/trade-capture-client.js.map +1 -1
- package/dist/sample/tcp/trade-capture/trade-capture-server.js.map +1 -1
- package/dist/sample/tcp/trade-capture/trade-factory.js +7 -1
- package/dist/sample/tcp/trade-capture/trade-factory.js.map +1 -1
- package/dist/segment-description.d.ts +0 -0
- package/dist/segment-description.js +1 -0
- package/dist/segment-description.js.map +1 -0
- package/dist/segment-summary.d.ts +0 -0
- package/dist/segment-summary.js +1 -0
- package/dist/segment-summary.js.map +1 -0
- package/dist/segment-type.d.ts +0 -0
- package/dist/segment-type.js +1 -0
- package/dist/segment-type.js.map +1 -0
- package/dist/session-description.d.ts +0 -0
- package/dist/session-description.js +1 -0
- package/dist/session-description.js.map +1 -0
- package/dist/session-msg-factory.d.ts +0 -0
- package/dist/session-msg-factory.js +1 -0
- package/dist/session-msg-factory.js.map +1 -0
- package/dist/session-state.d.ts +0 -0
- package/dist/session-state.js +1 -0
- package/dist/session-state.js.map +1 -0
- package/dist/session-state.test.d.ts +0 -0
- package/dist/session-state.test.js +1 -0
- package/dist/session-state.test.js.map +1 -0
- package/dist/session.test.d.ts +0 -0
- package/dist/session.test.js +1 -0
- package/dist/session.test.js.map +1 -0
- package/dist/setup.d.ts +0 -0
- package/dist/setup.js +1 -0
- package/dist/setup.js.map +1 -0
- package/dist/skeleton-runner.d.ts +0 -0
- package/dist/skeleton-runner.js +1 -0
- package/dist/skeleton-runner.js.map +1 -0
- package/dist/store/fix-msg-ascii-store-resend.d.ts +3 -2
- package/dist/store/fix-msg-ascii-store-resend.js +30 -21
- package/dist/store/fix-msg-ascii-store-resend.js.map +1 -1
- package/dist/store/fix-msg-memory-store.d.ts +11 -8
- package/dist/store/fix-msg-memory-store.js +108 -42
- package/dist/store/fix-msg-memory-store.js.map +1 -1
- package/dist/store/fix-msg-store-record.d.ts +4 -0
- package/dist/store/fix-msg-store-record.js +7 -0
- package/dist/store/fix-msg-store-record.js.map +1 -1
- package/dist/store/fix-msg-store-state.d.ts +6 -0
- package/dist/store/fix-msg-store-state.js +3 -0
- package/dist/store/fix-msg-store-state.js.map +1 -0
- package/dist/store/fix-msg-store.d.ts +8 -9
- package/dist/store/fix-msg-store.js.map +1 -1
- package/dist/structure.json +225 -485
- package/dist/tag-pos.d.ts +0 -0
- package/dist/tag-pos.js +1 -0
- package/dist/tag-pos.js.map +1 -0
- package/dist/tag-type.d.ts +0 -0
- package/dist/tag-type.js +1 -0
- package/dist/tag-type.js.map +1 -0
- package/dist/tags.d.ts +0 -0
- package/dist/tags.js +1 -0
- package/dist/tags.js.map +1 -0
- package/dist/test/ascii/ascii-encoder.test.d.ts +1 -0
- package/dist/test/ascii/ascii-encoder.test.js +507 -0
- package/dist/test/ascii/ascii-encoder.test.js.map +1 -0
- package/dist/test/ascii/ascii-parser.test.d.ts +1 -0
- package/dist/test/ascii/ascii-parser.test.js +123 -0
- package/dist/test/ascii/ascii-parser.test.js.map +1 -0
- package/dist/test/ascii/ascii-segment.test.d.ts +1 -0
- package/dist/test/ascii/ascii-segment.test.js +86 -0
- package/dist/test/ascii/ascii-segment.test.js.map +1 -0
- package/dist/test/ascii/ascii-store-replay.test.d.ts +1 -0
- package/dist/test/ascii/ascii-store-replay.test.js +92 -0
- package/dist/test/ascii/ascii-store-replay.test.js.map +1 -0
- package/dist/test/ascii/ascii-tag-pos.test.d.ts +1 -0
- package/dist/test/ascii/ascii-tag-pos.test.js +105 -0
- package/dist/test/ascii/ascii-tag-pos.test.js.map +1 -0
- package/dist/test/ascii/execution-report.test.d.ts +1 -0
- package/dist/test/ascii/execution-report.test.js +489 -0
- package/dist/test/ascii/execution-report.test.js.map +1 -0
- package/dist/test/ascii/fix-log-replay.test.d.ts +1 -0
- package/dist/test/{memory-store-test.js → ascii/fix-log-replay.test.js} +11 -23
- package/dist/test/ascii/fix-log-replay.test.js.map +1 -0
- package/dist/test/ascii/fix-repo-dict.test.d.ts +1 -0
- package/dist/test/ascii/fix-repo-dict.test.js +128 -0
- package/dist/test/ascii/fix-repo-dict.test.js.map +1 -0
- package/dist/test/ascii/includes.test.d.ts +1 -0
- package/dist/test/ascii/includes.test.js +43 -0
- package/dist/test/ascii/includes.test.js.map +1 -0
- package/dist/test/ascii/logon.test.d.ts +1 -0
- package/dist/test/ascii/logon.test.js +91 -0
- package/dist/test/ascii/logon.test.js.map +1 -0
- package/dist/test/ascii/memory-store.test.d.ts +1 -0
- package/dist/test/ascii/memory-store.test.js +75 -0
- package/dist/test/ascii/memory-store.test.js.map +1 -0
- package/dist/test/ascii/qf-full-msg.test.d.ts +1 -0
- package/dist/test/ascii/qf-full-msg.test.js +81 -0
- package/dist/test/ascii/qf-full-msg.test.js.map +1 -0
- package/dist/test/ascii/repo-full-ascii-msg.test.d.ts +1 -0
- package/dist/test/ascii/repo-full-ascii-msg.test.js +87 -0
- package/dist/test/ascii/repo-full-ascii-msg.test.js.map +1 -0
- package/dist/test/ascii/session-state.test.d.ts +1 -0
- package/dist/test/ascii/session-state.test.js +73 -0
- package/dist/test/ascii/session-state.test.js.map +1 -0
- package/dist/test/ascii/session.test.d.ts +1 -0
- package/dist/test/ascii/session.test.js +280 -0
- package/dist/test/ascii/session.test.js.map +1 -0
- package/dist/test/ascii/time-formatter.test.d.ts +1 -0
- package/dist/test/ascii/time-formatter.test.js +80 -0
- package/dist/test/ascii/time-formatter.test.js.map +1 -0
- package/dist/test/ascii/view-decode.test.d.ts +1 -0
- package/dist/test/ascii/view-decode.test.js +183 -0
- package/dist/test/ascii/view-decode.test.js.map +1 -0
- package/dist/test/ascii-encoder.test.d.ts +1 -0
- package/dist/test/{ascii-encode.test.js → ascii-encoder.test.js} +140 -48
- package/dist/test/ascii-encoder.test.js.map +1 -0
- package/dist/test/ascii-parser.test.d.ts +1 -1
- package/dist/test/ascii-parser.test.js +31 -48
- package/dist/test/ascii-parser.test.js.map +1 -1
- package/dist/test/ascii-segment.test.d.ts +1 -1
- package/dist/test/ascii-segment.test.js +19 -39
- package/dist/test/ascii-segment.test.js.map +1 -1
- package/dist/test/ascii-store-replay.test.d.ts +1 -1
- package/dist/test/ascii-store-replay.test.js +32 -44
- package/dist/test/ascii-store-replay.test.js.map +1 -1
- package/dist/test/ascii-tag-pos.test.d.ts +1 -1
- package/dist/test/ascii-tag-pos.test.js +8 -8
- package/dist/test/ascii-tag-pos.test.js.map +1 -1
- package/dist/test/elastic-buffer.test.d.ts +1 -1
- package/dist/test/elastic-buffer.test.js +3 -1
- package/dist/test/elastic-buffer.test.js.map +1 -1
- package/dist/test/encode-proxy.test.d.ts +1 -1
- package/dist/test/encode-proxy.test.js +9 -9
- package/dist/test/encode-proxy.test.js.map +1 -1
- package/dist/test/env/experiment.d.ts +23 -0
- package/dist/test/env/experiment.js +33 -0
- package/dist/test/env/experiment.js.map +1 -0
- package/dist/test/env/parsing-result.d.ts +10 -0
- package/dist/test/env/parsing-result.js +14 -0
- package/dist/test/env/parsing-result.js.map +1 -0
- package/dist/test/env/setup.d.ts +39 -0
- package/dist/test/env/setup.js +98 -0
- package/dist/test/env/setup.js.map +1 -0
- package/dist/test/env/skeleton-runner.d.ts +15 -0
- package/dist/test/env/skeleton-runner.js +108 -0
- package/dist/test/env/skeleton-runner.js.map +1 -0
- package/dist/test/env/test-recovery.d.ts +13 -0
- package/dist/test/env/test-recovery.js +41 -0
- package/dist/test/env/test-recovery.js.map +1 -0
- package/dist/test/env/to-views.d.ts +11 -0
- package/dist/test/env/to-views.js +56 -0
- package/dist/test/env/to-views.js.map +1 -0
- package/dist/test/execution-report.test.d.ts +1 -1
- package/dist/test/execution-report.test.js +53 -49
- package/dist/test/execution-report.test.js.map +1 -1
- package/dist/test/experiment.d.ts +23 -0
- package/dist/test/experiment.js +33 -0
- package/dist/test/experiment.js.map +1 -0
- package/dist/test/expieriment.d.ts +23 -0
- package/dist/test/expieriment.js +33 -0
- package/dist/test/expieriment.js.map +1 -0
- package/dist/test/fix-log-replay.test.d.ts +1 -1
- package/dist/test/fix-log-replay.test.js +7 -5
- package/dist/test/fix-log-replay.test.js.map +1 -1
- package/dist/test/fix-repo-dict.test.d.ts +1 -1
- package/dist/test/fix-repo-dict.test.js +6 -5
- package/dist/test/fix-repo-dict.test.js.map +1 -1
- package/dist/test/fixml/fixml-alloc-parse.test.d.ts +1 -0
- package/dist/test/fixml/fixml-alloc-parse.test.js +161 -0
- package/dist/test/fixml/fixml-alloc-parse.test.js.map +1 -0
- package/dist/test/fixml/fixml-mkt-data-fut-parse.test.d.ts +1 -0
- package/dist/test/fixml/fixml-mkt-data-fut-parse.test.js +61 -0
- package/dist/test/fixml/fixml-mkt-data-fut-parse.test.js.map +1 -0
- package/dist/test/fixml/fixml-mkt-data-settle-parse.test.d.ts +1 -0
- package/dist/test/fixml/fixml-mkt-data-settle-parse.test.js +34 -0
- package/dist/test/fixml/fixml-mkt-data-settle-parse.test.js.map +1 -0
- package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.d.ts +1 -0
- package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.js +97 -0
- package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.js.map +1 -0
- package/dist/test/fixml/repo-full-fixml-msg.test.d.ts +1 -0
- package/dist/test/fixml/repo-full-fixml-msg.test.js +143 -0
- package/dist/test/fixml/repo-full-fixml-msg.test.js.map +1 -0
- package/dist/test/fixml-alloc-parse.test.d.ts +1 -1
- package/dist/test/fixml-alloc-parse.test.js +2 -1
- package/dist/test/fixml-alloc-parse.test.js.map +1 -1
- package/dist/test/fixml-mkt-data-fut-parse.test.d.ts +1 -1
- package/dist/test/fixml-mkt-data-fut-parse.test.js +2 -1
- package/dist/test/fixml-mkt-data-fut-parse.test.js.map +1 -1
- package/dist/test/fixml-mkt-data-settle-parse.test.d.ts +1 -1
- package/dist/test/fixml-mkt-data-settle-parse.test.js +2 -1
- package/dist/test/fixml-mkt-data-settle-parse.test.js.map +1 -1
- package/dist/test/fixml-tc-bi-lateral-parse.test.d.ts +1 -1
- package/dist/test/fixml-tc-bi-lateral-parse.test.js +2 -1
- package/dist/test/fixml-tc-bi-lateral-parse.test.js.map +1 -1
- package/dist/test/includes.test.d.ts +1 -1
- package/dist/test/includes.test.js +1 -0
- package/dist/test/includes.test.js.map +1 -1
- package/dist/test/logon.test.d.ts +1 -1
- package/dist/test/logon.test.js +11 -11
- package/dist/test/logon.test.js.map +1 -1
- package/dist/test/memory-store.test.d.ts +1 -1
- package/dist/test/memory-store.test.js +35 -27
- package/dist/test/memory-store.test.js.map +1 -1
- package/dist/test/qf-full-msg.test.d.ts +1 -1
- package/dist/test/qf-full-msg.test.js +25 -19
- package/dist/test/qf-full-msg.test.js.map +1 -1
- package/dist/test/repo-full-ascii-msg.test.d.ts +1 -1
- package/dist/test/repo-full-ascii-msg.test.js +28 -22
- package/dist/test/repo-full-ascii-msg.test.js.map +1 -1
- package/dist/test/repo-full-fixml-msg.test.d.ts +1 -1
- package/dist/test/repo-full-fixml-msg.test.js +21 -18
- package/dist/test/repo-full-fixml-msg.test.js.map +1 -1
- package/dist/test/session-state.test.d.ts +1 -1
- package/dist/test/session-state.test.js +2 -1
- package/dist/test/session-state.test.js.map +1 -1
- package/dist/test/session.test.d.ts +1 -1
- package/dist/test/session.test.js +152 -163
- package/dist/test/session.test.js.map +1 -1
- package/dist/test/setup.d.ts +45 -0
- package/dist/test/setup.js +102 -0
- package/dist/test/setup.js.map +1 -0
- package/dist/test/skeleton-runner.d.ts +15 -0
- package/dist/test/skeleton-runner.js +108 -0
- package/dist/test/skeleton-runner.js.map +1 -0
- package/dist/test/time-formatter.test.d.ts +1 -1
- package/dist/test/time-formatter.test.js +3 -1
- package/dist/test/time-formatter.test.js.map +1 -1
- package/dist/test/to-views.d.ts +1 -1
- package/dist/test/to-views.js +5 -4
- package/dist/test/to-views.js.map +1 -1
- package/dist/test/view-decode.test.d.ts +1 -1
- package/dist/test/view-decode.test.js +9 -33
- package/dist/test/view-decode.test.js.map +1 -1
- package/dist/time-formatter.test.d.ts +0 -0
- package/dist/time-formatter.test.js +1 -0
- package/dist/time-formatter.test.js.map +1 -0
- package/dist/to-views.d.ts +0 -0
- package/dist/to-views.js +1 -0
- package/dist/to-views.js.map +1 -0
- package/dist/token.txt +246 -308
- package/dist/transport/FixEntity.d.ts +8 -0
- package/dist/transport/FixEntity.js +12 -0
- package/dist/transport/FixEntity.js.map +1 -0
- package/dist/transport/a-session-msg-factory.d.ts +23 -0
- package/dist/transport/a-session-msg-factory.js +58 -0
- package/dist/transport/a-session-msg-factory.js.map +1 -0
- package/dist/transport/ascii/ascii-msg-transmitter.js +50 -12
- package/dist/transport/ascii/ascii-msg-transmitter.js.map +1 -1
- package/dist/transport/ascii/ascii-session-msg-factory.d.ts +16 -0
- package/dist/transport/ascii/ascii-session-msg-factory.js +47 -0
- package/dist/transport/ascii/ascii-session-msg-factory.js.map +1 -0
- package/dist/transport/ascii/ascii-session.d.ts +10 -1
- package/dist/transport/ascii/ascii-session.js +98 -41
- package/dist/transport/ascii/ascii-session.js.map +1 -1
- package/dist/transport/ascii/index.d.ts +1 -1
- package/dist/transport/ascii/index.js +1 -1
- package/dist/transport/ascii/index.js.map +1 -1
- package/dist/transport/duplex/http-duplex.d.ts +1 -1
- package/dist/transport/duplex/http-duplex.js +2 -2
- package/dist/transport/duplex/http-duplex.js.map +1 -1
- package/dist/transport/duplex/tcp-duplex.js +22 -2
- package/dist/transport/duplex/tcp-duplex.js.map +1 -1
- package/dist/transport/factory/index.d.ts +1 -0
- package/dist/{sample/tcp/trade_capture → transport/factory}/index.js +1 -2
- package/dist/transport/factory/index.js.map +1 -0
- package/dist/transport/{msg-transport.d.ts → factory/msg-transport.d.ts} +4 -4
- package/dist/transport/factory/msg-transport.js +61 -0
- package/dist/transport/factory/msg-transport.js.map +1 -0
- package/dist/transport/fix-acceptor.d.ts +2 -2
- package/dist/transport/fix-acceptor.js.map +1 -1
- package/dist/transport/fix-entity.d.ts +8 -0
- package/dist/transport/fix-entity.js +12 -0
- package/dist/transport/fix-entity.js.map +1 -0
- package/dist/transport/fix-initiator.d.ts +2 -2
- package/dist/transport/fix-initiator.js.map +1 -1
- package/dist/transport/fix-msg-factory.d.ts +1 -1
- package/dist/transport/fix-msg-factory.js.map +1 -1
- package/dist/transport/fix-session-state-args.d.ts +8 -0
- package/dist/transport/fix-session-state-args.js +3 -0
- package/dist/transport/fix-session-state-args.js.map +1 -0
- package/dist/transport/fix-session-state.d.ts +8 -38
- package/dist/transport/fix-session-state.js +26 -56
- package/dist/transport/fix-session-state.js.map +1 -1
- package/dist/transport/fix-session.d.ts +9 -2
- package/dist/transport/fix-session.js +115 -59
- package/dist/transport/fix-session.js.map +1 -1
- package/dist/transport/fixml/fixml-msg-transmitter.js +23 -5
- package/dist/transport/fixml/fixml-msg-transmitter.js.map +1 -1
- package/dist/transport/fixml/fixml-session-msg-factory.d.ts +13 -0
- package/dist/transport/fixml/fixml-session-msg-factory.js +68 -0
- package/dist/transport/fixml/fixml-session-msg-factory.js.map +1 -0
- package/dist/transport/fixml/fixml-session.d.ts +1 -1
- package/dist/transport/fixml/fixml-session.js +3 -3
- package/dist/transport/fixml/fixml-session.js.map +1 -1
- package/dist/transport/fixml/index.d.ts +1 -2
- package/dist/transport/fixml/index.js +1 -2
- package/dist/transport/fixml/index.js.map +1 -1
- package/dist/transport/http/html-options.d.ts +8 -0
- package/dist/{hop_no_hops.js → transport/http/html-options.js} +1 -1
- package/dist/transport/http/html-options.js.map +1 -0
- package/dist/transport/http/html-route.d.ts +5 -0
- package/dist/{hop.js → transport/http/html-route.js} +1 -1
- package/dist/transport/http/html-route.js.map +1 -0
- package/dist/transport/http/http-acceptor-listener.d.ts +7 -0
- package/dist/transport/http/http-acceptor-listener.js +68 -0
- package/dist/transport/http/http-acceptor-listener.js.map +1 -0
- package/dist/transport/http/http-acceptor.js +31 -11
- package/dist/transport/http/http-acceptor.js.map +1 -1
- package/dist/transport/http/http-adapter.d.ts +7 -0
- package/dist/{trailer.js → transport/http/http-adapter.js} +1 -1
- package/dist/transport/http/http-adapter.js.map +1 -0
- package/dist/transport/http/http-initiator.d.ts +9 -3
- package/dist/transport/http/http-initiator.js +57 -26
- package/dist/transport/http/http-initiator.js.map +1 -1
- package/dist/transport/http/http-json-sample-adapter.d.ts +2 -1
- package/dist/transport/http/http-json-sample-adapter.js +21 -2
- package/dist/transport/http/http-json-sample-adapter.js.map +1 -1
- package/dist/transport/http/http-transaction.d.ts +1 -1
- package/dist/transport/http/http-transaction.js.map +1 -1
- package/dist/transport/http/http-transport-description.d.ts +8 -0
- package/dist/transport/http/http-transport-description.js +3 -0
- package/dist/transport/http/http-transport-description.js.map +1 -0
- package/dist/transport/http/index.d.ts +1 -0
- package/dist/transport/http/index.js +1 -0
- package/dist/transport/http/index.js.map +1 -1
- package/dist/transport/index.d.ts +11 -10
- package/dist/transport/index.js +11 -10
- package/dist/transport/index.js.map +1 -1
- package/dist/transport/{make-fixl-session.d.ts → make-fix-session.d.ts} +0 -0
- package/dist/transport/make-fix-session.js +3 -0
- package/dist/transport/make-fix-session.js.map +1 -0
- package/dist/transport/msg-application.d.ts +12 -0
- package/dist/transport/msg-application.js +3 -0
- package/dist/transport/msg-application.js.map +1 -0
- package/dist/transport/msg-transmitter.d.ts +5 -5
- package/dist/transport/msg-transmitter.js +2 -3
- package/dist/transport/msg-transmitter.js.map +1 -1
- package/dist/transport/session/a-session-msg-factory.d.ts +23 -0
- package/dist/transport/session/a-session-msg-factory.js +58 -0
- package/dist/transport/session/a-session-msg-factory.js.map +1 -0
- package/dist/transport/session/fix-session-state-args.d.ts +8 -0
- package/dist/transport/session/fix-session-state-args.js +3 -0
- package/dist/transport/session/fix-session-state-args.js.map +1 -0
- package/dist/transport/session/fix-session-state.d.ts +32 -0
- package/dist/transport/session/fix-session-state.js +133 -0
- package/dist/transport/session/fix-session-state.js.map +1 -0
- package/dist/transport/session/fix-session.d.ts +50 -0
- package/dist/transport/session/fix-session.js +291 -0
- package/dist/transport/session/fix-session.js.map +1 -0
- package/dist/transport/session/make-fix-session.d.ts +5 -0
- package/dist/transport/session/make-fix-session.js +3 -0
- package/dist/transport/session/make-fix-session.js.map +1 -0
- package/dist/transport/session/session-description.d.ts +17 -0
- package/dist/transport/session/session-description.js +3 -0
- package/dist/transport/session/session-description.js.map +1 -0
- package/dist/transport/session/session-msg-factory.d.ts +15 -0
- package/dist/transport/session/session-msg-factory.js +3 -0
- package/dist/transport/session/session-msg-factory.js.map +1 -0
- package/dist/transport/session/session-state.d.ts +25 -0
- package/dist/transport/session/session-state.js +30 -0
- package/dist/transport/session/session-state.js.map +1 -0
- package/dist/transport/session-description.d.ts +1 -48
- package/dist/transport/session-description.js.map +1 -1
- package/dist/transport/session-msg-factory.d.ts +7 -20
- package/dist/transport/session-msg-factory.js +0 -150
- package/dist/transport/session-msg-factory.js.map +1 -1
- package/dist/transport/session-state.d.ts +25 -0
- package/dist/transport/session-state.js +30 -0
- package/dist/transport/session-state.js.map +1 -0
- package/dist/transport/tcp/index.d.ts +3 -2
- package/dist/transport/tcp/index.js +3 -2
- package/dist/transport/tcp/index.js.map +1 -1
- package/dist/transport/tcp/recovering-tcp-initiator.d.ts +7 -9
- package/dist/transport/tcp/recovering-tcp-initiator.js +41 -16
- package/dist/transport/tcp/recovering-tcp-initiator.js.map +1 -1
- package/dist/transport/tcp/tcp-acceptor-listener.d.ts +7 -0
- package/dist/transport/tcp/tcp-acceptor-listener.js +70 -0
- package/dist/transport/tcp/tcp-acceptor-listener.js.map +1 -0
- package/dist/transport/tcp/tcp-acceptor.d.ts +7 -0
- package/dist/transport/tcp/tcp-acceptor.js +79 -43
- package/dist/transport/tcp/tcp-acceptor.js.map +1 -1
- package/dist/transport/tcp/tcp-initiator-connector.d.ts +10 -0
- package/dist/transport/tcp/tcp-initiator-connector.js +97 -0
- package/dist/transport/tcp/tcp-initiator-connector.js.map +1 -0
- package/dist/transport/tcp/tcp-initiator.d.ts +4 -2
- package/dist/transport/tcp/tcp-initiator.js +82 -36
- package/dist/transport/tcp/tcp-initiator.js.map +1 -1
- package/dist/transport/tcp/tcp-transport-description.d.ts +6 -0
- package/dist/transport/tcp/tcp-transport-description.js +3 -0
- package/dist/transport/tcp/tcp-transport-description.js.map +1 -0
- package/dist/transport/tcp/tls-options-factory.d.ts +9 -0
- package/dist/transport/tcp/tls-options-factory.js +53 -0
- package/dist/transport/tcp/tls-options-factory.js.map +1 -0
- package/dist/transport/tcp/tls-options.d.ts +10 -5
- package/dist/transport/tcp/tls-options.js +0 -49
- package/dist/transport/tcp/tls-options.js.map +1 -1
- package/dist/transport/tick-action.d.ts +8 -0
- package/dist/transport/tick-action.js +13 -0
- package/dist/transport/tick-action.js.map +1 -0
- package/dist/types/FIX4.4/repo/enum/all-enum.js.map +1 -1
- package/dist/util/buffer-helper.js +1 -1
- package/dist/util/buffer-helper.js.map +1 -1
- package/dist/util/definition-factory.d.ts +10 -0
- package/dist/util/definition-factory.js +56 -0
- package/dist/util/definition-factory.js.map +1 -0
- package/dist/util/dictionary-path.d.ts +4 -0
- package/dist/util/dictionary-path.js +3 -0
- package/dist/util/dictionary-path.js.map +1 -0
- package/dist/util/index.d.ts +1 -1
- package/dist/util/index.js +1 -1
- package/dist/util/index.js.map +1 -1
- package/dist/util/json-helper.d.ts +3 -1
- package/dist/util/json-helper.js +13 -12
- package/dist/util/json-helper.js.map +1 -1
- package/dist/util/message-generator.d.ts +1 -1
- package/dist/util/message-generator.js +16 -15
- package/dist/util/message-generator.js.map +1 -1
- package/dist/util/replay.d.ts +6 -3
- package/dist/util/replay.js +24 -26
- package/dist/util/replay.js.map +1 -1
- package/package.json +27 -20
- package/script/build.cmd +1 -0
- package/script/build.sh +2 -0
- package/script/genkey.ps1 +179 -179
- package/script/test.cmd +3 -0
- package/src/buffer/{ascii-chars.ts → ascii/ascii-chars.ts} +0 -0
- package/src/buffer/ascii/ascii-encoder.ts +80 -38
- package/src/buffer/ascii/ascii-parser-state.ts +7 -12
- package/src/buffer/ascii/ascii-parser.ts +23 -16
- package/src/buffer/ascii/ascii-segment-parser.ts +14 -8
- package/src/buffer/ascii/ascii-view.ts +4 -9
- package/src/buffer/ascii/index.ts +1 -0
- package/src/buffer/ascii/parse-state.ts +8 -0
- package/src/buffer/ascii/time-formatter.ts +3 -3
- package/src/buffer/elastic-buffer.ts +7 -2
- package/src/buffer/encode-proxy.ts +10 -5
- package/src/buffer/fixml/fixml-encoder.ts +15 -11
- package/src/buffer/fixml/fixml-parser.ts +16 -6
- package/src/buffer/fixml/fixml-view.ts +4 -4
- package/src/buffer/fixml/populated-attributes.ts +6 -0
- package/src/buffer/index.ts +4 -8
- package/src/buffer/msg-encoder.ts +2 -1
- package/src/buffer/msg-view.ts +13 -6
- package/src/buffer/{segment-description.ts → segment/segment-description.ts} +4 -11
- package/src/buffer/{segment-summary.ts → segment/segment-summary.ts} +0 -0
- package/src/buffer/segment/segment-type.ts +8 -0
- package/src/buffer/structure.ts +3 -3
- package/src/buffer/{tag-pos.ts → tag/tag-pos.ts} +0 -0
- package/src/buffer/tag/tag-type.ts +13 -0
- package/src/buffer/{tags.ts → tag/tags.ts} +4 -16
- package/src/config/get-js-fx-logger.ts +4 -0
- package/src/config/index.ts +1 -0
- package/src/config/js-fix-config.ts +5 -2
- package/src/config/js-fix-logger.ts +0 -3
- package/src/dictionary/compiler/compiler-type.ts +3 -3
- package/src/dictionary/compiler/enum-compiler.ts +12 -1
- package/src/dictionary/compiler/msg-compiler.ts +8 -7
- package/src/dictionary/contained/contained-component-field.ts +2 -1
- package/src/dictionary/contained/contained-field-dispatch.ts +3 -7
- package/src/dictionary/contained/contained-field-dispatcher.ts +9 -0
- package/src/dictionary/contained/contained-field-set.ts +5 -3
- package/src/dictionary/contained/contained-field-type.ts +5 -0
- package/src/dictionary/contained/contained-field.ts +1 -6
- package/src/dictionary/contained/contained-group-field.ts +2 -1
- package/src/dictionary/contained/contained-simple-field.ts +2 -1
- package/src/dictionary/contained/field-dispatcher.ts +9 -0
- package/src/dictionary/contained/fields-dispatch.ts +46 -0
- package/src/dictionary/contained/index.ts +2 -0
- package/src/dictionary/contained-set-type.ts +5 -0
- package/src/dictionary/definition/component-field-definition.ts +1 -1
- package/src/dictionary/definition/fix-definitions.ts +2 -1
- package/src/dictionary/definition/group-field-definition.ts +1 -1
- package/src/dictionary/definition/index.ts +0 -1
- package/src/dictionary/definition/message-definition.ts +1 -1
- package/src/dictionary/definition/simple-field-definition.ts +3 -1
- package/src/dictionary/dict-primitive.ts +0 -13
- package/src/dictionary/fix-definition-source.ts +6 -0
- package/src/dictionary/fix-versions.ts +0 -32
- package/src/dictionary/index.ts +1 -5
- package/src/dictionary/parser/fix-repository/abbreviations-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/base-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/components-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/data-types-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/enums-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/fields-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/messages-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/msg-contents-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/repository-abbreviation.ts +6 -0
- package/src/dictionary/parser/fix-repository/repository-component.ts +11 -0
- package/src/dictionary/parser/fix-repository/repository-data-type.ts +7 -0
- package/src/dictionary/parser/fix-repository/repository-enum.ts +8 -0
- package/src/dictionary/parser/fix-repository/repository-field.ts +12 -0
- package/src/dictionary/parser/fix-repository/repository-message.ts +12 -0
- package/src/dictionary/parser/fix-repository/repository-msg-content.ts +10 -0
- package/src/dictionary/parser/fix-repository/repository-type.ts +0 -59
- package/src/dictionary/parser/fix-repository/repository-xml-parser.ts +10 -9
- package/src/dictionary/parser/fix-repository/repository.ts +69 -38
- package/src/dictionary/parser/fixml/components-parser.ts +6 -3
- package/src/dictionary/parser/fixml/fields-parser.ts +1 -1
- package/src/dictionary/parser/fixml/fix-xsd-parser.ts +2 -1
- package/src/dictionary/parser/fixml/include-graph.ts +2 -1
- package/src/dictionary/parser/fixml/xsd-parser.ts +2 -1
- package/src/dictionary/parser/quickfix/field-definition-parser.ts +4 -5
- package/src/dictionary/parser/quickfix/field-set-parser.ts +4 -5
- package/src/dictionary/parser/quickfix/message-parser.ts +4 -5
- package/src/dictionary/parser/quickfix/node-parser.ts +3 -6
- package/src/dictionary/parser/quickfix/parse-state.ts +8 -0
- package/src/dictionary/parser/quickfix/quick-fix-xml-file-parser.ts +9 -15
- package/src/dictionary/sax-node.ts +7 -0
- package/src/dictionary/set-reduce.ts +30 -31
- package/src/dictionary/type-dispatcher.ts +7 -0
- package/src/dictionary/version-util.ts +25 -0
- package/src/index.ts +1 -0
- package/src/jsfix-cmd.ts +31 -16
- package/src/runtime/di-tokens.ts +48 -0
- package/src/runtime/engine-factory.ts +5 -0
- package/src/runtime/index.ts +5 -0
- package/src/runtime/make-config.ts +35 -0
- package/src/runtime/session-container.ts +180 -0
- package/src/runtime/session-launcher.ts +127 -0
- package/src/sample/http/oms/app.ts +20 -12
- package/src/sample/http/oms/http-client.ts +5 -2
- package/src/sample/http/oms/http-server.ts +5 -1
- package/src/sample/tcp/qf-md/app.ts +12 -12
- package/src/sample/tcp/qf-md/md-client.ts +4 -1
- package/src/sample/tcp/qf-md/md-server.ts +3 -1
- package/src/sample/tcp/recovering-skeleton/app.ts +37 -15
- package/src/sample/tcp/recovering-skeleton/respawn-acceptor.ts +16 -9
- package/src/sample/tcp/recovering-skeleton/skeleton-client.ts +4 -2
- package/src/sample/tcp/recovering-skeleton/skeleton-server.ts +4 -2
- package/src/sample/tcp/skeleton/app.ts +10 -15
- package/src/sample/tcp/skeleton/skeleton-session.ts +29 -3
- package/src/sample/tcp/tls-trade-capture/app.ts +8 -31
- package/src/sample/tcp/trade-capture/app-launcher.ts +22 -0
- package/src/sample/tcp/trade-capture/app.ts +3 -26
- package/src/sample/tcp/trade-capture/trade-capture-client.ts +10 -4
- package/src/sample/tcp/trade-capture/trade-capture-server.ts +2 -1
- package/src/sample/tcp/trade-capture/trade-factory.ts +7 -1
- package/src/store/fix-msg-ascii-store-resend.ts +38 -26
- package/src/store/fix-msg-memory-store.ts +105 -42
- package/src/store/fix-msg-store-record.ts +11 -0
- package/src/store/fix-msg-store-state.ts +6 -0
- package/src/store/fix-msg-store.ts +8 -13
- package/src/transport/ascii/ascii-msg-transmitter.ts +23 -13
- package/src/transport/ascii/ascii-session-msg-factory.ts +62 -0
- package/src/transport/ascii/ascii-session.ts +102 -34
- package/src/transport/ascii/index.ts +1 -1
- package/src/transport/duplex/http-duplex.ts +3 -3
- package/src/transport/duplex/tcp-duplex.ts +4 -1
- package/src/transport/factory/index.ts +1 -0
- package/src/transport/factory/msg-transport.ts +55 -0
- package/src/transport/fix-acceptor.ts +2 -2
- package/src/transport/fix-entity.ts +9 -0
- package/src/transport/fix-initiator.ts +2 -2
- package/src/transport/fixml/fixml-msg-transmitter.ts +8 -4
- package/src/transport/fixml/fixml-session-msg-factory.ts +76 -0
- package/src/transport/fixml/fixml-session.ts +2 -2
- package/src/transport/fixml/index.ts +1 -2
- package/src/transport/http/html-options.ts +8 -0
- package/src/transport/http/html-route.ts +6 -0
- package/src/transport/http/http-acceptor-listener.ts +42 -0
- package/src/transport/http/http-acceptor.ts +12 -8
- package/src/transport/http/http-adapter.ts +7 -0
- package/src/transport/http/http-initiator.ts +40 -25
- package/src/transport/http/http-json-sample-adapter.ts +7 -2
- package/src/transport/http/http-transaction.ts +1 -1
- package/src/transport/http/http-transport-description.ts +9 -0
- package/src/transport/http/index.ts +1 -0
- package/src/transport/index.ts +11 -10
- package/src/transport/msg-application.ts +13 -0
- package/src/transport/msg-transmitter.ts +5 -5
- package/src/transport/session/a-session-msg-factory.ts +81 -0
- package/src/transport/session/fix-session-state-args.ts +9 -0
- package/src/transport/{fix-session-state.ts → session/fix-session-state.ts} +23 -43
- package/src/transport/{fix-session.ts → session/fix-session.ts} +111 -46
- package/src/transport/{make-fixl-session.ts → session/make-fix-session.ts} +1 -1
- package/src/transport/session/session-description.ts +18 -0
- package/src/transport/{fix-msg-factory.ts → session/session-msg-factory.ts} +2 -2
- package/src/transport/session/session-state.ts +25 -0
- package/src/transport/tcp/index.ts +3 -2
- package/src/transport/tcp/recovering-tcp-initiator.ts +24 -13
- package/src/transport/tcp/tcp-acceptor-listener.ts +45 -0
- package/src/transport/tcp/tcp-acceptor.ts +65 -40
- package/src/transport/tcp/tcp-initiator-connector.ts +71 -0
- package/src/transport/tcp/tcp-initiator.ts +71 -42
- package/src/transport/tcp/tcp-transport-description.ts +7 -0
- package/src/transport/tcp/tls-options-factory.ts +55 -0
- package/src/transport/tcp/tls-options.ts +9 -51
- package/src/transport/tick-action.ts +8 -0
- package/src/types/FIX4.4/repo/enum/all-enum.ts +0 -1
- package/src/util/definition-factory.ts +47 -0
- package/src/util/dictionary-path.ts +4 -0
- package/src/util/index.ts +1 -1
- package/src/util/json-helper.ts +14 -4
- package/src/util/message-generator.ts +6 -3
- package/src/util/replay.ts +26 -21
- package/tsconfig.json +2 -0
- package/dist/buffer/ascii-chars.js.map +0 -1
- package/dist/dictionary/fields-dispatch.js +0 -40
- package/dist/dictionary/fields-dispatch.js.map +0 -1
- package/dist/header.d.ts +0 -31
- package/dist/header.js.map +0 -1
- package/dist/hop.d.ts +0 -4
- package/dist/hop.js.map +0 -1
- package/dist/hop_no_hops.d.ts +0 -5
- package/dist/hop_no_hops.js.map +0 -1
- package/dist/sample/http/oms/jsfix.test_http-client.txt +0 -170
- package/dist/sample/http/oms/jsfix.test_http-server.txt +0 -170
- package/dist/sample/tcp/qf-md/jsfix.test_client.txt +0 -18
- package/dist/sample/tcp/qf-md/jsfix.test_server.txt +0 -17
- package/dist/sample/tcp/recovering-skeleton/jsfix.test_client.txt +0 -96
- package/dist/sample/tcp/recovering-skeleton/jsfix.test_server.txt +0 -93
- package/dist/sample/tcp/recovering-skeleton/skeleton-session.d.ts +0 -17
- package/dist/sample/tcp/recovering-skeleton/skeleton-session.js +0 -70
- package/dist/sample/tcp/recovering-skeleton/skeleton-session.js.map +0 -1
- package/dist/sample/tcp/skeleton/jsfix.test_client.txt +0 -6
- package/dist/sample/tcp/skeleton/jsfix.test_server.txt +0 -6
- package/dist/sample/tcp/tls-trade-capture/jsfix.test_client.txt +0 -1871
- package/dist/sample/tcp/tls-trade-capture/jsfix.test_server.txt +0 -3059
- package/dist/sample/tcp/trade_capture/app.d.ts +0 -1
- package/dist/sample/tcp/trade_capture/app.js +0 -24
- package/dist/sample/tcp/trade_capture/app.js.map +0 -1
- package/dist/sample/tcp/trade_capture/index.d.ts +0 -2
- package/dist/sample/tcp/trade_capture/index.js.map +0 -1
- package/dist/sample/tcp/trade_capture/jsfix.test_client.txt +0 -193
- package/dist/sample/tcp/trade_capture/jsfix.test_server.txt +0 -193
- package/dist/sample/tcp/trade_capture/trade-capture-client.d.ts +0 -16
- package/dist/sample/tcp/trade_capture/trade-capture-client.js +0 -57
- package/dist/sample/tcp/trade_capture/trade-capture-client.js.map +0 -1
- package/dist/sample/tcp/trade_capture/trade-capture-server.d.ts +0 -18
- package/dist/sample/tcp/trade_capture/trade-capture-server.js +0 -72
- package/dist/sample/tcp/trade_capture/trade-capture-server.js.map +0 -1
- package/dist/sample/tcp/trade_capture/trade-factory.d.ts +0 -11
- package/dist/sample/tcp/trade_capture/trade-factory.js +0 -81
- package/dist/sample/tcp/trade_capture/trade-factory.js.map +0 -1
- package/dist/standard_header.d.ts +0 -31
- package/dist/standard_header.js.map +0 -1
- package/dist/standard_trailer.d.ts +0 -6
- package/dist/standard_trailer.js +0 -3
- package/dist/standard_trailer.js.map +0 -1
- package/dist/store/fix-msg-ascii-store-recovery.d.ts +0 -12
- package/dist/store/fix-msg-ascii-store-recovery.js +0 -60
- package/dist/store/fix-msg-ascii-store-recovery.js.map +0 -1
- package/dist/store/fix-resend-record.d.ts +0 -12
- package/dist/store/fix-resend-record.js +0 -12
- package/dist/store/fix-resend-record.js.map +0 -1
- package/dist/test/ascii-encode.test.d.ts +0 -1
- package/dist/test/ascii-encode.test.js.map +0 -1
- package/dist/test/ascii-store-recovery.test.d.ts +0 -1
- package/dist/test/ascii-store-recovery.test.js +0 -50
- package/dist/test/ascii-store-recovery.test.js.map +0 -1
- package/dist/test/memory-store-test.d.ts +0 -1
- package/dist/test/memory-store-test.js.map +0 -1
- package/dist/trailer.d.ts +0 -6
- package/dist/trailer.js.map +0 -1
- package/dist/transport/fixml/acceptor.d.ts +0 -3
- package/dist/transport/fixml/acceptor.js +0 -38
- package/dist/transport/fixml/acceptor.js.map +0 -1
- package/dist/transport/make-config.d.ts +0 -4
- package/dist/transport/make-config.js +0 -31
- package/dist/transport/make-config.js.map +0 -1
- package/dist/transport/make-fixl-session.js +0 -3
- package/dist/transport/make-fixl-session.js.map +0 -1
- package/dist/transport/msg-store.d.ts +0 -2
- package/dist/transport/msg-store.js +0 -3
- package/dist/transport/msg-store.js.map +0 -1
- package/dist/transport/msg-transport.js +0 -57
- package/dist/transport/msg-transport.js.map +0 -1
- package/dist/transport/tcp/acceptor.d.ts +0 -3
- package/dist/transport/tcp/acceptor.js +0 -40
- package/dist/transport/tcp/acceptor.js.map +0 -1
- package/dist/transport/tcp/initiator.d.ts +0 -3
- package/dist/transport/tcp/initiator.js +0 -67
- package/dist/transport/tcp/initiator.js.map +0 -1
- package/dist/transport/tcp/recovering-initiator.d.ts +0 -17
- package/dist/transport/tcp/recovering-initiator.js +0 -30
- package/dist/transport/tcp/recovering-initiator.js.map +0 -1
- package/dist/transport/tcp/recovering_initiator.d.ts +0 -12
- package/dist/transport/tcp/recovering_initiator.js +0 -25
- package/dist/transport/tcp/recovering_initiator.js.map +0 -1
- package/dist/types/FIX4.4/quickfix/set/header.d.ts +0 -31
- package/dist/types/FIX4.4/quickfix/set/header.js +0 -3
- package/dist/types/FIX4.4/quickfix/set/header.js.map +0 -1
- package/dist/types/FIX4.4/quickfix/set/trailer.d.ts +0 -6
- package/dist/types/FIX4.4/quickfix/set/trailer.js +0 -3
- package/dist/types/FIX4.4/quickfix/set/trailer.js.map +0 -1
- package/dist/util/dictionary-definitions.d.ts +0 -8
- package/dist/util/dictionary-definitions.js +0 -51
- package/dist/util/dictionary-definitions.js.map +0 -1
- package/src/dictionary/fields-dispatch.ts +0 -45
- package/src/sample/launcher.ts +0 -46
- package/src/transport/fixml/acceptor.ts +0 -29
- package/src/transport/make-config.ts +0 -19
- package/src/transport/msg-transport.ts +0 -67
- package/src/transport/session-description.ts +0 -70
- package/src/transport/session-msg-factory.ts +0 -195
- package/src/transport/tcp/acceptor.ts +0 -31
- package/src/transport/tcp/initiator.ts +0 -59
- package/src/util/dictionary-definitions.ts +0 -41
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"encode-proxy.test.js","sourceRoot":"","sources":["../../src/test/encode-proxy.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path'\r\nimport { EncodeProxy, AsciiChars } from '../buffer'\r\nimport { FixDefinitions } from '../dictionary'\r\nimport { ILooseObject } from '../collections/collection'\r\nimport { ISessionDescription, AsciiMsgTransmitter } from '../transport'\r\nimport { JsFixConfig } from '../config'\r\nimport { getDefinitions } from '../util'\r\nconst root: string = path.join(__dirname, '../../data')\r\n\r\nlet definitions: FixDefinitions\r\nlet session: AsciiMsgTransmitter\r\nlet proxyFactory: EncodeProxy\r\n\r\nbeforeAll(async () => {\r\n const sessionDescription: ISessionDescription = require(path.join(root, 'session/qf-fix44.json'))\r\n definitions = await getDefinitions(sessionDescription.application.dictionary)\r\n const config = new JsFixConfig(null, definitions, sessionDescription, AsciiChars.Pipe)\r\n session = new AsciiMsgTransmitter(config)\r\n proxyFactory = new EncodeProxy(definitions)\r\n}, 45000)\r\n\r\ntest('check wrapper will reject unknown field', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.Unknown = 999\r\n }\r\n expect(run).toThrow(/no field named Unknown/)\r\n})\r\n\r\ntest('check wrapper will accept known field', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.OrderID = 'ipsum'\r\n }\r\n run()\r\n expect(proxy.OrderID).toEqual('ipsum')\r\n})\r\n\r\ntest('check wrapper rejects unknown enum value', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.SettlType = '23'\r\n }\r\n expect(run).toThrow(/enum field SettlType does not support \"23\"/)\r\n})\r\n\r\ntest('check wrapper will accept known enum field', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.SettlType = '1'\r\n }\r\n run()\r\n expect(proxy.SettlType).toEqual('1')\r\n})\r\n\r\ntest('check wrapper rejects Date field when not given Date', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.SettlDate = \"I'm not a good date\"\r\n }\r\n expect(run).toThrow(/expects Date but receives/)\r\n})\r\n\r\ntest('check wrapper will accept Date field when given Date', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.SettlDate = new Date()\r\n }\r\n run()\r\n expect(proxy.SettlDate).toBeTruthy()\r\n})\r\n\r\ntest('check wrapper rejects boolean field when not given boolean', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.LastRptRequested = \"I'm not a good boolean\"\r\n }\r\n expect(run).toThrow(/expects boolean but receives/)\r\n})\r\n\r\ntest('check wrapper will accept boolean field when given boolean', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.LastRptRequested = true\r\n }\r\n run()\r\n expect(proxy.LastRptRequested).toEqual(true)\r\n})\r\n\r\ntest('check wrapper rejects Buffer field when not given Buffer', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.EncodedText = \"I'm not a Buffer, don't accept me!\"\r\n }\r\n expect(run).toThrow(/expects Buffer but receives/)\r\n})\r\n\r\ntest('check wrapper will accept Buffer field when given Buffer', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.EncodedText = new Buffer('I am a buffer.', 'utf8')\r\n }\r\n run()\r\n expect(proxy.EncodedText).toBeTruthy()\r\n})\r\n\r\ntest('check wrapper rejects string field when not given string', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.ClOrdID = 123\r\n }\r\n expect(run).toThrow(/expects string but receives/)\r\n})\r\n\r\ntest('check wrapper will accept string field when given string', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.ClOrdID = \"I'm a great string\"\r\n }\r\n run()\r\n expect(proxy.ClOrdID).toEqual(\"I'm a great string\")\r\n})\r\n\r\ntest('check wrapper rejects number field when not given number', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.GrossTradeAmt = \"I'm no number\"\r\n }\r\n expect(run).toThrow(/expects number but receives/)\r\n})\r\n\r\ntest('check wrapper will accept number field when given number', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.GrossTradeAmt = 12234\r\n }\r\n run()\r\n expect(proxy.GrossTradeAmt).toEqual(12234)\r\n})\r\n\r\ntest('check wrapper rejects non object field when assigning component', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.Parties = 'I should be an object, but I am sadly not'\r\n }\r\n expect(run).toThrow(/is a component but/)\r\n})\r\n\r\ntest('check wrapper accepts object field when assigning component', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.Parties = {\r\n }\r\n }\r\n run()\r\n expect(proxy.Parties).toBeTruthy()\r\n})\r\n\r\ntest('check wrapper when assigned component wraps so it can be checked.', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.YieldData = {\r\n }\r\n }\r\n run()\r\n function run2 (): void {\r\n proxy.YieldData.GrossTradeAmt = 999\r\n }\r\n // reject this\r\n expect(run2).toThrow(/no field named GrossTradeAmt/)\r\n proxy.YieldData.YieldCalcDate = new Date()\r\n // accept this\r\n expect(proxy.YieldData).toBeTruthy()\r\n})\r\n\r\ntest('check wrapper when given populated component.', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.YieldData = {\r\n ClOrdID: \"I don't belong here.\"\r\n }\r\n }\r\n // reject this\r\n expect(run).toThrow(/no field named ClOrdID/)\r\n})\r\n\r\ntest('check wrapper accepts number for group field and wraps n elements', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.Parties = {\r\n NoPartyIDs: 2\r\n }\r\n }\r\n run()\r\n expect(proxy.Parties).toBeTruthy()\r\n expect(Array.isArray(proxy.Parties.NoPartyIDs)).toEqual(true)\r\n expect(proxy.Parties.NoPartyIDs.length).toEqual(2)\r\n // now assign a field, this should also be wrapped\r\n proxy.Parties.NoPartyIDs[0].PartyID = 'hello'\r\n expect(proxy.Parties.NoPartyIDs[0].PartyID).toBeTruthy()\r\n function run2 (): void {\r\n proxy.Parties.NoPartyIDs[0].GrossTradeAmt = 999\r\n }\r\n // reject this\r\n expect(run2).toThrow(/no field named GrossTradeAmt/)\r\n})\r\n\r\ntest('check wrapper accepts array of objects in group component', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.Parties = {\r\n NoPartyIDs: getParties()\r\n }\r\n }\r\n run()\r\n function run2 (): void {\r\n proxy.Parties.NoPartyIDs[0].GrossTradeAmt = 999\r\n }\r\n // reject this\r\n expect(run2).toThrow(/no field named GrossTradeAmt/)\r\n})\r\n\r\nfunction getParties (): ILooseObject {\r\n return [\r\n {\r\n 'PartyID': 'magna.',\r\n 'PartyIDSource': '9',\r\n 'PartyRole': 28,\r\n 'PtysSubGrp': {\r\n 'NoPartySubIDs': [\r\n {\r\n 'PartySubID': 'et',\r\n 'PartySubIDType': 22\r\n },\r\n {\r\n 'PartySubID': 'leo,',\r\n 'PartySubIDType': 10\r\n }\r\n ]\r\n }\r\n },\r\n {\r\n 'PartyID': 'iaculis',\r\n 'PartyIDSource': 'F',\r\n 'PartyRole': 2,\r\n 'PtysSubGrp': {\r\n 'NoPartySubIDs': [\r\n {\r\n 'PartySubID': 'Nullam',\r\n 'PartySubIDType': 12\r\n },\r\n {\r\n 'PartySubID': 'lectus,',\r\n 'PartySubIDType': 13\r\n },\r\n {\r\n 'PartySubID': 'eget',\r\n 'PartySubIDType': 18\r\n }\r\n ]\r\n }\r\n },\r\n {\r\n 'PartyID': 'vitae,',\r\n 'PartyIDSource': '9',\r\n 'PartyRole': 5,\r\n 'PtysSubGrp': {\r\n 'NoPartySubIDs': [\r\n {\r\n 'PartySubID': 'ac',\r\n 'PartySubIDType': 6\r\n }\r\n ]\r\n }\r\n }\r\n ]\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"file":"encode-proxy.test.js","sourceRoot":"","sources":["../../src/test/encode-proxy.test.ts"],"names":[],"mappings":"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","sourcesContent":["import 'reflect-metadata'\r\n\r\nimport { EncodeProxy } from '../buffer'\r\nimport { FixDefinitions } from '../dictionary/definition'\r\nimport { ILooseObject } from '../collections/collection'\r\nimport { AsciiMsgTransmitter } from '../transport/ascii/ascii-msg-transmitter'\r\nimport { Setup } from './env/setup'\r\n\r\nlet definitions: FixDefinitions\r\nlet session: AsciiMsgTransmitter\r\nlet proxyFactory: EncodeProxy\r\nlet setup: Setup = null\r\n\r\nbeforeAll(async () => {\r\n setup = new Setup('session/qf-fix44.json', 'session/qf-fix44.json')\r\n await setup.init()\r\n definitions = setup.definitions\r\n const config = setup.clientConfig\r\n session = new AsciiMsgTransmitter(config)\r\n proxyFactory = new EncodeProxy(definitions)\r\n}, 45000)\r\n\r\ntest('check wrapper will reject unknown field', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.Unknown = 999\r\n }\r\n expect(run).toThrow(/no field named Unknown/)\r\n})\r\n\r\ntest('check wrapper will accept known field', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.OrderID = 'ipsum'\r\n }\r\n run()\r\n expect(proxy.OrderID).toEqual('ipsum')\r\n})\r\n\r\ntest('check wrapper rejects unknown enum value', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.SettlType = '23'\r\n }\r\n expect(run).toThrow(/enum field SettlType does not support \"23\"/)\r\n})\r\n\r\ntest('check wrapper will accept known enum field', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.SettlType = '1'\r\n }\r\n run()\r\n expect(proxy.SettlType).toEqual('1')\r\n})\r\n\r\ntest('check wrapper rejects Date field when not given Date', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.SettlDate = \"I'm not a good date\"\r\n }\r\n expect(run).toThrow(/expects Date but receives/)\r\n})\r\n\r\ntest('check wrapper will accept Date field when given Date', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.SettlDate = new Date()\r\n }\r\n run()\r\n expect(proxy.SettlDate).toBeTruthy()\r\n})\r\n\r\ntest('check wrapper rejects boolean field when not given boolean', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.LastRptRequested = \"I'm not a good boolean\"\r\n }\r\n expect(run).toThrow(/expects boolean but receives/)\r\n})\r\n\r\ntest('check wrapper will accept boolean field when given boolean', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.LastRptRequested = true\r\n }\r\n run()\r\n expect(proxy.LastRptRequested).toEqual(true)\r\n})\r\n\r\ntest('check wrapper rejects Buffer field when not given Buffer', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.EncodedText = \"I'm not a Buffer, don't accept me!\"\r\n }\r\n expect(run).toThrow(/expects Buffer but receives/)\r\n})\r\n\r\ntest('check wrapper will accept Buffer field when given Buffer', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.EncodedText = new Buffer('I am a buffer.', 'utf8')\r\n }\r\n run()\r\n expect(proxy.EncodedText).toBeTruthy()\r\n})\r\n\r\ntest('check wrapper rejects string field when not given string', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.ClOrdID = 123\r\n }\r\n expect(run).toThrow(/expects string but receives/)\r\n})\r\n\r\ntest('check wrapper will accept string field when given string', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.ClOrdID = \"I'm a great string\"\r\n }\r\n run()\r\n expect(proxy.ClOrdID).toEqual(\"I'm a great string\")\r\n})\r\n\r\ntest('check wrapper rejects number field when not given number', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.GrossTradeAmt = \"I'm no number\"\r\n }\r\n expect(run).toThrow(/expects number but receives/)\r\n})\r\n\r\ntest('check wrapper will accept number field when given number', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.GrossTradeAmt = 12234\r\n }\r\n run()\r\n expect(proxy.GrossTradeAmt).toEqual(12234)\r\n})\r\n\r\ntest('check wrapper rejects non object field when assigning component', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.Parties = 'I should be an object, but I am sadly not'\r\n }\r\n expect(run).toThrow(/is a component but/)\r\n})\r\n\r\ntest('check wrapper accepts object field when assigning component', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.Parties = {\r\n }\r\n }\r\n run()\r\n expect(proxy.Parties).toBeTruthy()\r\n})\r\n\r\ntest('check wrapper when assigned component wraps so it can be checked.', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.YieldData = {\r\n }\r\n }\r\n run()\r\n function run2 (): void {\r\n proxy.YieldData.GrossTradeAmt = 999\r\n }\r\n // reject this\r\n expect(run2).toThrow(/no field named GrossTradeAmt/)\r\n proxy.YieldData.YieldCalcDate = new Date()\r\n // accept this\r\n expect(proxy.YieldData).toBeTruthy()\r\n})\r\n\r\ntest('check wrapper when given populated component.', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.YieldData = {\r\n ClOrdID: \"I don't belong here.\"\r\n }\r\n }\r\n // reject this\r\n expect(run).toThrow(/no field named ClOrdID/)\r\n})\r\n\r\ntest('check wrapper accepts number for group field and wraps n elements', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.Parties = {\r\n NoPartyIDs: 2\r\n }\r\n }\r\n run()\r\n expect(proxy.Parties).toBeTruthy()\r\n expect(Array.isArray(proxy.Parties.NoPartyIDs)).toEqual(true)\r\n expect(proxy.Parties.NoPartyIDs.length).toEqual(2)\r\n // now assign a field, this should also be wrapped\r\n proxy.Parties.NoPartyIDs[0].PartyID = 'hello'\r\n expect(proxy.Parties.NoPartyIDs[0].PartyID).toBeTruthy()\r\n function run2 (): void {\r\n proxy.Parties.NoPartyIDs[0].GrossTradeAmt = 999\r\n }\r\n // reject this\r\n expect(run2).toThrow(/no field named GrossTradeAmt/)\r\n})\r\n\r\ntest('check wrapper accepts array of objects in group component', () => {\r\n const proxy: ILooseObject = proxyFactory.wrap('ExecutionReport')\r\n expect(proxy).toBeTruthy()\r\n function run (): void {\r\n proxy.Parties = {\r\n NoPartyIDs: getParties()\r\n }\r\n }\r\n run()\r\n function run2 (): void {\r\n proxy.Parties.NoPartyIDs[0].GrossTradeAmt = 999\r\n }\r\n // reject this\r\n expect(run2).toThrow(/no field named GrossTradeAmt/)\r\n})\r\n\r\nfunction getParties (): ILooseObject {\r\n return [\r\n {\r\n 'PartyID': 'magna.',\r\n 'PartyIDSource': '9',\r\n 'PartyRole': 28,\r\n 'PtysSubGrp': {\r\n 'NoPartySubIDs': [\r\n {\r\n 'PartySubID': 'et',\r\n 'PartySubIDType': 22\r\n },\r\n {\r\n 'PartySubID': 'leo,',\r\n 'PartySubIDType': 10\r\n }\r\n ]\r\n }\r\n },\r\n {\r\n 'PartyID': 'iaculis',\r\n 'PartyIDSource': 'F',\r\n 'PartyRole': 2,\r\n 'PtysSubGrp': {\r\n 'NoPartySubIDs': [\r\n {\r\n 'PartySubID': 'Nullam',\r\n 'PartySubIDType': 12\r\n },\r\n {\r\n 'PartySubID': 'lectus,',\r\n 'PartySubIDType': 13\r\n },\r\n {\r\n 'PartySubID': 'eget',\r\n 'PartySubIDType': 18\r\n }\r\n ]\r\n }\r\n },\r\n {\r\n 'PartyID': 'vitae,',\r\n 'PartyIDSource': '9',\r\n 'PartyRole': 5,\r\n 'PtysSubGrp': {\r\n 'NoPartySubIDs': [\r\n {\r\n 'PartySubID': 'ac',\r\n 'PartySubIDType': 6\r\n }\r\n ]\r\n }\r\n }\r\n ]\r\n}\r\n"]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { AsciiSessionMsgFactory } from '../../transport/ascii';
|
|
2
|
+
import { FixDuplex } from '../../transport';
|
|
3
|
+
import { Setup } from './setup';
|
|
4
|
+
import { MsgView } from '../../buffer';
|
|
5
|
+
import { IJsFixConfig } from '../../config';
|
|
6
|
+
import { MsgTransport } from '../../transport/factory';
|
|
7
|
+
declare class FixEntity {
|
|
8
|
+
readonly config: IJsFixConfig;
|
|
9
|
+
readonly duplex: FixDuplex;
|
|
10
|
+
readonly transport: MsgTransport;
|
|
11
|
+
readonly views: MsgView[];
|
|
12
|
+
readonly errors: Error[];
|
|
13
|
+
constructor(config: IJsFixConfig, duplex?: FixDuplex, transport?: MsgTransport);
|
|
14
|
+
}
|
|
15
|
+
export declare class Experiment {
|
|
16
|
+
readonly client: FixEntity;
|
|
17
|
+
readonly clientFactory: AsciiSessionMsgFactory;
|
|
18
|
+
readonly serverFactory: AsciiSessionMsgFactory;
|
|
19
|
+
readonly server: FixEntity;
|
|
20
|
+
loopBack(lhs: FixDuplex, rhs: FixDuplex): void;
|
|
21
|
+
constructor(setup: Setup);
|
|
22
|
+
}
|
|
23
|
+
export {};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Experiment = void 0;
|
|
4
|
+
const transport_1 = require("../../transport");
|
|
5
|
+
const factory_1 = require("../../transport/factory");
|
|
6
|
+
class FixEntity {
|
|
7
|
+
constructor(config, duplex = new transport_1.StringDuplex(), transport = new factory_1.MsgTransport(0, config, duplex)) {
|
|
8
|
+
this.config = config;
|
|
9
|
+
this.duplex = duplex;
|
|
10
|
+
this.transport = transport;
|
|
11
|
+
this.views = [];
|
|
12
|
+
this.errors = [];
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
class Experiment {
|
|
16
|
+
constructor(setup) {
|
|
17
|
+
this.clientFactory = setup.client.sessionMsgFactory;
|
|
18
|
+
this.serverFactory = setup.server.sessionMsgFactory;
|
|
19
|
+
const clientConfig = setup.clientConfig;
|
|
20
|
+
const serverConfig = setup.serverConfig;
|
|
21
|
+
this.client = new FixEntity(clientConfig);
|
|
22
|
+
this.server = new FixEntity(serverConfig);
|
|
23
|
+
this.loopBack(this.client.duplex, this.server.duplex);
|
|
24
|
+
this.loopBack(this.server.duplex, this.client.duplex);
|
|
25
|
+
}
|
|
26
|
+
loopBack(lhs, rhs) {
|
|
27
|
+
lhs.writable.on('data', (data) => {
|
|
28
|
+
rhs.readable.push(data);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
exports.Experiment = Experiment;
|
|
33
|
+
//# sourceMappingURL=experiment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"experiment.js","sourceRoot":"","sources":["../../../src/test/env/experiment.ts"],"names":[],"mappings":";;;AAEA,+CAAyD;AAIzD,qDAAsD;AAEtD,MAAM,SAAS;IAIb,YAA6B,MAAoB,EACpB,SAAoB,IAAI,wBAAY,EAAE,EACtC,YAA0B,IAAI,sBAAY,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC;QAF7D,WAAM,GAAN,MAAM,CAAc;QACpB,WAAM,GAAN,MAAM,CAAgC;QACtC,cAAS,GAAT,SAAS,CAAoD;QAL1E,UAAK,GAAc,EAAE,CAAA;QACrB,WAAM,GAAY,EAAE,CAAA;IAKpC,CAAC;CACF;AAED,MAAa,UAAU;IAYrB,YAAa,KAAY;QACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,iBAA2C,CAAA;QAC7E,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,iBAA2C,CAAA;QAE7E,MAAM,YAAY,GAAG,KAAK,CAAC,YAAY,CAAA;QACvC,MAAM,YAAY,GAAG,KAAK,CAAC,YAAY,CAAA;QAEvC,IAAI,CAAC,MAAM,GAAG,IAAI,SAAS,CAAC,YAAY,CAAC,CAAA;QACzC,IAAI,CAAC,MAAM,GAAG,IAAI,SAAS,CAAC,YAAY,CAAC,CAAA;QAIzC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QACrD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACvD,CAAC;IApBD,QAAQ,CAAE,GAAc,EAAE,GAAc;QACtC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;YACvC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACzB,CAAC,CAAC,CAAA;IACJ,CAAC;CAiBF;AA3BD,gCA2BC","sourcesContent":["\r\nimport { AsciiSessionMsgFactory } from '../../transport/ascii'\r\nimport { FixDuplex, StringDuplex } from '../../transport'\r\nimport { Setup } from './setup'\r\nimport { MsgView } from '../../buffer'\r\nimport { IJsFixConfig } from '../../config'\r\nimport { MsgTransport } from '../../transport/factory'\r\n\r\nclass FixEntity {\r\n public readonly views: MsgView[] = []\r\n public readonly errors: Error[] = []\r\n\r\n constructor (public readonly config: IJsFixConfig,\r\n public readonly duplex: FixDuplex = new StringDuplex(),\r\n public readonly transport: MsgTransport = new MsgTransport(0, config, duplex)) {\r\n }\r\n}\r\n\r\nexport class Experiment {\r\n public readonly client: FixEntity\r\n public readonly clientFactory: AsciiSessionMsgFactory\r\n public readonly serverFactory: AsciiSessionMsgFactory\r\n public readonly server: FixEntity\r\n\r\n loopBack (lhs: FixDuplex, rhs: FixDuplex) {\r\n lhs.writable.on('data', (data: Buffer) => {\r\n rhs.readable.push(data)\r\n })\r\n }\r\n\r\n constructor (setup: Setup) {\r\n this.clientFactory = setup.client.sessionMsgFactory as AsciiSessionMsgFactory\r\n this.serverFactory = setup.server.sessionMsgFactory as AsciiSessionMsgFactory\r\n\r\n const clientConfig = setup.clientConfig\r\n const serverConfig = setup.serverConfig\r\n\r\n this.client = new FixEntity(clientConfig)\r\n this.server = new FixEntity(serverConfig)\r\n\r\n // using a string duplex so pipe a write to client to read to server\r\n // to simulate a tcp connection.\r\n this.loopBack(this.client.duplex, this.server.duplex)\r\n this.loopBack(this.server.duplex, this.client.duplex)\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { MsgView } from '../../buffer';
|
|
2
|
+
import { AsciiParser } from '../../buffer/ascii';
|
|
3
|
+
export declare class ParsingResult {
|
|
4
|
+
readonly event: string;
|
|
5
|
+
readonly msgType: string;
|
|
6
|
+
readonly view: MsgView;
|
|
7
|
+
readonly contents: string;
|
|
8
|
+
readonly parser: AsciiParser;
|
|
9
|
+
constructor(event: string, msgType: string, view: MsgView, contents: string, parser: AsciiParser);
|
|
10
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ParsingResult = void 0;
|
|
4
|
+
class ParsingResult {
|
|
5
|
+
constructor(event, msgType, view, contents, parser) {
|
|
6
|
+
this.event = event;
|
|
7
|
+
this.msgType = msgType;
|
|
8
|
+
this.view = view;
|
|
9
|
+
this.contents = contents;
|
|
10
|
+
this.parser = parser;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.ParsingResult = ParsingResult;
|
|
14
|
+
//# sourceMappingURL=parsing-result.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parsing-result.js","sourceRoot":"","sources":["../../../src/test/env/parsing-result.ts"],"names":[],"mappings":";;;AAGA,MAAa,aAAa;IACxB,YAA6B,KAAa,EACb,OAAe,EACf,IAAa,EACb,QAAgB,EAChB,MAAmB;QAJnB,UAAK,GAAL,KAAK,CAAQ;QACb,YAAO,GAAP,OAAO,CAAQ;QACf,SAAI,GAAJ,IAAI,CAAS;QACb,aAAQ,GAAR,QAAQ,CAAQ;QAChB,WAAM,GAAN,MAAM,CAAa;IAChD,CAAC;CACF;AAPD,sCAOC","sourcesContent":["import { MsgView } from '../../buffer'\r\nimport { AsciiParser } from '../../buffer/ascii'\r\n\r\nexport class ParsingResult {\r\n constructor (public readonly event: string,\r\n public readonly msgType: string,\r\n public readonly view: MsgView,\r\n public readonly contents: string,\r\n public readonly parser: AsciiParser) {\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { FixDefinitions } from '../../dictionary/definition';
|
|
2
|
+
import { SessionContainer } from '../../runtime';
|
|
3
|
+
import { ISessionDescription, ISessionMsgFactory, MsgTransmitter } from '../../transport';
|
|
4
|
+
import { DependencyContainer } from 'tsyringe';
|
|
5
|
+
import { IJsFixConfig } from '../../config';
|
|
6
|
+
import { FileReplayer } from '../../util';
|
|
7
|
+
import { ElasticBuffer, MsgView } from '../../buffer';
|
|
8
|
+
import { AsciiParser } from '../../buffer/ascii';
|
|
9
|
+
import { ParsingResult } from './parsing-result';
|
|
10
|
+
export declare class TestEntity {
|
|
11
|
+
readonly sessionPath: string;
|
|
12
|
+
readonly fixContainer: SessionContainer;
|
|
13
|
+
readonly description: ISessionDescription;
|
|
14
|
+
sessionContainer: DependencyContainer;
|
|
15
|
+
config: IJsFixConfig;
|
|
16
|
+
replayer: FileReplayer;
|
|
17
|
+
rxBuffer: ElasticBuffer;
|
|
18
|
+
txBuffer: ElasticBuffer;
|
|
19
|
+
transmitter: MsgTransmitter;
|
|
20
|
+
sessionMsgFactory: ISessionMsgFactory;
|
|
21
|
+
constructor(sessionPath: string);
|
|
22
|
+
getViews(fix?: string): Promise<MsgView[]>;
|
|
23
|
+
getAsciiParser(text: string, chunks?: boolean): AsciiParser;
|
|
24
|
+
parseText(text: string, chunks?: boolean): Promise<ParsingResult>;
|
|
25
|
+
make(): Promise<void>;
|
|
26
|
+
}
|
|
27
|
+
export declare class Setup {
|
|
28
|
+
readonly clientPath: string;
|
|
29
|
+
readonly serverPath: string;
|
|
30
|
+
definitions: FixDefinitions;
|
|
31
|
+
client: TestEntity;
|
|
32
|
+
server: TestEntity;
|
|
33
|
+
clientConfig: IJsFixConfig;
|
|
34
|
+
serverConfig: IJsFixConfig;
|
|
35
|
+
clientDescription: ISessionDescription;
|
|
36
|
+
clientSessionContainer: DependencyContainer;
|
|
37
|
+
constructor(clientPath?: string, serverPath?: string);
|
|
38
|
+
init(): Promise<void>;
|
|
39
|
+
}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.Setup = exports.TestEntity = void 0;
|
|
13
|
+
const di_tokens_1 = require("../../runtime/di-tokens");
|
|
14
|
+
const runtime_1 = require("../../runtime");
|
|
15
|
+
const transport_1 = require("../../transport");
|
|
16
|
+
const path = require("path");
|
|
17
|
+
const util_1 = require("../../util");
|
|
18
|
+
const ascii_1 = require("../../buffer/ascii");
|
|
19
|
+
const parsing_result_1 = require("./parsing-result");
|
|
20
|
+
const root = path.join(__dirname, '../../../data');
|
|
21
|
+
class TestEntity {
|
|
22
|
+
constructor(sessionPath) {
|
|
23
|
+
this.sessionPath = sessionPath;
|
|
24
|
+
this.fixContainer = new runtime_1.SessionContainer();
|
|
25
|
+
this.description = require(path.join(root, this.sessionPath));
|
|
26
|
+
}
|
|
27
|
+
getViews(fix = 'examples/FIX.4.4/fix.txt') {
|
|
28
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
29
|
+
return this.replayer.replayFixFile(path.join(root, fix));
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
getAsciiParser(text, chunks = false) {
|
|
33
|
+
return new ascii_1.AsciiParser(this.config, new transport_1.StringDuplex(text, chunks).readable, this.rxBuffer);
|
|
34
|
+
}
|
|
35
|
+
parseText(text, chunks = false) {
|
|
36
|
+
return new Promise((resolve, reject) => {
|
|
37
|
+
const parser = this.getAsciiParser(text, chunks);
|
|
38
|
+
parser.on('error', (e) => {
|
|
39
|
+
reject(e);
|
|
40
|
+
});
|
|
41
|
+
parser.on('msg', (msgType, view) => {
|
|
42
|
+
resolve(new parsing_result_1.ParsingResult('msg', msgType, view.clone(), parser.state.elasticBuffer.toString(), parser));
|
|
43
|
+
});
|
|
44
|
+
parser.on('done', () => {
|
|
45
|
+
resolve(new parsing_result_1.ParsingResult('done', null, null, parser.state.elasticBuffer.toString(), parser));
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
make() {
|
|
50
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
51
|
+
this.fixContainer.reset();
|
|
52
|
+
this.fixContainer.registerGlobal('error');
|
|
53
|
+
this.sessionContainer = yield this.fixContainer.makeSystem(this.description);
|
|
54
|
+
const container = this.sessionContainer;
|
|
55
|
+
this.config = container.resolve(di_tokens_1.DITokens.IJsFixConfig);
|
|
56
|
+
this.config.delimiter = this.config.logDelimiter;
|
|
57
|
+
this.replayer = new util_1.FileReplayer(this.config);
|
|
58
|
+
this.sessionMsgFactory = container.resolve(di_tokens_1.DITokens.ISessionMsgFactory);
|
|
59
|
+
if (container.isRegistered(di_tokens_1.DITokens.ParseBuffer)) {
|
|
60
|
+
this.rxBuffer = container.resolve(di_tokens_1.DITokens.ParseBuffer);
|
|
61
|
+
}
|
|
62
|
+
if (container.isRegistered(di_tokens_1.DITokens.TransmitBuffer)) {
|
|
63
|
+
this.txBuffer = container.resolve(di_tokens_1.DITokens.TransmitBuffer);
|
|
64
|
+
}
|
|
65
|
+
if (container.isRegistered(di_tokens_1.DITokens.MsgTransmitter)) {
|
|
66
|
+
this.transmitter = container.resolve(di_tokens_1.DITokens.MsgTransmitter);
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
exports.TestEntity = TestEntity;
|
|
72
|
+
class Setup {
|
|
73
|
+
constructor(clientPath = 'session/test-initiator.json', serverPath = 'session/test-acceptor.json') {
|
|
74
|
+
this.clientPath = clientPath;
|
|
75
|
+
this.serverPath = serverPath;
|
|
76
|
+
this.client = new TestEntity(clientPath);
|
|
77
|
+
if (serverPath) {
|
|
78
|
+
this.server = new TestEntity(serverPath);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
init() {
|
|
82
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
83
|
+
if (this.client) {
|
|
84
|
+
yield this.client.make();
|
|
85
|
+
this.definitions = this.client.config.definitions;
|
|
86
|
+
this.clientConfig = this.client.config;
|
|
87
|
+
this.clientSessionContainer = this.client.sessionContainer;
|
|
88
|
+
this.clientDescription = this.client.description;
|
|
89
|
+
}
|
|
90
|
+
if (this.server) {
|
|
91
|
+
yield this.server.make();
|
|
92
|
+
this.serverConfig = this.server.config;
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
exports.Setup = Setup;
|
|
98
|
+
//# sourceMappingURL=setup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"setup.js","sourceRoot":"","sources":["../../../src/test/env/setup.ts"],"names":[],"mappings":"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","sourcesContent":["import { FixDefinitions } from '../../dictionary/definition'\r\nimport { DITokens } from '../../runtime/di-tokens'\r\nimport { SessionContainer } from '../../runtime'\r\nimport { ISessionDescription, ISessionMsgFactory, MsgTransmitter, StringDuplex } from '../../transport'\r\nimport { DependencyContainer } from 'tsyringe'\r\nimport { IJsFixConfig } from '../../config'\r\nimport * as path from 'path'\r\nimport { FileReplayer } from '../../util'\r\nimport { ElasticBuffer, MsgView } from '../../buffer'\r\nimport { AsciiParser } from '../../buffer/ascii'\r\nimport { ParsingResult } from './parsing-result'\r\nconst root: string = path.join(__dirname, '../../../data')\r\n\r\nexport class TestEntity {\r\n public readonly fixContainer: SessionContainer = new SessionContainer()\r\n public readonly description: ISessionDescription\r\n public sessionContainer: DependencyContainer\r\n public config: IJsFixConfig\r\n public replayer: FileReplayer\r\n public rxBuffer: ElasticBuffer\r\n public txBuffer: ElasticBuffer\r\n public transmitter: MsgTransmitter\r\n\r\n public sessionMsgFactory: ISessionMsgFactory\r\n\r\n constructor (public readonly sessionPath: string) {\r\n this.description = require(path.join(root, this.sessionPath))\r\n }\r\n\r\n async getViews (fix: string = 'examples/FIX.4.4/fix.txt'): Promise<MsgView[]> {\r\n return this.replayer.replayFixFile(path.join(root, fix))\r\n }\r\n\r\n getAsciiParser (text: string, chunks: boolean = false): AsciiParser {\r\n return new AsciiParser(this.config, new StringDuplex(text, chunks).readable, this.rxBuffer)\r\n }\r\n\r\n parseText (text: string, chunks: boolean = false): Promise<ParsingResult> {\r\n return new Promise<any>((resolve, reject) => {\r\n const parser = this.getAsciiParser(text, chunks)\r\n parser.on('error', (e: Error) => {\r\n reject(e)\r\n })\r\n parser.on('msg', (msgType: string, view: MsgView) => {\r\n resolve(new ParsingResult('msg', msgType, view.clone(), parser.state.elasticBuffer.toString(), parser))\r\n })\r\n parser.on('done', () => {\r\n resolve(new ParsingResult('done', null,null, parser.state.elasticBuffer.toString(), parser))\r\n })\r\n })\r\n }\r\n\r\n async make () {\r\n this.fixContainer.reset()\r\n this.fixContainer.registerGlobal('error')\r\n this.sessionContainer = await this.fixContainer.makeSystem(this.description)\r\n const container = this.sessionContainer\r\n this.config = container.resolve<IJsFixConfig>(DITokens.IJsFixConfig)\r\n this.config.delimiter = this.config.logDelimiter\r\n this.replayer = new FileReplayer(this.config)\r\n\r\n this.sessionMsgFactory = container.resolve<ISessionMsgFactory>(DITokens.ISessionMsgFactory)\r\n if (container.isRegistered(DITokens.ParseBuffer)) {\r\n this.rxBuffer = container.resolve<ElasticBuffer>(DITokens.ParseBuffer)\r\n }\r\n if (container.isRegistered(DITokens.TransmitBuffer)) {\r\n this.txBuffer = container.resolve<ElasticBuffer>(DITokens.TransmitBuffer)\r\n }\r\n if (container.isRegistered(DITokens.MsgTransmitter)) {\r\n this.transmitter = container.resolve<MsgTransmitter>(DITokens.MsgTransmitter)\r\n }\r\n }\r\n}\r\n\r\nexport class Setup {\r\n public definitions: FixDefinitions\r\n client: TestEntity\r\n server: TestEntity\r\n clientConfig: IJsFixConfig\r\n serverConfig: IJsFixConfig\r\n clientDescription: ISessionDescription\r\n clientSessionContainer: DependencyContainer\r\n\r\n constructor (public readonly clientPath: string = 'session/test-initiator.json',\r\n public readonly serverPath: string = 'session/test-acceptor.json') {\r\n\r\n this.client = new TestEntity(clientPath)\r\n if (serverPath) {\r\n this.server = new TestEntity(serverPath)\r\n }\r\n }\r\n\r\n async init () {\r\n if (this.client) {\r\n await this.client.make()\r\n this.definitions = this.client.config.definitions\r\n this.clientConfig = this.client.config\r\n this.clientSessionContainer = this.client.sessionContainer\r\n this.clientDescription = this.client.description\r\n }\r\n if (this.server) {\r\n await this.server.make()\r\n this.serverConfig = this.server.config\r\n }\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { SkeletonSession } from '../../sample/tcp/skeleton/skeleton-session';
|
|
2
|
+
import { ILooseObject } from '../../collections/collection';
|
|
3
|
+
import { Experiment } from './experiment';
|
|
4
|
+
export declare class SkeletonRunner {
|
|
5
|
+
readonly experiment: Experiment;
|
|
6
|
+
readonly logoutSeconds: number;
|
|
7
|
+
clientSkeleton: SkeletonSession;
|
|
8
|
+
serverSkeleton: SkeletonSession;
|
|
9
|
+
constructor(experiment: Experiment, logoutSeconds?: number);
|
|
10
|
+
watchdog(): void;
|
|
11
|
+
sendMsg(msgType: string, o: ILooseObject): void;
|
|
12
|
+
sendText(followOn: string): void;
|
|
13
|
+
done(): void;
|
|
14
|
+
wait(): Promise<void>;
|
|
15
|
+
}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.SkeletonRunner = void 0;
|
|
13
|
+
const skeleton_session_1 = require("../../sample/tcp/skeleton/skeleton-session");
|
|
14
|
+
const buffer_1 = require("../../buffer");
|
|
15
|
+
class SkeletonRunner {
|
|
16
|
+
constructor(experiment, logoutSeconds = 1) {
|
|
17
|
+
this.experiment = experiment;
|
|
18
|
+
this.logoutSeconds = logoutSeconds;
|
|
19
|
+
this.clientSkeleton = new skeleton_session_1.SkeletonSession(experiment.client.config, logoutSeconds, false);
|
|
20
|
+
this.serverSkeleton = new skeleton_session_1.SkeletonSession(experiment.server.config, logoutSeconds, false);
|
|
21
|
+
this.clientSkeleton.checkMsgIntegrity = true;
|
|
22
|
+
this.serverSkeleton.checkMsgIntegrity = true;
|
|
23
|
+
experiment.client.transport.receiver.on('msg', (type, view) => {
|
|
24
|
+
experiment.client.views.push(view.clone());
|
|
25
|
+
this.watchdog();
|
|
26
|
+
});
|
|
27
|
+
experiment.server.transport.receiver.on('msg', (type, view) => {
|
|
28
|
+
experiment.server.views.push(view.clone());
|
|
29
|
+
this.watchdog();
|
|
30
|
+
});
|
|
31
|
+
this.clientSkeleton.on('error', e => {
|
|
32
|
+
experiment.client.errors.push(e);
|
|
33
|
+
});
|
|
34
|
+
this.serverSkeleton.on('error', e => {
|
|
35
|
+
experiment.server.errors.push(e);
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
watchdog() {
|
|
39
|
+
const experiment = this.experiment;
|
|
40
|
+
const cviews = experiment.client.views;
|
|
41
|
+
const sviews = experiment.server.views;
|
|
42
|
+
const cerrors = experiment.client.errors;
|
|
43
|
+
const serrors = experiment.server.errors;
|
|
44
|
+
const clientStop = cviews.length > 20 || cerrors.length > 0;
|
|
45
|
+
const serverStop = sviews.length > 20 || serrors.length > 0;
|
|
46
|
+
const stop = clientStop || serverStop;
|
|
47
|
+
if (stop) {
|
|
48
|
+
this.clientSkeleton.done();
|
|
49
|
+
this.serverSkeleton.done();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
sendMsg(msgType, o) {
|
|
53
|
+
let count = 0;
|
|
54
|
+
this.experiment.client.transport.receiver.on('msg', m => {
|
|
55
|
+
if (count === 0) {
|
|
56
|
+
count++;
|
|
57
|
+
this.clientSkeleton.sendMessage(msgType, o);
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
sendText(followOn) {
|
|
62
|
+
const experiment = this.experiment;
|
|
63
|
+
if (followOn) {
|
|
64
|
+
let sent = false;
|
|
65
|
+
experiment.client.transport.transmitter.on('encoded', () => {
|
|
66
|
+
const b1 = new buffer_1.ElasticBuffer();
|
|
67
|
+
b1.writeString(followOn);
|
|
68
|
+
if (!sent) {
|
|
69
|
+
experiment.client.transport.duplex.writable.write(b1.slice());
|
|
70
|
+
const at = experiment.client.transport.transmitter;
|
|
71
|
+
at.msgSeqNum++;
|
|
72
|
+
sent = true;
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
done() {
|
|
78
|
+
this.clientSkeleton.done();
|
|
79
|
+
this.serverSkeleton.done();
|
|
80
|
+
}
|
|
81
|
+
wait() {
|
|
82
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
83
|
+
const experiment = this.experiment;
|
|
84
|
+
yield Promise.all([
|
|
85
|
+
this.clientSkeleton.run(experiment.client.transport),
|
|
86
|
+
this.serverSkeleton.run(experiment.server.transport),
|
|
87
|
+
new Promise((accept, reject) => {
|
|
88
|
+
let handle = null;
|
|
89
|
+
try {
|
|
90
|
+
handle = setTimeout(() => {
|
|
91
|
+
this.done();
|
|
92
|
+
accept(true);
|
|
93
|
+
}, (this.logoutSeconds + 2) * 1000);
|
|
94
|
+
}
|
|
95
|
+
catch (e) {
|
|
96
|
+
if (handle) {
|
|
97
|
+
clearTimeout(handle);
|
|
98
|
+
}
|
|
99
|
+
this.done();
|
|
100
|
+
reject(e);
|
|
101
|
+
}
|
|
102
|
+
})
|
|
103
|
+
]);
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
exports.SkeletonRunner = SkeletonRunner;
|
|
108
|
+
//# sourceMappingURL=skeleton-runner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skeleton-runner.js","sourceRoot":"","sources":["../../../src/test/env/skeleton-runner.ts"],"names":[],"mappings":"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","sourcesContent":["import { SkeletonSession } from '../../sample/tcp/skeleton/skeleton-session'\r\nimport { ElasticBuffer, MsgView } from '../../buffer'\r\nimport { ILooseObject } from '../../collections/collection'\r\nimport { AsciiMsgTransmitter } from '../../transport/ascii/ascii-msg-transmitter'\r\nimport { Experiment } from './experiment'\r\n\r\nexport class SkeletonRunner {\r\n clientSkeleton: SkeletonSession\r\n serverSkeleton: SkeletonSession\r\n\r\n constructor (public readonly experiment: Experiment, public readonly logoutSeconds: number = 1) {\r\n this.clientSkeleton = new SkeletonSession(experiment.client.config, logoutSeconds, false)\r\n this.serverSkeleton = new SkeletonSession(experiment.server.config, logoutSeconds, false)\r\n this.clientSkeleton.checkMsgIntegrity = true\r\n this.serverSkeleton.checkMsgIntegrity = true\r\n\r\n experiment.client.transport.receiver.on('msg', (type: string, view: MsgView) => {\r\n experiment.client.views.push(view.clone())\r\n this.watchdog()\r\n })\r\n\r\n experiment.server.transport.receiver.on('msg', (type: string, view: MsgView) => {\r\n experiment.server.views.push(view.clone())\r\n this.watchdog()\r\n })\r\n\r\n this.clientSkeleton.on('error', e => {\r\n experiment.client.errors.push(e)\r\n })\r\n\r\n this.serverSkeleton.on('error', e => {\r\n experiment.server.errors.push(e)\r\n })\r\n }\r\n\r\n watchdog () {\r\n const experiment = this.experiment\r\n const cviews = experiment.client.views\r\n const sviews = experiment.server.views\r\n\r\n const cerrors = experiment.client.errors\r\n const serrors = experiment.server.errors\r\n\r\n const clientStop = cviews.length > 20 || cerrors.length > 0\r\n const serverStop = sviews.length > 20 || serrors.length > 0\r\n const stop = clientStop || serverStop\r\n if (stop) {\r\n this.clientSkeleton.done()\r\n this.serverSkeleton.done()\r\n }\r\n }\r\n\r\n sendMsg (msgType: string, o: ILooseObject): void {\r\n let count = 0\r\n this.experiment.client.transport.receiver.on('msg', m => {\r\n if (count === 0) {\r\n count++\r\n this.clientSkeleton.sendMessage(msgType, o)\r\n }\r\n })\r\n }\r\n\r\n sendText (followOn: string): void {\r\n const experiment = this.experiment\r\n if (followOn) {\r\n let sent: boolean = false\r\n experiment.client.transport.transmitter.on('encoded', () => {\r\n const b1 = new ElasticBuffer()\r\n b1.writeString(followOn)\r\n if (!sent) {\r\n experiment.client.transport.duplex.writable.write(b1.slice())\r\n const at = experiment.client.transport.transmitter as AsciiMsgTransmitter\r\n at.msgSeqNum++\r\n sent = true\r\n }\r\n })\r\n }\r\n }\r\n\r\n done () {\r\n this.clientSkeleton.done()\r\n this.serverSkeleton.done()\r\n }\r\n\r\n async wait () {\r\n const experiment = this.experiment\r\n await Promise.all([\r\n this.clientSkeleton.run(experiment.client.transport),\r\n this.serverSkeleton.run(experiment.server.transport),\r\n new Promise((accept, reject) => {\r\n let handle = null\r\n try {\r\n handle = setTimeout(() => {\r\n this.done()\r\n accept(true)\r\n }, (this.logoutSeconds + 2) * 1000)\r\n } catch (e) {\r\n if (handle) {\r\n clearTimeout(handle)\r\n }\r\n this.done()\r\n reject(e)\r\n }\r\n })])\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { FixMsgAsciiStoreResend, FixMsgStoreRecord, IFixMsgStore } from '../../store';
|
|
2
|
+
import { MsgView } from '../../buffer';
|
|
3
|
+
import { IJsFixConfig } from '../../config';
|
|
4
|
+
export declare class TestRecovery {
|
|
5
|
+
readonly views: MsgView[];
|
|
6
|
+
readonly config: IJsFixConfig;
|
|
7
|
+
readonly store: IFixMsgStore;
|
|
8
|
+
readonly records: FixMsgStoreRecord[];
|
|
9
|
+
readonly recovery: FixMsgAsciiStoreResend;
|
|
10
|
+
constructor(views: MsgView[], config: IJsFixConfig);
|
|
11
|
+
populate(): Promise<void>;
|
|
12
|
+
getRecords(comp: string): FixMsgStoreRecord[];
|
|
13
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.TestRecovery = void 0;
|
|
13
|
+
const store_1 = require("../../store");
|
|
14
|
+
const types_1 = require("../../types");
|
|
15
|
+
class TestRecovery {
|
|
16
|
+
constructor(views, config) {
|
|
17
|
+
this.views = views;
|
|
18
|
+
this.config = config;
|
|
19
|
+
const id = config.description.SenderCompId;
|
|
20
|
+
this.store = new store_1.FixMsgMemoryStore(`test-${id}`, config);
|
|
21
|
+
this.records = this.getRecords(id);
|
|
22
|
+
this.recovery = new store_1.FixMsgAsciiStoreResend(this.store, config);
|
|
23
|
+
}
|
|
24
|
+
populate() {
|
|
25
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
26
|
+
const records = this.records;
|
|
27
|
+
const toWrite = records.map(r => this.store.put(r));
|
|
28
|
+
yield Promise.all(toWrite);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
getRecords(comp) {
|
|
32
|
+
return this.views.reduce((agg, v) => {
|
|
33
|
+
if (v.getString(types_1.MsgTag.SenderCompID) === comp) {
|
|
34
|
+
agg.push(store_1.FixMsgStoreRecord.toMsgStoreRecord(v));
|
|
35
|
+
}
|
|
36
|
+
return agg;
|
|
37
|
+
}, []);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
exports.TestRecovery = TestRecovery;
|
|
41
|
+
//# sourceMappingURL=test-recovery.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"test-recovery.js","sourceRoot":"","sources":["../../../src/test/env/test-recovery.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,uCAAwG;AAIxG,uCAAoC;AAEpC,MAAa,YAAY;IAKvB,YAA6B,KAAgB,EAAkB,MAAoB;QAAtD,UAAK,GAAL,KAAK,CAAW;QAAkB,WAAM,GAAN,MAAM,CAAc;QACjF,MAAM,EAAE,GAAG,MAAM,CAAC,WAAW,CAAC,YAAY,CAAA;QAE1C,IAAI,CAAC,KAAK,GAAG,IAAI,yBAAiB,CAAC,QAAQ,EAAE,EAAE,EAAE,MAAM,CAAC,CAAA;QACxD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,8BAAsB,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAA;IAChE,CAAC;IAEK,QAAQ;;YACZ,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAA;YAC5B,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;YACnD,MAAM,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QAC5B,CAAC;KAAA;IAED,UAAU,CAAE,IAAY;QACtB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAwB,EAAE,CAAY,EAAE,EAAE;YAClE,IAAI,CAAC,CAAC,SAAS,CAAC,cAAM,CAAC,YAAY,CAAC,KAAK,IAAI,EAAE;gBAC7C,GAAG,CAAC,IAAI,CAAC,yBAAiB,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAA;aAChD;YACD,OAAO,GAAG,CAAA;QACZ,CAAC,EAAE,EAAE,CAAC,CAAA;IACR,CAAC;CACF;AA3BD,oCA2BC","sourcesContent":["import { FixMsgAsciiStoreResend, FixMsgMemoryStore, FixMsgStoreRecord, IFixMsgStore } from '../../store'\r\nimport { MsgView } from '../../buffer'\r\nimport { IJsFixConfig } from '../../config'\r\nimport { AsciiView } from '../../buffer/ascii'\r\nimport { MsgTag } from '../../types'\r\n\r\nexport class TestRecovery {\r\n public readonly store: IFixMsgStore\r\n public readonly records: FixMsgStoreRecord[]\r\n public readonly recovery: FixMsgAsciiStoreResend\r\n\r\n constructor (public readonly views: MsgView[], public readonly config: IJsFixConfig) {\r\n const id = config.description.SenderCompId\r\n\r\n this.store = new FixMsgMemoryStore(`test-${id}`, config)\r\n this.records = this.getRecords(id)\r\n this.recovery = new FixMsgAsciiStoreResend(this.store, config)\r\n }\r\n\r\n async populate () {\r\n const records = this.records\r\n const toWrite = records.map(r => this.store.put(r))\r\n await Promise.all(toWrite)\r\n }\r\n\r\n getRecords (comp: string) {\r\n return this.views.reduce((agg: FixMsgStoreRecord[], v: AsciiView) => {\r\n if (v.getString(MsgTag.SenderCompID) === comp) {\r\n agg.push(FixMsgStoreRecord.toMsgStoreRecord(v))\r\n }\r\n return agg\r\n }, [])\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { MsgView } from '../../buffer';
|
|
2
|
+
import { FixDefinitions } from '../../dictionary/definition';
|
|
3
|
+
export declare class ToViews {
|
|
4
|
+
readonly testFolder: string;
|
|
5
|
+
definitions: FixDefinitions;
|
|
6
|
+
readonly views: MsgView[];
|
|
7
|
+
batch: MsgView;
|
|
8
|
+
private readonly root;
|
|
9
|
+
constructor(testFolder: string);
|
|
10
|
+
load(file?: string): Promise<any>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ToViews = void 0;
|
|
13
|
+
const path = require("path");
|
|
14
|
+
const config_1 = require("../../config");
|
|
15
|
+
const ascii_1 = require("../../buffer/ascii");
|
|
16
|
+
const fixml_1 = require("../../buffer/fixml");
|
|
17
|
+
const util_1 = require("../../util");
|
|
18
|
+
class ToViews {
|
|
19
|
+
constructor(testFolder) {
|
|
20
|
+
this.testFolder = testFolder;
|
|
21
|
+
this.views = [];
|
|
22
|
+
this.batch = null;
|
|
23
|
+
this.root = path.join(__dirname, '../../../data');
|
|
24
|
+
}
|
|
25
|
+
load(file = 'repofixml') {
|
|
26
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
27
|
+
const root = this.root;
|
|
28
|
+
const testFolder = this.testFolder;
|
|
29
|
+
const views = this.views;
|
|
30
|
+
this.definitions = yield new util_1.DefinitionFactory().getDefinitions(file);
|
|
31
|
+
const definitions = this.definitions;
|
|
32
|
+
const fs = require('fs');
|
|
33
|
+
const fullName = path.join(root, `${testFolder}/fix.xml`);
|
|
34
|
+
const readStream = fs.createReadStream(fullName);
|
|
35
|
+
const sessionDescription = require(path.join(root, 'session/test-initiator.json'));
|
|
36
|
+
const config = new config_1.JsFixConfig(null, definitions, sessionDescription, ascii_1.AsciiChars.Pipe);
|
|
37
|
+
const xmlParser = new fixml_1.FiXmlParser(config, readStream);
|
|
38
|
+
return new Promise((accept, reject) => {
|
|
39
|
+
xmlParser.on('msg', (msgType, v) => {
|
|
40
|
+
views.push(v.clone());
|
|
41
|
+
});
|
|
42
|
+
xmlParser.on('batch', (msgType, v) => {
|
|
43
|
+
this.batch = v.clone();
|
|
44
|
+
});
|
|
45
|
+
xmlParser.on('close', () => {
|
|
46
|
+
accept(true);
|
|
47
|
+
});
|
|
48
|
+
xmlParser.on('error', (e) => {
|
|
49
|
+
reject(e);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
exports.ToViews = ToViews;
|
|
56
|
+
//# sourceMappingURL=to-views.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"to-views.js","sourceRoot":"","sources":["../../../src/test/env/to-views.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6BAA4B;AAG5B,yCAA0C;AAE1C,8CAA+C;AAC/C,8CAAgD;AAEhD,qCAA8C;AAE9C,MAAa,OAAO;IAMlB,YAA6B,UAAkB;QAAlB,eAAU,GAAV,UAAU,CAAQ;QAJ/B,UAAK,GAAc,EAAE,CAAA;QAC9B,UAAK,GAAY,IAAI,CAAA;QACX,SAAI,GAAW,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,eAAe,CAAC,CAAA;IAGrE,CAAC;IAEY,IAAI,CAAE,OAAe,WAAW;;YAC3C,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAA;YACtB,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAA;YAClC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAA;YACxB,IAAI,CAAC,WAAW,GAAG,MAAM,IAAI,wBAAiB,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,CAAA;YACrE,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAA;YACpC,MAAM,EAAE,GAAQ,OAAO,CAAC,IAAI,CAAC,CAAA;YAC7B,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,UAAU,UAAU,CAAC,CAAA;YACzD,MAAM,UAAU,GAAe,EAAE,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAA;YAC5D,MAAM,kBAAkB,GAAwB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,6BAA6B,CAAC,CAAC,CAAA;YACvG,MAAM,MAAM,GAAG,IAAI,oBAAW,CAAC,IAAI,EAAE,WAAW,EAAE,kBAAkB,EAAE,kBAAU,CAAC,IAAI,CAAC,CAAA;YACtF,MAAM,SAAS,GAAc,IAAI,mBAAW,CAAC,MAAM,EAAE,UAAU,CAAC,CAAA;YAChE,OAAO,IAAI,OAAO,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE;gBACpC,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC,OAAe,EAAE,CAAU,EAAE,EAAE;oBAClD,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAA;gBACvB,CAAC,CAAC,CAAA;gBACF,SAAS,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,OAAe,EAAE,CAAU,EAAE,EAAE;oBACpD,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,EAAE,CAAA;gBACxB,CAAC,CAAC,CAAA;gBACF,SAAS,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;oBACzB,MAAM,CAAC,IAAI,CAAC,CAAA;gBACd,CAAC,CAAC,CAAA;gBACF,SAAS,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,CAAQ,EAAE,EAAE;oBACjC,MAAM,CAAC,CAAC,CAAC,CAAA;gBACX,CAAC,CAAC,CAAA;YACJ,CAAC,CAAC,CAAA;QACJ,CAAC;KAAA;CACF;AApCD,0BAoCC","sourcesContent":["import * as path from 'path'\r\nimport { ReadStream } from 'fs'\r\nimport { ISessionDescription } from '../../transport'\r\nimport { JsFixConfig } from '../../config'\r\nimport { MsgParser, MsgView } from '../../buffer'\r\nimport { AsciiChars } from '../../buffer/ascii'\r\nimport { FiXmlParser } from '../../buffer/fixml'\r\nimport { FixDefinitions } from '../../dictionary/definition'\r\nimport { DefinitionFactory } from '../../util'\r\n\r\nexport class ToViews {\r\n public definitions: FixDefinitions\r\n public readonly views: MsgView[] = []\r\n public batch: MsgView = null\r\n private readonly root: string = path.join(__dirname, '../../../data')\r\n\r\n constructor (public readonly testFolder: string) {\r\n }\r\n\r\n public async load (file: string = 'repofixml'): Promise<any> {\r\n const root = this.root\r\n const testFolder = this.testFolder\r\n const views = this.views\r\n this.definitions = await new DefinitionFactory().getDefinitions(file)\r\n const definitions = this.definitions\r\n const fs: any = require('fs')\r\n const fullName = path.join(root, `${testFolder}/fix.xml`)\r\n const readStream: ReadStream = fs.createReadStream(fullName)\r\n const sessionDescription: ISessionDescription = require(path.join(root, 'session/test-initiator.json'))\r\n const config = new JsFixConfig(null, definitions, sessionDescription, AsciiChars.Pipe)\r\n const xmlParser: MsgParser = new FiXmlParser(config, readStream)\r\n return new Promise((accept, reject) => {\r\n xmlParser.on('msg', (msgType: string, v: MsgView) => {\r\n views.push(v.clone())\r\n })\r\n xmlParser.on('batch', (msgType: string, v: MsgView) => {\r\n this.batch = v.clone()\r\n })\r\n xmlParser.on('close', () => {\r\n accept(true)\r\n })\r\n xmlParser.on('error', (e: Error) => {\r\n reject(e)\r\n })\r\n })\r\n }\r\n}\r\n"]}
|