@quantform/core 0.6.5 → 0.6.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/adapter/adapter-aggregate.d.ts +2 -2
- package/dist/adapter/adapter-aggregate.d.ts.map +1 -1
- package/dist/adapter/adapter-aggregate.js +12 -11
- package/dist/adapter/adapter.d.ts +2 -3
- package/dist/adapter/adapter.d.ts.map +1 -1
- package/dist/adapter/backtester/backtester-adapter.d.ts +1 -5
- package/dist/adapter/backtester/backtester-adapter.d.ts.map +1 -1
- package/dist/adapter/backtester/backtester-adapter.js +2 -2
- package/dist/adapter/backtester/backtester-cursor.d.ts.map +1 -1
- package/dist/adapter/backtester/backtester-cursor.js +2 -2
- package/dist/adapter/backtester/backtester-cursor.spec.d.ts +2 -0
- package/dist/adapter/backtester/backtester-cursor.spec.d.ts.map +1 -0
- package/dist/adapter/backtester/backtester-cursor.spec.js +47 -0
- package/dist/adapter/backtester/backtester-streamer.d.ts +1 -1
- package/dist/adapter/backtester/backtester-streamer.d.ts.map +1 -1
- package/dist/adapter/backtester/backtester-streamer.js +4 -5
- package/dist/adapter/backtester/backtester-streamer.spec.d.ts +2 -0
- package/dist/adapter/backtester/backtester-streamer.spec.d.ts.map +1 -0
- package/dist/adapter/backtester/backtester-streamer.spec.js +45 -0
- package/dist/adapter/backtester/error.d.ts +6 -2
- package/dist/adapter/backtester/error.d.ts.map +1 -1
- package/dist/adapter/backtester/error.js +11 -7
- package/dist/adapter/backtester/index.d.ts +4 -2
- package/dist/adapter/backtester/index.d.ts.map +1 -1
- package/dist/adapter/backtester/index.js +4 -2
- package/dist/adapter/error.d.ts +9 -3
- package/dist/adapter/error.d.ts.map +1 -1
- package/dist/adapter/error.js +16 -10
- package/dist/adapter/index.d.ts +5 -4
- package/dist/adapter/index.d.ts.map +1 -1
- package/dist/adapter/index.js +5 -4
- package/dist/adapter/paper/engine/paper-engine.d.ts.map +1 -1
- package/dist/adapter/paper/engine/paper-engine.js +7 -8
- package/dist/adapter/paper/engine/paper-engine.spec.d.ts +2 -0
- package/dist/adapter/paper/engine/paper-engine.spec.d.ts.map +1 -0
- package/dist/adapter/paper/engine/paper-engine.spec.js +63 -0
- package/dist/adapter/paper/index.d.ts +2 -2
- package/dist/adapter/paper/index.d.ts.map +1 -1
- package/dist/adapter/paper/index.js +2 -2
- package/dist/adapter/paper/paper-adapter.d.ts +1 -3
- package/dist/adapter/paper/paper-adapter.d.ts.map +1 -1
- package/dist/adapter/paper/paper-adapter.js +8 -7
- package/dist/cli/build.js +1 -1
- package/dist/cli/dev.js +6 -6
- package/dist/cli/index.js +5 -5
- package/dist/cli/internal/workspace.js +1 -1
- package/dist/cli/pull.js +6 -6
- package/dist/cli/run.js +6 -6
- package/dist/cli/test.d.ts.map +1 -1
- package/dist/cli/test.js +9 -8
- package/dist/domain/asset.d.ts +5 -1
- package/dist/domain/asset.d.ts.map +1 -1
- package/dist/domain/asset.js +13 -7
- package/dist/domain/asset.spec.d.ts +2 -0
- package/dist/domain/asset.spec.d.ts.map +1 -0
- package/dist/domain/asset.spec.js +54 -0
- package/dist/domain/balance-operator.d.ts +1 -3
- package/dist/domain/balance-operator.d.ts.map +1 -1
- package/dist/domain/balance-operator.js +2 -2
- package/dist/domain/balance-operator.spec.d.ts +2 -0
- package/dist/domain/balance-operator.spec.d.ts.map +1 -0
- package/dist/domain/balance-operator.spec.js +21 -0
- package/dist/domain/balance.d.ts +14 -15
- package/dist/domain/balance.d.ts.map +1 -1
- package/dist/domain/balance.js +30 -48
- package/dist/domain/balance.spec.d.ts +2 -0
- package/dist/domain/balance.spec.d.ts.map +1 -0
- package/dist/domain/balance.spec.js +32 -0
- package/dist/domain/commission.d.ts.map +1 -1
- package/dist/domain/commission.spec.d.ts +2 -0
- package/dist/domain/commission.spec.d.ts.map +1 -0
- package/dist/domain/commission.spec.js +30 -0
- package/dist/domain/component.d.ts +2 -2
- package/dist/domain/component.d.ts.map +1 -1
- package/dist/domain/error.d.ts +15 -5
- package/dist/domain/error.d.ts.map +1 -1
- package/dist/domain/error.js +26 -16
- package/dist/domain/index.d.ts +21 -21
- package/dist/domain/index.d.ts.map +1 -1
- package/dist/domain/index.js +21 -21
- package/dist/domain/instrument-operator.d.ts +1 -2
- package/dist/domain/instrument-operator.d.ts.map +1 -1
- package/dist/domain/instrument-operator.js +3 -3
- package/dist/domain/instrument-operator.spec.d.ts +2 -0
- package/dist/domain/instrument-operator.spec.d.ts.map +1 -0
- package/dist/domain/instrument-operator.spec.js +21 -0
- package/dist/domain/instrument.d.ts +3 -3
- package/dist/domain/instrument.d.ts.map +1 -1
- package/dist/domain/instrument.js +10 -8
- package/dist/domain/instrument.spec.d.ts +2 -0
- package/dist/domain/instrument.spec.d.ts.map +1 -0
- package/dist/domain/instrument.spec.js +51 -0
- package/dist/domain/ohlc-operator.d.ts +1 -1
- package/dist/domain/ohlc-operator.d.ts.map +1 -1
- package/dist/domain/ohlc-operator.js +4 -5
- package/dist/domain/ohlc-operator.spec.d.ts +2 -0
- package/dist/domain/ohlc-operator.spec.d.ts.map +1 -0
- package/dist/domain/ohlc-operator.spec.js +110 -0
- package/dist/domain/ohlc.d.ts.map +1 -1
- package/dist/domain/ohlc.spec.d.ts +2 -0
- package/dist/domain/ohlc.spec.d.ts.map +1 -0
- package/dist/domain/ohlc.spec.js +25 -0
- package/dist/domain/order-operator.d.ts +1 -3
- package/dist/domain/order-operator.d.ts.map +1 -1
- package/dist/domain/order-operator.js +3 -3
- package/dist/domain/order-operator.spec.d.ts +2 -0
- package/dist/domain/order-operator.spec.d.ts.map +1 -0
- package/dist/domain/order-operator.spec.js +61 -0
- package/dist/domain/order.d.ts +5 -8
- package/dist/domain/order.d.ts.map +1 -1
- package/dist/domain/order.js +14 -22
- package/dist/domain/order.spec.d.ts +2 -0
- package/dist/domain/order.spec.d.ts.map +1 -0
- package/dist/domain/order.spec.js +27 -0
- package/dist/domain/orderbook-operator.d.ts +1 -3
- package/dist/domain/orderbook-operator.d.ts.map +1 -1
- package/dist/domain/orderbook-operator.js +2 -2
- package/dist/domain/orderbook-operator.spec.d.ts +2 -0
- package/dist/domain/orderbook-operator.spec.d.ts.map +1 -0
- package/dist/domain/orderbook-operator.spec.js +19 -0
- package/dist/domain/orderbook.d.ts +3 -2
- package/dist/domain/orderbook.d.ts.map +1 -1
- package/dist/domain/orderbook.js +3 -0
- package/dist/domain/orderbook.spec.d.ts +2 -0
- package/dist/domain/orderbook.spec.d.ts.map +1 -0
- package/dist/domain/orderbook.spec.js +11 -0
- package/dist/domain/position-operator.d.ts +1 -3
- package/dist/domain/position-operator.d.ts.map +1 -1
- package/dist/domain/position-operator.js +3 -4
- package/dist/domain/position-operator.spec.d.ts +2 -0
- package/dist/domain/position-operator.spec.d.ts.map +1 -0
- package/dist/domain/position-operator.spec.js +44 -0
- package/dist/domain/position.d.ts +3 -2
- package/dist/domain/position.d.ts.map +1 -1
- package/dist/domain/position.js +2 -0
- package/dist/domain/position.spec.d.ts +2 -0
- package/dist/domain/position.spec.d.ts.map +1 -0
- package/dist/domain/position.spec.js +28 -0
- package/dist/domain/session-builder.d.ts +8 -4
- package/dist/domain/session-builder.d.ts.map +1 -1
- package/dist/domain/session-builder.js +10 -15
- package/dist/domain/session.d.ts +1 -1
- package/dist/domain/session.d.ts.map +1 -1
- package/dist/domain/session.js +11 -17
- package/dist/domain/session.spec.d.ts +2 -0
- package/dist/domain/session.spec.d.ts.map +1 -0
- package/dist/domain/session.spec.js +17 -0
- package/dist/domain/trade-operator.d.ts +1 -3
- package/dist/domain/trade-operator.d.ts.map +1 -1
- package/dist/domain/trade-operator.js +2 -2
- package/dist/domain/trade-operator.spec.d.ts +2 -0
- package/dist/domain/trade-operator.spec.d.ts.map +1 -0
- package/dist/domain/trade-operator.spec.js +21 -0
- package/dist/domain/trade.d.ts +3 -2
- package/dist/domain/trade.d.ts.map +1 -1
- package/dist/domain/trade.js +3 -0
- package/dist/domain/trade.spec.d.ts +2 -0
- package/dist/domain/trade.spec.d.ts.map +1 -0
- package/dist/domain/trade.spec.js +11 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +9 -8
- package/dist/shared/collections.spec.d.ts +2 -0
- package/dist/shared/collections.spec.d.ts.map +1 -0
- package/dist/shared/collections.spec.js +29 -0
- package/dist/shared/decimals.spec.d.ts +2 -0
- package/dist/shared/decimals.spec.d.ts.map +1 -0
- package/dist/shared/decimals.spec.js +28 -0
- package/dist/shared/hash.d.ts +2 -0
- package/dist/shared/hash.d.ts.map +1 -0
- package/dist/shared/hash.js +12 -0
- package/dist/shared/index.d.ts +7 -7
- package/dist/shared/index.d.ts.map +1 -1
- package/dist/shared/index.js +7 -7
- package/dist/shared/logger.d.ts +8 -5
- package/dist/shared/logger.d.ts.map +1 -1
- package/dist/shared/logger.js +23 -16
- package/dist/storage/cache.d.ts +1 -1
- package/dist/storage/cache.d.ts.map +1 -1
- package/dist/storage/cache.spec.d.ts +2 -0
- package/dist/storage/cache.spec.d.ts.map +1 -0
- package/dist/storage/cache.spec.js +25 -0
- package/dist/storage/feed.d.ts +1 -1
- package/dist/storage/feed.d.ts.map +1 -1
- package/dist/storage/index.d.ts +4 -4
- package/dist/storage/index.d.ts.map +1 -1
- package/dist/storage/index.js +4 -4
- package/dist/storage/measurement.d.ts +1 -1
- package/dist/storage/measurement.d.ts.map +1 -1
- package/dist/store/error.d.ts +21 -7
- package/dist/store/error.d.ts.map +1 -1
- package/dist/store/error.js +36 -22
- package/dist/store/index.d.ts +10 -9
- package/dist/store/index.d.ts.map +1 -1
- package/dist/store/index.js +10 -9
- package/dist/store/store-balance-event.d.ts +10 -30
- package/dist/store/store-balance-event.d.ts.map +1 -1
- package/dist/store/store-balance-event.js +19 -94
- package/dist/store/store-balance-event.spec.d.ts +2 -0
- package/dist/store/store-balance-event.spec.d.ts.map +1 -0
- package/dist/store/store-balance-event.spec.js +24 -0
- package/dist/store/store-event.d.ts +1 -1
- package/dist/store/store-event.d.ts.map +1 -1
- package/dist/store/store-instrument-event.d.ts +1 -2
- package/dist/store/store-instrument-event.d.ts.map +1 -1
- package/dist/store/store-instrument-event.js +5 -6
- package/dist/store/store-instrument-event.spec.d.ts +2 -0
- package/dist/store/store-instrument-event.spec.d.ts.map +1 -0
- package/dist/store/store-instrument-event.spec.js +22 -0
- package/dist/store/store-order-event.d.ts +1 -2
- package/dist/store/store-order-event.d.ts.map +1 -1
- package/dist/store/store-order-event.js +60 -22
- package/dist/store/store-order-event.spec.d.ts +2 -0
- package/dist/store/store-order-event.spec.d.ts.map +1 -0
- package/dist/store/store-order-event.spec.js +23 -0
- package/dist/store/store-orderbook-event.d.ts +1 -2
- package/dist/store/store-orderbook-event.d.ts.map +1 -1
- package/dist/store/store-orderbook-event.js +3 -3
- package/dist/store/store-orderbook-event.spec.d.ts +2 -0
- package/dist/store/store-orderbook-event.spec.d.ts.map +1 -0
- package/dist/store/store-orderbook-event.spec.js +27 -0
- package/dist/store/store-position-event.d.ts +1 -2
- package/dist/store/store-position-event.d.ts.map +1 -1
- package/dist/store/store-position-event.js +5 -5
- package/dist/store/store-state.d.ts.map +1 -1
- package/dist/store/store-trade-event.d.ts +1 -2
- package/dist/store/store-trade-event.d.ts.map +1 -1
- package/dist/store/store-trade-event.js +3 -3
- package/dist/store/store-trade-event.spec.d.ts +2 -0
- package/dist/store/store-trade-event.spec.d.ts.map +1 -0
- package/dist/store/store-trade-event.spec.js +44 -0
- package/dist/store/store.d.ts +1 -2
- package/dist/store/store.d.ts.map +1 -1
- package/dist/store/store.js +5 -2
- package/dist/store/store.spec.d.ts +2 -0
- package/dist/store/store.spec.d.ts.map +1 -0
- package/dist/store/store.spec.js +122 -0
- package/jest.config.ts +23 -2
- package/package.json +2 -2
- package/src/adapter/adapter-aggregate.ts +35 -21
- package/src/adapter/adapter.ts +6 -7
- package/src/adapter/backtester/backtester-adapter.ts +12 -8
- package/src/adapter/backtester/backtester-cursor.spec.ts +6 -6
- package/src/adapter/backtester/backtester-cursor.ts +5 -5
- package/src/adapter/backtester/backtester-streamer.spec.ts +6 -6
- package/src/adapter/backtester/backtester-streamer.ts +12 -9
- package/src/adapter/backtester/error.ts +8 -4
- package/src/adapter/backtester/index.ts +4 -2
- package/src/adapter/error.ts +14 -8
- package/src/adapter/index.ts +5 -4
- package/src/adapter/paper/engine/paper-engine.spec.ts +6 -12
- package/src/adapter/paper/engine/paper-engine.ts +13 -28
- package/src/adapter/paper/index.ts +2 -2
- package/src/adapter/paper/paper-adapter.ts +18 -11
- package/src/cli/build.ts +1 -1
- package/src/cli/dev.ts +5 -5
- package/src/cli/index.ts +5 -5
- package/src/cli/internal/workspace.ts +1 -1
- package/src/cli/pull.ts +7 -7
- package/src/cli/run.ts +5 -5
- package/src/cli/test.ts +8 -7
- package/src/domain/asset.spec.ts +4 -4
- package/src/domain/asset.ts +13 -6
- package/src/domain/balance-operator.spec.ts +3 -6
- package/src/domain/balance-operator.ts +5 -6
- package/src/domain/balance.spec.ts +7 -77
- package/src/domain/balance.ts +51 -64
- package/src/domain/commission.spec.ts +3 -3
- package/src/domain/commission.ts +1 -1
- package/src/domain/component.ts +3 -3
- package/src/domain/error.ts +23 -18
- package/src/domain/index.ts +21 -21
- package/src/domain/instrument-operator.spec.ts +10 -7
- package/src/domain/instrument-operator.ts +6 -6
- package/src/domain/instrument.spec.ts +11 -6
- package/src/domain/instrument.ts +16 -7
- package/src/domain/ohlc-operator.spec.ts +5 -6
- package/src/domain/ohlc-operator.ts +2 -3
- package/src/domain/ohlc.spec.ts +2 -2
- package/src/domain/ohlc.ts +2 -2
- package/src/domain/order-operator.spec.ts +14 -10
- package/src/domain/order-operator.ts +8 -7
- package/src/domain/order.spec.ts +3 -6
- package/src/domain/order.ts +26 -29
- package/src/domain/orderbook-operator.spec.ts +11 -9
- package/src/domain/orderbook-operator.ts +5 -6
- package/src/domain/orderbook.spec.ts +3 -6
- package/src/domain/orderbook.ts +5 -3
- package/src/domain/position-operator.spec.ts +14 -11
- package/src/domain/position-operator.ts +12 -9
- package/src/domain/position.spec.ts +3 -6
- package/src/domain/position.ts +5 -3
- package/src/domain/session-builder.ts +14 -14
- package/src/domain/session.spec.ts +4 -4
- package/src/domain/session.ts +20 -15
- package/src/domain/trade-operator.spec.ts +4 -9
- package/src/domain/trade-operator.ts +5 -6
- package/src/domain/trade.spec.ts +3 -6
- package/src/domain/trade.ts +5 -3
- package/src/index.ts +15 -14
- package/src/shared/collections.spec.ts +2 -2
- package/src/shared/decimals.spec.ts +1 -1
- package/src/shared/hash.ts +10 -0
- package/src/shared/index.ts +7 -7
- package/src/shared/logger.ts +22 -15
- package/src/storage/cache.spec.ts +2 -3
- package/src/storage/cache.ts +2 -2
- package/src/storage/feed.ts +4 -4
- package/src/storage/index.ts +4 -4
- package/src/storage/measurement.ts +2 -2
- package/src/store/error.ts +33 -22
- package/src/store/index.ts +10 -9
- package/src/store/store-balance-event.spec.ts +5 -7
- package/src/store/store-balance-event.ts +20 -115
- package/src/store/store-event.ts +2 -2
- package/src/store/store-instrument-event.spec.ts +4 -5
- package/src/store/store-instrument-event.ts +13 -9
- package/src/store/store-order-event.spec.ts +6 -5
- package/src/store/store-order-event.ts +92 -23
- package/src/store/store-orderbook-event.spec.ts +4 -5
- package/src/store/store-orderbook-event.ts +11 -7
- package/src/store/store-position-event.ts +13 -9
- package/src/store/store-state.ts +2 -2
- package/src/store/store-trade-event.spec.ts +4 -5
- package/src/store/store-trade-event.ts +11 -7
- package/src/store/store.spec.ts +45 -31
- package/src/store/store.ts +6 -3
- package/tsconfig.json +7 -4
- package/dist/cli/error.d.ts +0 -2
- package/dist/cli/error.d.ts.map +0 -1
- package/dist/cli/error.js +0 -7
- package/dist/shared/pipe.d.ts +0 -5
- package/dist/shared/pipe.d.ts.map +0 -1
- package/dist/shared/pipe.js +0 -8
- package/src/cli/error.ts +0 -5
- package/src/shared/pipe.ts +0 -12
|
@@ -1,9 +1,8 @@
|
|
|
1
|
+
import { Adapter, AdapterFactory, AdapterTimeProvider, FeedAsyncCallback } from '../adapter';
|
|
1
2
|
import { InstrumentSelector, Ohlc, Order } from '../domain';
|
|
2
3
|
import { timestamp } from '../shared';
|
|
3
4
|
import { Cache } from '../storage';
|
|
4
5
|
import { Store } from '../store';
|
|
5
|
-
import { Adapter } from '.';
|
|
6
|
-
import { AdapterFactory, AdapterTimeProvider, FeedAsyncCallback } from './adapter';
|
|
7
6
|
/**
|
|
8
7
|
* Manages instances of all adapters provided in session descriptor.
|
|
9
8
|
* Awakes and disposes adapters, routes and executes commands.
|
|
@@ -13,6 +12,7 @@ export declare class AdapterAggregate {
|
|
|
13
12
|
private readonly timeProvider;
|
|
14
13
|
private readonly store;
|
|
15
14
|
private readonly cache;
|
|
15
|
+
private readonly logger;
|
|
16
16
|
private readonly adapter;
|
|
17
17
|
constructor(factories: AdapterFactory[], timeProvider: AdapterTimeProvider, store: Store, cache: Cache);
|
|
18
18
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"adapter-aggregate.d.ts","sourceRoot":"","sources":["../../src/adapter/adapter-aggregate.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"adapter-aggregate.d.ts","sourceRoot":"","sources":["../../src/adapter/adapter-aggregate.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,EACP,cAAc,EAEd,mBAAmB,EACnB,iBAAiB,EAClB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAC9D,OAAO,EAAO,SAAS,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAEnC;;;GAGG;AACH,qBAAa,gBAAgB;IAKzB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,KAAK;IAPxB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA8B;IACrD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA+B;gBAGpC,SAAS,EAAE,cAAc,EAAE,EAC3B,YAAY,EAAE,mBAAmB,EACjC,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK;IAG/B;;;;OAIG;IACH,GAAG,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO;IAUjC;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAe5B;;OAEG;IACG,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAU9B;;;OAGG;IACG,SAAS,CAAC,SAAS,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IA4B/D;;;OAGG;IACG,IAAI,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAcvC;;OAEG;IACH,MAAM,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAcnC;;;OAGG;IACH,OAAO,CACL,UAAU,EAAE,kBAAkB,EAC9B,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,EAAE,CAAC;IAclB;;;OAGG;IACH,IAAI,CACF,UAAU,EAAE,kBAAkB,EAC9B,IAAI,EAAE,SAAS,EACf,EAAE,EAAE,SAAS,EACb,QAAQ,EAAE,iBAAiB,GAC1B,OAAO,CAAC,IAAI,CAAC;CAajB"}
|
|
@@ -10,8 +10,8 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.AdapterAggregate = void 0;
|
|
13
|
+
const adapter_1 = require("../adapter");
|
|
13
14
|
const shared_1 = require("../shared");
|
|
14
|
-
const error_1 = require("./error");
|
|
15
15
|
/**
|
|
16
16
|
* Manages instances of all adapters provided in session descriptor.
|
|
17
17
|
* Awakes and disposes adapters, routes and executes commands.
|
|
@@ -22,6 +22,7 @@ class AdapterAggregate {
|
|
|
22
22
|
this.timeProvider = timeProvider;
|
|
23
23
|
this.store = store;
|
|
24
24
|
this.cache = cache;
|
|
25
|
+
this.logger = (0, shared_1.log)(AdapterAggregate.name);
|
|
25
26
|
this.adapter = {};
|
|
26
27
|
}
|
|
27
28
|
/**
|
|
@@ -32,7 +33,7 @@ class AdapterAggregate {
|
|
|
32
33
|
get(adapterName) {
|
|
33
34
|
const adapter = this.adapter[adapterName];
|
|
34
35
|
if (!adapter) {
|
|
35
|
-
throw
|
|
36
|
+
throw new adapter_1.AdapterNotFoundError(adapterName);
|
|
36
37
|
}
|
|
37
38
|
return adapter;
|
|
38
39
|
}
|
|
@@ -48,7 +49,7 @@ class AdapterAggregate {
|
|
|
48
49
|
yield adapter.account();
|
|
49
50
|
}
|
|
50
51
|
catch (error) {
|
|
51
|
-
|
|
52
|
+
this.logger.error(`unable to awake for ${adapter.name}`, error);
|
|
52
53
|
}
|
|
53
54
|
this.adapter[adapter.name] = adapter;
|
|
54
55
|
}
|
|
@@ -64,7 +65,7 @@ class AdapterAggregate {
|
|
|
64
65
|
yield adapter.dispose();
|
|
65
66
|
}
|
|
66
67
|
catch (error) {
|
|
67
|
-
|
|
68
|
+
this.logger.error(`unable to dispose for ${adapter.name}`, error);
|
|
68
69
|
}
|
|
69
70
|
}
|
|
70
71
|
});
|
|
@@ -90,7 +91,7 @@ class AdapterAggregate {
|
|
|
90
91
|
yield this.get(adapterName).subscribe(grouped[adapterName]);
|
|
91
92
|
}
|
|
92
93
|
catch (error) {
|
|
93
|
-
|
|
94
|
+
this.logger.error(`unable to subscribe for ${adapterName}`, grouped[adapterName], error);
|
|
94
95
|
throw error;
|
|
95
96
|
}
|
|
96
97
|
}
|
|
@@ -103,12 +104,12 @@ class AdapterAggregate {
|
|
|
103
104
|
open(order) {
|
|
104
105
|
return __awaiter(this, void 0, void 0, function* () {
|
|
105
106
|
const { adapterName } = order.instrument.base;
|
|
106
|
-
|
|
107
|
+
this.logger.debug(`opening a new order on ${order.instrument.id} as ${order.id}`);
|
|
107
108
|
try {
|
|
108
109
|
yield this.get(adapterName).open(order);
|
|
109
110
|
}
|
|
110
111
|
catch (error) {
|
|
111
|
-
|
|
112
|
+
this.logger.error(`unable to open a new order for ${adapterName}`, order, error);
|
|
112
113
|
throw error;
|
|
113
114
|
}
|
|
114
115
|
});
|
|
@@ -118,12 +119,12 @@ class AdapterAggregate {
|
|
|
118
119
|
*/
|
|
119
120
|
cancel(order) {
|
|
120
121
|
const { adapterName } = order.instrument.base;
|
|
121
|
-
|
|
122
|
+
this.logger.debug(`canceling a ${order.id} order`);
|
|
122
123
|
try {
|
|
123
124
|
return this.get(adapterName).cancel(order);
|
|
124
125
|
}
|
|
125
126
|
catch (error) {
|
|
126
|
-
|
|
127
|
+
this.logger.error(`unable to cancel a order for ${adapterName}`, order, error);
|
|
127
128
|
throw error;
|
|
128
129
|
}
|
|
129
130
|
}
|
|
@@ -136,7 +137,7 @@ class AdapterAggregate {
|
|
|
136
137
|
return this.get(instrument.base.adapterName).history(instrument, timeframe, length);
|
|
137
138
|
}
|
|
138
139
|
catch (error) {
|
|
139
|
-
|
|
140
|
+
this.logger.error(`unable to get history ${instrument.base.adapterName}`, { instrument, timeframe, length }, error);
|
|
140
141
|
throw error;
|
|
141
142
|
}
|
|
142
143
|
}
|
|
@@ -149,7 +150,7 @@ class AdapterAggregate {
|
|
|
149
150
|
return this.get(instrument.base.adapterName).feed(instrument, from, to, callback);
|
|
150
151
|
}
|
|
151
152
|
catch (error) {
|
|
152
|
-
|
|
153
|
+
this.logger.error(`unable to get feed ${instrument.base.adapterName}`, { instrument, from, to }, error);
|
|
153
154
|
throw error;
|
|
154
155
|
}
|
|
155
156
|
}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { PaperAdapter, PaperEngine } from '../adapter';
|
|
2
|
+
import { InstrumentSelector, Ohlc, Order } from '../domain';
|
|
2
3
|
import { timestamp } from '../shared';
|
|
3
4
|
import { Cache, StorageEvent } from '../storage';
|
|
4
5
|
import { Store } from '../store';
|
|
5
|
-
import { PaperAdapter } from './paper';
|
|
6
|
-
import { PaperEngine } from './paper/engine/paper-engine';
|
|
7
6
|
export declare type AdapterTimeProvider = {
|
|
8
7
|
timestamp: () => number;
|
|
9
8
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../src/adapter/adapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../src/adapter/adapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAC9D,OAAO,EAAO,SAAS,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAEnC,oBAAY,mBAAmB,GAAG;IAChC,SAAS,EAAE,MAAM,MAAM,CAAC;CACzB,CAAC;AAEF,eAAO,MAAM,mBAAmB;;CAE/B,CAAC;AAEF,oBAAY,iBAAiB,GAAG,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,IAAI,CAAC;AAEnF,oBAAY,cAAc,GAAG,CAC3B,YAAY,EAAE,mBAAmB,EACjC,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK,KACT,OAAO,CAAC;AAEb;;;GAGG;AACH,8BAAsB,OAAO;IAOf,OAAO,CAAC,QAAQ,CAAC,YAAY;IANzC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IAEtB,SAAS,IAAI,SAAS;gBAIO,YAAY,EAAE,mBAAmB;IAE9D;;OAEG;IACH,QAAQ,CAAC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAE/B;;OAEG;IACH,QAAQ,CAAC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAEjC;;;OAGG;IACH,QAAQ,CAAC,SAAS,CAAC,WAAW,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAEpE;;OAEG;IACH,QAAQ,CAAC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAEjC;;;OAGG;IACH,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAE1C;;OAEG;IACH,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAE5C,QAAQ,CAAC,OAAO,CACd,UAAU,EAAE,kBAAkB,EAC9B,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,EAAE,CAAC;IAElB,QAAQ,CAAC,IAAI,CACX,UAAU,EAAE,kBAAkB,EAC9B,IAAI,EAAE,SAAS,EACf,EAAE,EAAE,SAAS,EACb,QAAQ,EAAE,iBAAiB,GAC1B,OAAO,CAAC,IAAI,CAAC;IAEhB,QAAQ,CAAC,iBAAiB,CAAC,OAAO,EAAE,YAAY,GAAG,WAAW;CAC/D"}
|
|
@@ -1,11 +1,7 @@
|
|
|
1
|
+
import { Adapter, AdapterFactory, BacktesterStreamer, FeedAsyncCallback, PaperAdapter, PaperEngine, PaperOptions } from '../../adapter';
|
|
1
2
|
import { InstrumentSelector, Ohlc, Order } from '../../domain';
|
|
2
3
|
import { timestamp } from '../../shared';
|
|
3
4
|
import { Store } from '../../store';
|
|
4
|
-
import { Adapter } from '..';
|
|
5
|
-
import { AdapterFactory, FeedAsyncCallback } from '../adapter';
|
|
6
|
-
import { PaperAdapter, PaperOptions } from '../paper';
|
|
7
|
-
import { PaperEngine } from '../paper/engine/paper-engine';
|
|
8
|
-
import { BacktesterStreamer } from './backtester-streamer';
|
|
9
5
|
export interface BacktesterOptions extends PaperOptions {
|
|
10
6
|
from: timestamp;
|
|
11
7
|
to: timestamp;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"backtester-adapter.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/backtester-adapter.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"backtester-adapter.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/backtester-adapter.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,EACP,cAAc,EACd,kBAAkB,EAClB,iBAAiB,EACjB,YAAY,EACZ,WAAW,EACX,YAAY,EACb,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAA+B,KAAK,EAAE,MAAM,YAAY,CAAC;AAEhE,MAAM,WAAW,iBAAkB,SAAQ,YAAY;IACrD,IAAI,EAAE,SAAS,CAAC;IAChB,EAAE,EAAE,SAAS,CAAC;CACf;AAED,wBAAgB,8BAA8B,CAC5C,uBAAuB,EAAE,cAAc,EACvC,QAAQ,EAAE,kBAAkB,GAC3B,cAAc,CAOhB;AAED,qBAAa,iBAAkB,SAAQ,OAAO;IAI1C,QAAQ,CAAC,gBAAgB,EAAE,OAAO;IAClC,QAAQ,CAAC,QAAQ,EAAE,kBAAkB;IACrC,QAAQ,CAAC,KAAK,EAAE,KAAK;IALvB,QAAQ,CAAC,IAAI,SAA8B;gBAGhC,gBAAgB,EAAE,OAAO,EACzB,QAAQ,EAAE,kBAAkB,EAC5B,KAAK,EAAE,KAAK;IAKjB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAI5B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAIlB,SAAS,CAAC,WAAW,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAYjE,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAIxB,IAAI,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAIjC,MAAM,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC;IAI7B,OAAO,CACX,UAAU,EAAE,kBAAkB,EAC9B,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,EAAE,CAAC;IAUlB,IAAI,CACF,UAAU,EAAE,kBAAkB,EAC9B,IAAI,EAAE,SAAS,EACf,EAAE,EAAE,SAAS,EACb,QAAQ,EAAE,iBAAiB,GAC1B,OAAO,CAAC,IAAI,CAAC;IAIhB,iBAAiB,CAAC,OAAO,EAAE,YAAY,GAAG,WAAW;CAGtD"}
|
|
@@ -10,13 +10,13 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.BacktesterAdapter = exports.createBacktesterAdapterFactory = void 0;
|
|
13
|
+
const adapter_1 = require("../../adapter");
|
|
13
14
|
const store_1 = require("../../store");
|
|
14
|
-
const __1 = require("..");
|
|
15
15
|
function createBacktesterAdapterFactory(decoratedAdapterFactory, streamer) {
|
|
16
16
|
return (timeProvider, store, cache) => new BacktesterAdapter(decoratedAdapterFactory(timeProvider, store, cache), streamer, store);
|
|
17
17
|
}
|
|
18
18
|
exports.createBacktesterAdapterFactory = createBacktesterAdapterFactory;
|
|
19
|
-
class BacktesterAdapter extends
|
|
19
|
+
class BacktesterAdapter extends adapter_1.Adapter {
|
|
20
20
|
constructor(decoratedAdapter, streamer, store) {
|
|
21
21
|
super(streamer.getTimeProvider());
|
|
22
22
|
this.decoratedAdapter = decoratedAdapter;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"backtester-cursor.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/backtester-cursor.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"backtester-cursor.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/backtester-cursor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAElD,qBAAa,gBAAgB;IASf,QAAQ,CAAC,UAAU,EAAE,kBAAkB;IAAE,OAAO,CAAC,QAAQ,CAAC,IAAI;IAR1E,OAAO,CAAC,IAAI,CAA6B;IACzC,OAAO,CAAC,SAAS,CAAK;IACtB,SAAS,UAAS;IAElB,IAAI,IAAI,IAAI,MAAM,CAEjB;gBAEoB,UAAU,EAAE,kBAAkB,EAAmB,IAAI,EAAE,IAAI;IAEhF,IAAI,IAAI,YAAY,GAAG,SAAS;IAQhC,OAAO,IAAI,YAAY;IAIjB,aAAa,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAkBhE"}
|
|
@@ -10,7 +10,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.BacktesterCursor = void 0;
|
|
13
|
-
const
|
|
13
|
+
const adapter_1 = require("../../adapter");
|
|
14
14
|
class BacktesterCursor {
|
|
15
15
|
constructor(instrument, feed) {
|
|
16
16
|
this.instrument = instrument;
|
|
@@ -37,7 +37,7 @@ class BacktesterCursor {
|
|
|
37
37
|
return;
|
|
38
38
|
}
|
|
39
39
|
if (this.size > 0) {
|
|
40
|
-
throw
|
|
40
|
+
throw new adapter_1.BacktestPageNotEmpty();
|
|
41
41
|
}
|
|
42
42
|
this.pageIndex = 0;
|
|
43
43
|
this.page = yield this.feed.query(this.instrument, {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backtester-cursor.spec.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/backtester-cursor.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,47 @@
|
|
|
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
|
+
const adapter_1 = require("../../adapter");
|
|
13
|
+
const domain_1 = require("../../domain");
|
|
14
|
+
const shared_1 = require("../../shared");
|
|
15
|
+
const storage_1 = require("../../storage");
|
|
16
|
+
const store_1 = require("../../store");
|
|
17
|
+
describe(adapter_1.BacktesterCursor.name, () => {
|
|
18
|
+
test('should repeat specific events', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
19
|
+
const instrument = (0, domain_1.instrumentOf)('binance:btc-usdt');
|
|
20
|
+
const feed = new storage_1.Feed(new storage_1.InMemoryStorage());
|
|
21
|
+
const cursor = new adapter_1.BacktesterCursor(instrument, feed);
|
|
22
|
+
feed.save([
|
|
23
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(1), (0, shared_1.d)(1), 1),
|
|
24
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(2), (0, shared_1.d)(2), 2),
|
|
25
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(3), (0, shared_1.d)(3), 3),
|
|
26
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(4), (0, shared_1.d)(4), 4),
|
|
27
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(5), (0, shared_1.d)(5), 5),
|
|
28
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(6), (0, shared_1.d)(6), 6),
|
|
29
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(7), (0, shared_1.d)(7), 7),
|
|
30
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(8), (0, shared_1.d)(8), 8)
|
|
31
|
+
]);
|
|
32
|
+
yield cursor.fetchNextPage(0, 4);
|
|
33
|
+
expect(cursor.dequeue()).toEqual(new store_1.TradePatchEvent(instrument, (0, shared_1.d)(1), (0, shared_1.d)(1), 1));
|
|
34
|
+
expect(cursor.dequeue()).toEqual(new store_1.TradePatchEvent(instrument, (0, shared_1.d)(2), (0, shared_1.d)(2), 2));
|
|
35
|
+
expect(cursor.dequeue()).toEqual(new store_1.TradePatchEvent(instrument, (0, shared_1.d)(3), (0, shared_1.d)(3), 3));
|
|
36
|
+
expect(cursor.peek()).toEqual(undefined);
|
|
37
|
+
yield cursor.fetchNextPage(3, 7);
|
|
38
|
+
expect(cursor.dequeue()).toEqual(new store_1.TradePatchEvent(instrument, (0, shared_1.d)(4), (0, shared_1.d)(4), 4));
|
|
39
|
+
expect(cursor.dequeue()).toEqual(new store_1.TradePatchEvent(instrument, (0, shared_1.d)(5), (0, shared_1.d)(5), 5));
|
|
40
|
+
expect(cursor.dequeue()).toEqual(new store_1.TradePatchEvent(instrument, (0, shared_1.d)(6), (0, shared_1.d)(6), 6));
|
|
41
|
+
expect(cursor.peek()).toEqual(undefined);
|
|
42
|
+
yield cursor.fetchNextPage(6, 10);
|
|
43
|
+
expect(cursor.dequeue()).toEqual(new store_1.TradePatchEvent(instrument, (0, shared_1.d)(7), (0, shared_1.d)(7), 7));
|
|
44
|
+
expect(cursor.dequeue()).toEqual(new store_1.TradePatchEvent(instrument, (0, shared_1.d)(8), (0, shared_1.d)(8), 8));
|
|
45
|
+
expect(cursor.peek()).toEqual(undefined);
|
|
46
|
+
}));
|
|
47
|
+
});
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
+
import { AdapterTimeProvider } from '../../adapter';
|
|
1
2
|
import { InstrumentSelector } from '../../domain';
|
|
2
3
|
import { timestamp } from '../../shared';
|
|
3
4
|
import { Feed } from '../../storage';
|
|
4
5
|
import { Store } from '../../store';
|
|
5
|
-
import { AdapterTimeProvider } from '../adapter';
|
|
6
6
|
/**
|
|
7
7
|
* Listen to backtest session events.
|
|
8
8
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"backtester-streamer.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/backtester-streamer.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"backtester-streamer.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/backtester-streamer.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EAIpB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AACpC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAEnC;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC;;OAEG;IACH,iBAAiB,CAAC,CAAC,QAAQ,EAAE,kBAAkB,GAAG,IAAI,CAAC;IAEvD;;OAEG;IACH,iBAAiB,CAAC,CAAC,QAAQ,EAAE,kBAAkB,GAAG,IAAI,CAAC;IAEvD;;OAEG;IACH,mBAAmB,CAAC,CAAC,QAAQ,EAAE,kBAAkB,GAAG,IAAI,CAAC;CAC1D;AAED,qBAAa,kBAAkB;IAS3B,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC;IAX5B,OAAO,CAAC,mBAAmB,CAAS;IACpC,OAAO,CAAC,MAAM,CAAwC;IACtD,OAAO,CAAC,WAAW,CAAK;IAExB,SAAS,EAAE,SAAS,CAAC;IACrB,QAAQ,SAAK;gBAGM,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,IAAI,EACV,MAAM,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,EAAE,EAAE,MAAM,CAAA;KAAE,EACpC,QAAQ,CAAC,gCAAoB;IAShD,eAAe,IAAI,mBAAmB;IAQtC,SAAS,CAAC,UAAU,EAAE,kBAAkB;IAUxC;;OAEG;IACH,IAAI;IAIJ;;OAEG;IACH,WAAW;YAsCG,WAAW;YAwBX,OAAO;CAetB"}
|
|
@@ -10,8 +10,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.BacktesterStreamer = void 0;
|
|
13
|
-
const
|
|
14
|
-
const error_1 = require("./error");
|
|
13
|
+
const adapter_1 = require("../../adapter");
|
|
15
14
|
class BacktesterStreamer {
|
|
16
15
|
constructor(store, feed, period, listener) {
|
|
17
16
|
this.store = store;
|
|
@@ -23,7 +22,7 @@ class BacktesterStreamer {
|
|
|
23
22
|
this.stopAcquire = 1;
|
|
24
23
|
this.sequence = 0;
|
|
25
24
|
if (period.from == undefined || period.to == undefined) {
|
|
26
|
-
throw
|
|
25
|
+
throw new adapter_1.MissingPeriodParametersError();
|
|
27
26
|
}
|
|
28
27
|
this.timestamp = period.from;
|
|
29
28
|
}
|
|
@@ -37,7 +36,7 @@ class BacktesterStreamer {
|
|
|
37
36
|
if (instrument.id in this.cursor) {
|
|
38
37
|
return;
|
|
39
38
|
}
|
|
40
|
-
const cursor = new
|
|
39
|
+
const cursor = new adapter_1.BacktesterCursor(instrument, this.feed);
|
|
41
40
|
this.cursor[instrument.id] = cursor;
|
|
42
41
|
}
|
|
43
42
|
/**
|
|
@@ -97,7 +96,7 @@ class BacktesterStreamer {
|
|
|
97
96
|
this.sequence++;
|
|
98
97
|
this.store.dispatch(event);
|
|
99
98
|
if (cursor.dequeue().timestamp != event.timestamp) {
|
|
100
|
-
throw
|
|
99
|
+
throw new adapter_1.InvalidEventSequenceError();
|
|
101
100
|
}
|
|
102
101
|
return true;
|
|
103
102
|
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backtester-streamer.spec.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/backtester-streamer.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const adapter_1 = require("../../adapter");
|
|
4
|
+
const domain_1 = require("../../domain");
|
|
5
|
+
const shared_1 = require("../../shared");
|
|
6
|
+
const storage_1 = require("../../storage");
|
|
7
|
+
const store_1 = require("../../store");
|
|
8
|
+
describe(adapter_1.BacktesterStreamer.name, () => {
|
|
9
|
+
const instrument = new domain_1.Instrument(0, new domain_1.Asset('btc', 'binance', 8), new domain_1.Asset('usdt', 'binance', 2), 'binance:btc-usdt', domain_1.Commission.Zero);
|
|
10
|
+
test('should repeat specific events', done => {
|
|
11
|
+
const feed = new storage_1.Feed(new storage_1.InMemoryStorage());
|
|
12
|
+
const store = new store_1.Store();
|
|
13
|
+
store.snapshot.universe.instrument.upsert(instrument);
|
|
14
|
+
store.snapshot.subscription.instrument.upsert(instrument);
|
|
15
|
+
const streamer = new adapter_1.BacktesterStreamer(store, feed, {
|
|
16
|
+
from: 0,
|
|
17
|
+
to: 10
|
|
18
|
+
}, {
|
|
19
|
+
onBacktestCompleted: () => {
|
|
20
|
+
var _a;
|
|
21
|
+
const trade = (_a = store.snapshot.trade.get(instrument.id)) !== null && _a !== void 0 ? _a : fail();
|
|
22
|
+
expect(trade.timestamp).toEqual(8);
|
|
23
|
+
expect(trade.rate).toEqual((0, shared_1.d)(8));
|
|
24
|
+
expect(trade.quantity).toEqual((0, shared_1.d)(8));
|
|
25
|
+
expect(store.snapshot.timestamp).toEqual(8);
|
|
26
|
+
done();
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
feed
|
|
30
|
+
.save([
|
|
31
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(1), (0, shared_1.d)(1), 1),
|
|
32
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(2), (0, shared_1.d)(2), 2),
|
|
33
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(3), (0, shared_1.d)(3), 3),
|
|
34
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(4), (0, shared_1.d)(4), 4),
|
|
35
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(5), (0, shared_1.d)(5), 5),
|
|
36
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(6), (0, shared_1.d)(6), 6),
|
|
37
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(7), (0, shared_1.d)(7), 7),
|
|
38
|
+
new store_1.TradePatchEvent(instrument, (0, shared_1.d)(8), (0, shared_1.d)(8), 8)
|
|
39
|
+
])
|
|
40
|
+
.then(() => {
|
|
41
|
+
streamer.subscribe(instrument);
|
|
42
|
+
streamer.tryContinue();
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
});
|
|
@@ -1,3 +1,7 @@
|
|
|
1
|
-
export declare
|
|
2
|
-
|
|
1
|
+
export declare class MissingPeriodParametersError extends Error {
|
|
2
|
+
constructor();
|
|
3
|
+
}
|
|
4
|
+
export declare class InvalidEventSequenceError extends Error {
|
|
5
|
+
constructor();
|
|
6
|
+
}
|
|
3
7
|
//# sourceMappingURL=error.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/error.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/error.ts"],"names":[],"mappings":"AAAA,qBAAa,4BAA6B,SAAQ,KAAK;;CAItD;AAED,qBAAa,yBAA0B,SAAQ,KAAK;;CAInD"}
|
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
exports.InvalidEventSequenceError = exports.MissingPeriodParametersError = void 0;
|
|
4
|
+
class MissingPeriodParametersError extends Error {
|
|
5
|
+
constructor() {
|
|
6
|
+
super('invalid backtest options, please provide from and to period.');
|
|
7
|
+
}
|
|
6
8
|
}
|
|
7
|
-
exports.
|
|
8
|
-
|
|
9
|
-
|
|
9
|
+
exports.MissingPeriodParametersError = MissingPeriodParametersError;
|
|
10
|
+
class InvalidEventSequenceError extends Error {
|
|
11
|
+
constructor() {
|
|
12
|
+
super('invalid event to consume');
|
|
13
|
+
}
|
|
10
14
|
}
|
|
11
|
-
exports.
|
|
15
|
+
exports.InvalidEventSequenceError = InvalidEventSequenceError;
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
-
export * from '
|
|
2
|
-
export * from '
|
|
1
|
+
export * from '../../adapter/backtester/backtester-adapter';
|
|
2
|
+
export * from '../../adapter/backtester/backtester-streamer';
|
|
3
|
+
export * from '../../adapter/backtester/backtester-cursor';
|
|
4
|
+
export * from '../../adapter/backtester/error';
|
|
3
5
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/adapter/backtester/index.ts"],"names":[],"mappings":"AAAA,cAAc,4CAA4C,CAAC;AAC3D,cAAc,6CAA6C,CAAC;AAC5D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,+BAA+B,CAAC"}
|
|
@@ -14,5 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("
|
|
18
|
-
__exportStar(require("
|
|
17
|
+
__exportStar(require("../../adapter/backtester/backtester-adapter"), exports);
|
|
18
|
+
__exportStar(require("../../adapter/backtester/backtester-streamer"), exports);
|
|
19
|
+
__exportStar(require("../../adapter/backtester/backtester-cursor"), exports);
|
|
20
|
+
__exportStar(require("../../adapter/backtester/error"), exports);
|
package/dist/adapter/error.d.ts
CHANGED
|
@@ -1,4 +1,10 @@
|
|
|
1
|
-
export declare
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
export declare class AdapterNotFoundError extends Error {
|
|
2
|
+
constructor(adapterName: string);
|
|
3
|
+
}
|
|
4
|
+
export declare class NoPaperEngineProvidedError extends Error {
|
|
5
|
+
constructor();
|
|
6
|
+
}
|
|
7
|
+
export declare class BacktestPageNotEmpty extends Error {
|
|
8
|
+
constructor();
|
|
9
|
+
}
|
|
4
10
|
//# sourceMappingURL=error.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../src/adapter/error.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../src/adapter/error.ts"],"names":[],"mappings":"AAAA,qBAAa,oBAAqB,SAAQ,KAAK;gBACjC,WAAW,EAAE,MAAM;CAKhC;AAED,qBAAa,0BAA2B,SAAQ,KAAK;;CAIpD;AAED,qBAAa,oBAAqB,SAAQ,KAAK;;CAI9C"}
|
package/dist/adapter/error.js
CHANGED
|
@@ -1,15 +1,21 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
exports.BacktestPageNotEmpty = exports.NoPaperEngineProvidedError = exports.AdapterNotFoundError = void 0;
|
|
4
|
+
class AdapterNotFoundError extends Error {
|
|
5
|
+
constructor(adapterName) {
|
|
6
|
+
super(`Unknown adapter: ${adapterName}. You should provide adapter in session descriptor.`);
|
|
7
|
+
}
|
|
6
8
|
}
|
|
7
|
-
exports.
|
|
8
|
-
|
|
9
|
-
|
|
9
|
+
exports.AdapterNotFoundError = AdapterNotFoundError;
|
|
10
|
+
class NoPaperEngineProvidedError extends Error {
|
|
11
|
+
constructor() {
|
|
12
|
+
super('No paper engine provided.');
|
|
13
|
+
}
|
|
10
14
|
}
|
|
11
|
-
exports.
|
|
12
|
-
|
|
13
|
-
|
|
15
|
+
exports.NoPaperEngineProvidedError = NoPaperEngineProvidedError;
|
|
16
|
+
class BacktestPageNotEmpty extends Error {
|
|
17
|
+
constructor() {
|
|
18
|
+
super('Backtest page is not empty');
|
|
19
|
+
}
|
|
14
20
|
}
|
|
15
|
-
exports.
|
|
21
|
+
exports.BacktestPageNotEmpty = BacktestPageNotEmpty;
|
package/dist/adapter/index.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
export * from '
|
|
2
|
-
export * from '
|
|
3
|
-
export * from '
|
|
4
|
-
export * from '
|
|
1
|
+
export * from '../adapter/adapter';
|
|
2
|
+
export * from '../adapter/adapter-aggregate';
|
|
3
|
+
export * from '../adapter/backtester';
|
|
4
|
+
export * from '../adapter/paper';
|
|
5
|
+
export * from '../adapter/error';
|
|
5
6
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/adapter/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/adapter/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,yBAAyB,CAAC;AACxC,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC"}
|
package/dist/adapter/index.js
CHANGED
|
@@ -14,7 +14,8 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("
|
|
18
|
-
__exportStar(require("
|
|
19
|
-
__exportStar(require("
|
|
20
|
-
__exportStar(require("
|
|
17
|
+
__exportStar(require("../adapter/adapter"), exports);
|
|
18
|
+
__exportStar(require("../adapter/adapter-aggregate"), exports);
|
|
19
|
+
__exportStar(require("../adapter/backtester"), exports);
|
|
20
|
+
__exportStar(require("../adapter/paper"), exports);
|
|
21
|
+
__exportStar(require("../adapter/error"), exports);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"paper-engine.d.ts","sourceRoot":"","sources":["../../../../src/adapter/paper/engine/paper-engine.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAoB,MAAM,
|
|
1
|
+
{"version":3,"file":"paper-engine.d.ts","sourceRoot":"","sources":["../../../../src/adapter/paper/engine/paper-engine.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAoB,MAAM,aAAa,CAAC;AAEtD,OAAO,EAQL,KAAK,EACN,MAAM,YAAY,CAAC;AAEpB,qBAAa,WAAW;IACV,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,KAAK;IAclC,IAAI,CAAC,KAAK,EAAE,KAAK;IAYjB,MAAM,CAAC,KAAK,EAAE,KAAK;IAQ1B,OAAO,CAAC,WAAW;IA2BnB,OAAO,CAAC,OAAO;IAuBf,OAAO,CAAC,aAAa;CAmCtB"}
|
|
@@ -5,16 +5,15 @@ const rxjs_1 = require("rxjs");
|
|
|
5
5
|
const domain_1 = require("../../../domain");
|
|
6
6
|
const shared_1 = require("../../../shared");
|
|
7
7
|
const store_1 = require("../../../store");
|
|
8
|
-
const error_1 = require("../../../store/error");
|
|
9
8
|
class PaperEngine {
|
|
10
9
|
constructor(store) {
|
|
11
10
|
this.store = store;
|
|
12
11
|
store.changes$
|
|
13
12
|
.pipe((0, rxjs_1.tap)(it => {
|
|
14
|
-
if (it
|
|
13
|
+
if (it.type === domain_1.Orderbook.type) {
|
|
15
14
|
this.onOrderbook(it);
|
|
16
15
|
}
|
|
17
|
-
else if (it
|
|
16
|
+
else if (it.type === domain_1.Trade.type) {
|
|
18
17
|
this.onTrade(it);
|
|
19
18
|
}
|
|
20
19
|
}))
|
|
@@ -23,17 +22,17 @@ class PaperEngine {
|
|
|
23
22
|
open(order) {
|
|
24
23
|
const { timestamp } = this.store.snapshot;
|
|
25
24
|
try {
|
|
26
|
-
this.store.dispatch(new store_1.OrderNewEvent(order, timestamp)
|
|
25
|
+
this.store.dispatch(new store_1.OrderNewEvent(order, timestamp));
|
|
27
26
|
this.store.dispatch(new store_1.OrderPendingEvent(order.id, order.instrument, timestamp));
|
|
28
27
|
}
|
|
29
28
|
catch (error) {
|
|
30
|
-
this.store.dispatch(new store_1.
|
|
29
|
+
this.store.dispatch(new store_1.OrderRejectedEvent(order.id, order.instrument, timestamp));
|
|
31
30
|
}
|
|
32
31
|
}
|
|
33
32
|
cancel(order) {
|
|
34
33
|
const { timestamp } = this.store.snapshot;
|
|
35
34
|
this.store.dispatch(new store_1.OrderCancelingEvent(order.id, order.instrument, timestamp));
|
|
36
|
-
this.store.dispatch(new store_1.
|
|
35
|
+
this.store.dispatch(new store_1.OrderCanceledEvent(order.id, order.instrument, timestamp));
|
|
37
36
|
}
|
|
38
37
|
onOrderbook(orderbook) {
|
|
39
38
|
const orders = this.store.snapshot.order.get(orderbook.instrument.id);
|
|
@@ -88,7 +87,7 @@ class PaperEngine {
|
|
|
88
87
|
const { timestamp } = this.store.snapshot;
|
|
89
88
|
const instrument = this.store.snapshot.universe.instrument.get(order.instrument.id);
|
|
90
89
|
if (!instrument) {
|
|
91
|
-
throw
|
|
90
|
+
throw new store_1.InstrumentNotSupportedError(order.instrument);
|
|
92
91
|
}
|
|
93
92
|
const transacted = {
|
|
94
93
|
base: shared_1.d.Zero,
|
|
@@ -103,7 +102,7 @@ class PaperEngine {
|
|
|
103
102
|
transacted.base = transacted.base.minus(instrument.base.floor(qty));
|
|
104
103
|
transacted.quote = transacted.quote.plus(instrument.quote.floor(instrument.commission.applyMakerFee(averageExecutionRate.mul(qty))));
|
|
105
104
|
}
|
|
106
|
-
this.store.dispatch(new store_1.
|
|
105
|
+
this.store.dispatch(new store_1.OrderFilledEvent(order.id, order.instrument, averageExecutionRate, timestamp));
|
|
107
106
|
}
|
|
108
107
|
}
|
|
109
108
|
exports.PaperEngine = PaperEngine;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"paper-engine.spec.d.ts","sourceRoot":"","sources":["../../../../src/adapter/paper/engine/paper-engine.spec.ts"],"names":[],"mappings":""}
|