@quantform/core 0.6.6 → 0.7.0-beta.4

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.
Files changed (521) hide show
  1. package/dist/as-readonly.d.ts +3 -0
  2. package/dist/as-readonly.d.ts.map +1 -0
  3. package/dist/as-readonly.js +8 -0
  4. package/dist/{domain → asset}/asset.d.ts +6 -1
  5. package/dist/asset/asset.d.ts.map +1 -0
  6. package/dist/{domain → asset}/asset.js +16 -7
  7. package/dist/asset/asset.spec.d.ts +2 -0
  8. package/dist/asset/asset.spec.d.ts.map +1 -0
  9. package/dist/asset/asset.spec.js +54 -0
  10. package/dist/asset/index.d.ts +2 -0
  11. package/dist/asset/index.d.ts.map +1 -0
  12. package/dist/{adapter/paper → asset}/index.js +1 -2
  13. package/dist/cli/build.js +1 -1
  14. package/dist/cli/dev.d.ts.map +1 -1
  15. package/dist/cli/dev.js +15 -11
  16. package/dist/cli/index.js +8 -8
  17. package/dist/cli/internal/workspace.js +1 -1
  18. package/dist/cli/pull.d.ts.map +1 -1
  19. package/dist/cli/pull.js +50 -20
  20. package/dist/cli/{test.d.ts → replay.d.ts} +1 -1
  21. package/dist/cli/replay.d.ts.map +1 -0
  22. package/dist/cli/{test.js → replay.js} +18 -20
  23. package/dist/cli/run.d.ts.map +1 -1
  24. package/dist/cli/run.js +16 -11
  25. package/dist/component/distinct-until-timesamp-changed.d.ts +5 -0
  26. package/dist/component/distinct-until-timesamp-changed.d.ts.map +1 -0
  27. package/dist/component/distinct-until-timesamp-changed.js +9 -0
  28. package/dist/component/error.d.ts +17 -0
  29. package/dist/component/error.d.ts.map +1 -0
  30. package/dist/component/error.js +33 -0
  31. package/dist/component/index.d.ts +8 -0
  32. package/dist/component/index.d.ts.map +1 -0
  33. package/dist/{store → component}/index.js +7 -9
  34. package/dist/{domain → component}/ohlc-operator.d.ts +1 -1
  35. package/dist/component/ohlc-operator.d.ts.map +1 -0
  36. package/dist/{domain → component}/ohlc-operator.js +4 -5
  37. package/dist/component/ohlc-operator.spec.d.ts +2 -0
  38. package/dist/component/ohlc-operator.spec.d.ts.map +1 -0
  39. package/dist/component/ohlc-operator.spec.js +110 -0
  40. package/dist/component/ohlc.d.ts.map +1 -0
  41. package/dist/component/ohlc.spec.d.ts +2 -0
  42. package/dist/component/ohlc.spec.d.ts.map +1 -0
  43. package/dist/component/ohlc.spec.js +25 -0
  44. package/dist/component/timeframe.d.ts.map +1 -0
  45. package/dist/core.d.ts +3 -0
  46. package/dist/core.d.ts.map +1 -0
  47. package/dist/core.js +15 -0
  48. package/dist/defined.d.ts +3 -0
  49. package/dist/defined.d.ts.map +1 -0
  50. package/dist/defined.js +8 -0
  51. package/dist/exclude.d.ts +3 -0
  52. package/dist/exclude.d.ts.map +1 -0
  53. package/dist/exclude.js +8 -0
  54. package/dist/index.d.ts +25 -27
  55. package/dist/index.d.ts.map +1 -1
  56. package/dist/index.js +25 -66
  57. package/dist/{domain → instrument/commission}/commission.d.ts +1 -1
  58. package/dist/instrument/commission/commission.d.ts.map +1 -0
  59. package/dist/{domain → instrument/commission}/commission.js +2 -2
  60. package/dist/instrument/commission/commission.spec.d.ts +2 -0
  61. package/dist/instrument/commission/commission.spec.d.ts.map +1 -0
  62. package/dist/instrument/commission/commission.spec.js +30 -0
  63. package/dist/instrument/index.d.ts +3 -0
  64. package/dist/instrument/index.d.ts.map +1 -0
  65. package/dist/{adapter → instrument}/index.js +2 -4
  66. package/dist/{domain → instrument}/instrument.d.ts +4 -4
  67. package/dist/instrument/instrument.d.ts.map +1 -0
  68. package/dist/{domain → instrument}/instrument.js +8 -5
  69. package/dist/instrument/instrument.spec.d.ts +2 -0
  70. package/dist/instrument/instrument.spec.d.ts.map +1 -0
  71. package/dist/instrument/instrument.spec.js +51 -0
  72. package/dist/make-test-module.d.ts +13 -0
  73. package/dist/make-test-module.d.ts.map +1 -0
  74. package/dist/make-test-module.js +46 -0
  75. package/dist/module.d.ts +57 -0
  76. package/dist/module.d.ts.map +1 -0
  77. package/dist/module.js +136 -0
  78. package/dist/module.spec.d.ts +2 -0
  79. package/dist/module.spec.d.ts.map +1 -0
  80. package/dist/module.spec.js +86 -0
  81. package/dist/not-found.d.ts +2 -0
  82. package/dist/not-found.d.ts.map +1 -0
  83. package/dist/{domain/component.js → not-found.js} +2 -0
  84. package/dist/replay/index.d.ts +7 -0
  85. package/dist/replay/index.d.ts.map +1 -0
  86. package/dist/replay/index.js +22 -0
  87. package/dist/replay/use-replay-coordinator.d.ts +10 -0
  88. package/dist/replay/use-replay-coordinator.d.ts.map +1 -0
  89. package/dist/replay/use-replay-coordinator.js +119 -0
  90. package/dist/replay/use-replay-options.d.ts +15 -0
  91. package/dist/replay/use-replay-options.d.ts.map +1 -0
  92. package/dist/replay/use-replay-options.js +20 -0
  93. package/dist/replay/use-replay-reader.d.ts +7 -0
  94. package/dist/replay/use-replay-reader.d.ts.map +1 -0
  95. package/dist/replay/use-replay-reader.js +32 -0
  96. package/dist/replay/use-replay-reader.spec.d.ts +2 -0
  97. package/dist/replay/use-replay-reader.spec.d.ts.map +1 -0
  98. package/dist/replay/use-replay-reader.spec.js +58 -0
  99. package/dist/replay/use-replay-storage.d.ts +10 -0
  100. package/dist/replay/use-replay-storage.d.ts.map +1 -0
  101. package/dist/replay/use-replay-storage.js +10 -0
  102. package/dist/replay/use-replay-writer.d.ts +6 -0
  103. package/dist/replay/use-replay-writer.d.ts.map +1 -0
  104. package/dist/replay/use-replay-writer.js +14 -0
  105. package/dist/replay/use-replay-writer.spec.d.ts +2 -0
  106. package/dist/replay/use-replay-writer.spec.d.ts.map +1 -0
  107. package/dist/replay/use-replay-writer.spec.js +53 -0
  108. package/dist/replay/use-replay.d.ts +10 -0
  109. package/dist/replay/use-replay.d.ts.map +1 -0
  110. package/dist/replay/use-replay.js +32 -0
  111. package/dist/replay/use-replay.spec.d.ts +2 -0
  112. package/dist/replay/use-replay.spec.d.ts.map +1 -0
  113. package/dist/replay/use-replay.spec.js +106 -0
  114. package/dist/replay/with-replay.d.ts +4 -0
  115. package/dist/replay/with-replay.d.ts.map +1 -0
  116. package/dist/replay/with-replay.js +8 -0
  117. package/dist/session/index.d.ts +4 -0
  118. package/dist/session/index.d.ts.map +1 -0
  119. package/dist/session/index.js +19 -0
  120. package/dist/session/use-session-object.d.ts +18 -0
  121. package/dist/session/use-session-object.d.ts.map +1 -0
  122. package/dist/session/use-session-object.js +13 -0
  123. package/dist/session/use-session-storage.d.ts +2 -0
  124. package/dist/session/use-session-storage.d.ts.map +1 -0
  125. package/dist/session/use-session-storage.js +10 -0
  126. package/dist/session/use-session.d.ts +4 -0
  127. package/dist/session/use-session.d.ts.map +1 -0
  128. package/dist/session/use-session.js +7 -0
  129. package/dist/shared/datetime.d.ts +1 -1
  130. package/dist/shared/datetime.d.ts.map +1 -1
  131. package/dist/shared/decimals.d.ts.map +1 -1
  132. package/dist/shared/decimals.js +5 -0
  133. package/dist/shared/decimals.spec.d.ts +2 -0
  134. package/dist/shared/decimals.spec.d.ts.map +1 -0
  135. package/dist/shared/decimals.spec.js +28 -0
  136. package/dist/shared/index.d.ts +3 -7
  137. package/dist/shared/index.d.ts.map +1 -1
  138. package/dist/shared/index.js +3 -7
  139. package/dist/simulator/index.d.ts +2 -0
  140. package/dist/simulator/index.d.ts.map +1 -0
  141. package/dist/{adapter/backtester → simulator}/index.js +1 -2
  142. package/dist/simulator/use-simulator.d.ts +2 -0
  143. package/dist/simulator/use-simulator.d.ts.map +1 -0
  144. package/dist/simulator/use-simulator.js +9 -0
  145. package/dist/simulator/use-simulator.spec.d.ts +2 -0
  146. package/dist/simulator/use-simulator.spec.d.ts.map +1 -0
  147. package/dist/simulator/use-simulator.spec.js +49 -0
  148. package/dist/storage/in-memory/in-memory-storage.d.ts +9 -0
  149. package/dist/storage/in-memory/in-memory-storage.d.ts.map +1 -0
  150. package/dist/storage/in-memory/in-memory-storage.factory.d.ts +6 -0
  151. package/dist/storage/in-memory/in-memory-storage.factory.d.ts.map +1 -0
  152. package/dist/storage/in-memory/in-memory-storage.factory.js +23 -0
  153. package/dist/storage/in-memory/in-memory-storage.js +72 -0
  154. package/dist/storage/in-memory/in-memory-storage.spec.d.ts +2 -0
  155. package/dist/storage/in-memory/in-memory-storage.spec.d.ts.map +1 -0
  156. package/dist/storage/in-memory/in-memory-storage.spec.js +167 -0
  157. package/dist/storage/in-memory/index.d.ts +3 -0
  158. package/dist/storage/in-memory/index.d.ts.map +1 -0
  159. package/dist/storage/in-memory/index.js +18 -0
  160. package/dist/storage/index.d.ts +3 -3
  161. package/dist/storage/index.d.ts.map +1 -1
  162. package/dist/storage/index.js +3 -3
  163. package/dist/storage/storage.d.ts +51 -61
  164. package/dist/storage/storage.d.ts.map +1 -1
  165. package/dist/storage/storage.js +20 -85
  166. package/dist/storage/use-cache.d.ts +4 -0
  167. package/dist/storage/use-cache.d.ts.map +1 -0
  168. package/dist/storage/use-cache.js +34 -0
  169. package/dist/storage/use-cache.spec.d.ts +2 -0
  170. package/dist/storage/use-cache.spec.d.ts.map +1 -0
  171. package/dist/storage/use-cache.spec.js +36 -0
  172. package/dist/storage/use-storage-factory.d.ts +10 -0
  173. package/dist/storage/use-storage-factory.d.ts.map +1 -0
  174. package/dist/storage/use-storage-factory.js +14 -0
  175. package/dist/storage/use-storage.d.ts +3 -0
  176. package/dist/storage/use-storage.d.ts.map +1 -0
  177. package/dist/storage/use-storage.js +11 -0
  178. package/dist/strat.d.ts +7 -0
  179. package/dist/strat.d.ts.map +1 -0
  180. package/dist/strat.js +7 -0
  181. package/dist/use-execution-mode.d.ts +29 -0
  182. package/dist/use-execution-mode.d.ts.map +1 -0
  183. package/dist/use-execution-mode.js +37 -0
  184. package/dist/use-hash.d.ts +5 -0
  185. package/dist/use-hash.d.ts.map +1 -0
  186. package/dist/use-hash.js +7 -0
  187. package/dist/use-hash.spec.d.ts +2 -0
  188. package/dist/use-hash.spec.d.ts.map +1 -0
  189. package/dist/use-hash.spec.js +16 -0
  190. package/dist/use-lock.d.ts +9 -0
  191. package/dist/use-lock.d.ts.map +1 -0
  192. package/dist/use-lock.js +40 -0
  193. package/dist/use-logger.d.ts +10 -0
  194. package/dist/use-logger.d.ts.map +1 -0
  195. package/dist/use-logger.js +37 -0
  196. package/dist/use-memo.d.ts +21 -0
  197. package/dist/use-memo.d.ts.map +1 -0
  198. package/dist/use-memo.js +35 -0
  199. package/dist/use-memo.spec.d.ts +2 -0
  200. package/dist/use-memo.spec.d.ts.map +1 -0
  201. package/dist/use-memo.spec.js +35 -0
  202. package/dist/use-request.d.ts +16 -0
  203. package/dist/use-request.d.ts.map +1 -0
  204. package/dist/use-request.js +27 -0
  205. package/dist/use-socket.d.ts +6 -0
  206. package/dist/use-socket.d.ts.map +1 -0
  207. package/dist/use-socket.js +52 -0
  208. package/dist/use-state.d.ts +4 -0
  209. package/dist/use-state.d.ts.map +1 -0
  210. package/dist/use-state.js +24 -0
  211. package/dist/use-state.spec.d.ts +2 -0
  212. package/dist/use-state.spec.d.ts.map +1 -0
  213. package/dist/use-state.spec.js +36 -0
  214. package/dist/use-timestamp.d.ts +2 -0
  215. package/dist/use-timestamp.d.ts.map +1 -0
  216. package/dist/use-timestamp.js +13 -0
  217. package/dist/use.d.ts +5 -0
  218. package/dist/use.d.ts.map +1 -0
  219. package/dist/use.js +20 -0
  220. package/dist/use.spec.d.ts +2 -0
  221. package/dist/use.spec.d.ts.map +1 -0
  222. package/dist/use.spec.js +47 -0
  223. package/jest.config.ts +23 -2
  224. package/package.json +14 -11
  225. package/src/as-readonly.ts +5 -0
  226. package/src/{domain → asset}/asset.spec.ts +4 -4
  227. package/src/{domain → asset}/asset.ts +17 -6
  228. package/src/asset/index.ts +1 -0
  229. package/src/cli/build.ts +1 -1
  230. package/src/cli/dev.ts +18 -13
  231. package/src/cli/index.ts +7 -7
  232. package/src/cli/internal/workspace.ts +1 -1
  233. package/src/cli/pull.ts +22 -10
  234. package/src/cli/replay.ts +31 -0
  235. package/src/cli/run.ts +17 -13
  236. package/src/component/distinct-until-timesamp-changed.ts +11 -0
  237. package/src/component/error.ts +32 -0
  238. package/src/component/index.ts +7 -0
  239. package/src/{domain → component}/ohlc-operator.spec.ts +5 -6
  240. package/src/{domain → component}/ohlc-operator.ts +2 -3
  241. package/src/{domain → component}/ohlc.spec.ts +2 -2
  242. package/src/{domain → component}/ohlc.ts +2 -2
  243. package/src/core.ts +14 -0
  244. package/src/defined.ts +6 -0
  245. package/src/exclude.ts +9 -0
  246. package/src/index.ts +27 -80
  247. package/src/{domain → instrument/commission}/commission.spec.ts +4 -3
  248. package/src/{domain → instrument/commission}/commission.ts +1 -1
  249. package/src/instrument/index.ts +2 -0
  250. package/src/{domain → instrument}/instrument.spec.ts +11 -6
  251. package/src/{domain → instrument}/instrument.ts +12 -8
  252. package/src/make-test-module.ts +46 -0
  253. package/src/module.spec.ts +74 -0
  254. package/src/module.ts +156 -0
  255. package/src/not-found.ts +1 -0
  256. package/src/replay/index.ts +6 -0
  257. package/src/replay/use-replay-coordinator.ts +142 -0
  258. package/src/replay/use-replay-options.ts +23 -0
  259. package/src/replay/use-replay-reader.spec.ts +64 -0
  260. package/src/replay/use-replay-reader.ts +23 -0
  261. package/src/replay/use-replay-storage.ts +8 -0
  262. package/src/replay/use-replay-writer.spec.ts +56 -0
  263. package/src/replay/use-replay-writer.ts +17 -0
  264. package/src/replay/use-replay.spec.ts +132 -0
  265. package/src/replay/use-replay.ts +34 -0
  266. package/src/replay/with-replay.ts +10 -0
  267. package/src/session/index.ts +3 -0
  268. package/src/session/use-session-object.ts +26 -0
  269. package/src/session/use-session-storage.ts +9 -0
  270. package/src/session/use-session.ts +5 -0
  271. package/src/shared/decimals.spec.ts +1 -1
  272. package/src/shared/decimals.ts +5 -0
  273. package/src/shared/index.ts +3 -7
  274. package/src/simulator/index.ts +1 -0
  275. package/src/simulator/use-simulator.spec.ts +54 -0
  276. package/src/simulator/use-simulator.ts +7 -0
  277. package/src/storage/in-memory/in-memory-storage.factory.ts +16 -0
  278. package/src/storage/in-memory/in-memory-storage.spec.ts +193 -0
  279. package/src/storage/in-memory/in-memory-storage.ts +80 -0
  280. package/src/storage/in-memory/index.ts +2 -0
  281. package/src/storage/index.ts +3 -3
  282. package/src/storage/storage.ts +63 -119
  283. package/src/storage/use-cache.spec.ts +31 -0
  284. package/src/storage/use-cache.ts +50 -0
  285. package/src/storage/use-storage-factory.ts +17 -0
  286. package/src/storage/use-storage.ts +11 -0
  287. package/src/strat.ts +7 -0
  288. package/src/use-execution-mode.ts +41 -0
  289. package/src/use-hash.spec.ts +16 -0
  290. package/src/use-hash.ts +5 -0
  291. package/src/use-lock.ts +52 -0
  292. package/src/use-logger.ts +47 -0
  293. package/src/use-memo.spec.ts +30 -0
  294. package/src/use-memo.ts +35 -0
  295. package/src/use-request.ts +47 -0
  296. package/src/use-socket.ts +59 -0
  297. package/src/use-state.spec.ts +31 -0
  298. package/src/use-state.ts +30 -0
  299. package/src/use-timestamp.ts +12 -0
  300. package/src/use.spec.ts +46 -0
  301. package/src/use.ts +33 -0
  302. package/tsconfig.json +7 -4
  303. package/dist/adapter/adapter-aggregate.d.ts +0 -57
  304. package/dist/adapter/adapter-aggregate.d.ts.map +0 -1
  305. package/dist/adapter/adapter-aggregate.js +0 -157
  306. package/dist/adapter/adapter.d.ts +0 -54
  307. package/dist/adapter/adapter.d.ts.map +0 -1
  308. package/dist/adapter/adapter.js +0 -20
  309. package/dist/adapter/backtester/backtester-adapter.d.ts +0 -30
  310. package/dist/adapter/backtester/backtester-adapter.d.ts.map +0 -1
  311. package/dist/adapter/backtester/backtester-adapter.js +0 -67
  312. package/dist/adapter/backtester/backtester-cursor.d.ts +0 -16
  313. package/dist/adapter/backtester/backtester-cursor.d.ts.map +0 -1
  314. package/dist/adapter/backtester/backtester-cursor.js +0 -52
  315. package/dist/adapter/backtester/backtester-streamer.d.ts +0 -50
  316. package/dist/adapter/backtester/backtester-streamer.d.ts.map +0 -1
  317. package/dist/adapter/backtester/backtester-streamer.js +0 -119
  318. package/dist/adapter/backtester/error.d.ts +0 -3
  319. package/dist/adapter/backtester/error.d.ts.map +0 -1
  320. package/dist/adapter/backtester/error.js +0 -11
  321. package/dist/adapter/backtester/index.d.ts +0 -3
  322. package/dist/adapter/backtester/index.d.ts.map +0 -1
  323. package/dist/adapter/error.d.ts +0 -4
  324. package/dist/adapter/error.d.ts.map +0 -1
  325. package/dist/adapter/error.js +0 -15
  326. package/dist/adapter/index.d.ts +0 -5
  327. package/dist/adapter/index.d.ts.map +0 -1
  328. package/dist/adapter/paper/engine/paper-engine.d.ts +0 -12
  329. package/dist/adapter/paper/engine/paper-engine.d.ts.map +0 -1
  330. package/dist/adapter/paper/engine/paper-engine.js +0 -109
  331. package/dist/adapter/paper/index.d.ts +0 -3
  332. package/dist/adapter/paper/index.d.ts.map +0 -1
  333. package/dist/adapter/paper/paper-adapter.d.ts +0 -30
  334. package/dist/adapter/paper/paper-adapter.d.ts.map +0 -1
  335. package/dist/adapter/paper/paper-adapter.js +0 -87
  336. package/dist/cli/error.d.ts +0 -2
  337. package/dist/cli/error.d.ts.map +0 -1
  338. package/dist/cli/error.js +0 -7
  339. package/dist/cli/test.d.ts.map +0 -1
  340. package/dist/domain/asset.d.ts.map +0 -1
  341. package/dist/domain/balance-operator.d.ts +0 -7
  342. package/dist/domain/balance-operator.d.ts.map +0 -1
  343. package/dist/domain/balance-operator.js +0 -9
  344. package/dist/domain/balance.d.ts +0 -47
  345. package/dist/domain/balance.d.ts.map +0 -1
  346. package/dist/domain/balance.js +0 -97
  347. package/dist/domain/commission.d.ts.map +0 -1
  348. package/dist/domain/component.d.ts +0 -6
  349. package/dist/domain/component.d.ts.map +0 -1
  350. package/dist/domain/error.d.ts +0 -7
  351. package/dist/domain/error.d.ts.map +0 -1
  352. package/dist/domain/error.js +0 -23
  353. package/dist/domain/index.d.ts +0 -22
  354. package/dist/domain/index.d.ts.map +0 -1
  355. package/dist/domain/index.js +0 -37
  356. package/dist/domain/instrument-operator.d.ts +0 -7
  357. package/dist/domain/instrument-operator.d.ts.map +0 -1
  358. package/dist/domain/instrument-operator.js +0 -13
  359. package/dist/domain/instrument.d.ts.map +0 -1
  360. package/dist/domain/ohlc-operator.d.ts.map +0 -1
  361. package/dist/domain/ohlc.d.ts.map +0 -1
  362. package/dist/domain/order-operator.d.ts +0 -8
  363. package/dist/domain/order-operator.d.ts.map +0 -1
  364. package/dist/domain/order-operator.js +0 -16
  365. package/dist/domain/order.d.ts +0 -24
  366. package/dist/domain/order.d.ts.map +0 -1
  367. package/dist/domain/order.js +0 -49
  368. package/dist/domain/orderbook-operator.d.ts +0 -7
  369. package/dist/domain/orderbook-operator.d.ts.map +0 -1
  370. package/dist/domain/orderbook-operator.js +0 -9
  371. package/dist/domain/orderbook.d.ts +0 -30
  372. package/dist/domain/orderbook.d.ts.map +0 -1
  373. package/dist/domain/orderbook.js +0 -20
  374. package/dist/domain/position-operator.d.ts +0 -13
  375. package/dist/domain/position-operator.d.ts.map +0 -1
  376. package/dist/domain/position-operator.js +0 -45
  377. package/dist/domain/position.d.ts +0 -18
  378. package/dist/domain/position.d.ts.map +0 -1
  379. package/dist/domain/position.js +0 -23
  380. package/dist/domain/session-builder.d.ts +0 -54
  381. package/dist/domain/session-builder.d.ts.map +0 -1
  382. package/dist/domain/session-builder.js +0 -106
  383. package/dist/domain/session.d.ts +0 -77
  384. package/dist/domain/session.d.ts.map +0 -1
  385. package/dist/domain/session.js +0 -162
  386. package/dist/domain/timeframe.d.ts.map +0 -1
  387. package/dist/domain/trade-operator.d.ts +0 -7
  388. package/dist/domain/trade-operator.d.ts.map +0 -1
  389. package/dist/domain/trade-operator.js +0 -9
  390. package/dist/domain/trade.d.ts +0 -16
  391. package/dist/domain/trade.d.ts.map +0 -1
  392. package/dist/domain/trade.js +0 -17
  393. package/dist/shared/collections.d.ts +0 -29
  394. package/dist/shared/collections.d.ts.map +0 -1
  395. package/dist/shared/collections.js +0 -123
  396. package/dist/shared/logger.d.ts +0 -8
  397. package/dist/shared/logger.d.ts.map +0 -1
  398. package/dist/shared/logger.js +0 -33
  399. package/dist/shared/pipe.d.ts +0 -5
  400. package/dist/shared/pipe.d.ts.map +0 -1
  401. package/dist/shared/pipe.js +0 -8
  402. package/dist/shared/policy.d.ts +0 -2
  403. package/dist/shared/policy.d.ts.map +0 -1
  404. package/dist/shared/policy.js +0 -8
  405. package/dist/storage/cache.d.ts +0 -10
  406. package/dist/storage/cache.d.ts.map +0 -1
  407. package/dist/storage/cache.js +0 -43
  408. package/dist/storage/feed.d.ts +0 -38
  409. package/dist/storage/feed.d.ts.map +0 -1
  410. package/dist/storage/feed.js +0 -108
  411. package/dist/storage/measurement.d.ts +0 -34
  412. package/dist/storage/measurement.d.ts.map +0 -1
  413. package/dist/storage/measurement.js +0 -59
  414. package/dist/store/error.d.ts +0 -9
  415. package/dist/store/error.d.ts.map +0 -1
  416. package/dist/store/error.js +0 -31
  417. package/dist/store/index.d.ts +0 -10
  418. package/dist/store/index.d.ts.map +0 -1
  419. package/dist/store/store-balance-event.d.ts +0 -46
  420. package/dist/store/store-balance-event.d.ts.map +0 -1
  421. package/dist/store/store-balance-event.js +0 -134
  422. package/dist/store/store-event.d.ts +0 -7
  423. package/dist/store/store-event.d.ts.map +0 -1
  424. package/dist/store/store-event.js +0 -2
  425. package/dist/store/store-instrument-event.d.ts +0 -22
  426. package/dist/store/store-instrument-event.d.ts.map +0 -1
  427. package/dist/store/store-instrument-event.js +0 -60
  428. package/dist/store/store-order-event.d.ts +0 -64
  429. package/dist/store/store-order-event.d.ts.map +0 -1
  430. package/dist/store/store-order-event.js +0 -185
  431. package/dist/store/store-orderbook-event.d.ts +0 -13
  432. package/dist/store/store-orderbook-event.d.ts.map +0 -1
  433. package/dist/store/store-orderbook-event.js +0 -43
  434. package/dist/store/store-position-event.d.ts +0 -22
  435. package/dist/store/store-position-event.d.ts.map +0 -1
  436. package/dist/store/store-position-event.js +0 -96
  437. package/dist/store/store-state.d.ts +0 -28
  438. package/dist/store/store-state.d.ts.map +0 -1
  439. package/dist/store/store-state.js +0 -29
  440. package/dist/store/store-trade-event.d.ts +0 -17
  441. package/dist/store/store-trade-event.d.ts.map +0 -1
  442. package/dist/store/store-trade-event.js +0 -34
  443. package/dist/store/store.d.ts +0 -15
  444. package/dist/store/store.d.ts.map +0 -1
  445. package/dist/store/store.js +0 -32
  446. package/src/adapter/adapter-aggregate.ts +0 -171
  447. package/src/adapter/adapter.ts +0 -83
  448. package/src/adapter/backtester/backtester-adapter.ts +0 -96
  449. package/src/adapter/backtester/backtester-cursor.spec.ts +0 -44
  450. package/src/adapter/backtester/backtester-cursor.ts +0 -47
  451. package/src/adapter/backtester/backtester-streamer.spec.ts +0 -60
  452. package/src/adapter/backtester/backtester-streamer.ts +0 -155
  453. package/src/adapter/backtester/error.ts +0 -7
  454. package/src/adapter/backtester/index.ts +0 -2
  455. package/src/adapter/error.ts +0 -13
  456. package/src/adapter/index.ts +0 -4
  457. package/src/adapter/paper/engine/paper-engine.spec.ts +0 -116
  458. package/src/adapter/paper/engine/paper-engine.ts +0 -151
  459. package/src/adapter/paper/index.ts +0 -2
  460. package/src/adapter/paper/paper-adapter.ts +0 -111
  461. package/src/cli/error.ts +0 -5
  462. package/src/cli/test.ts +0 -40
  463. package/src/domain/balance-operator.spec.ts +0 -26
  464. package/src/domain/balance-operator.ts +0 -15
  465. package/src/domain/balance.spec.ts +0 -116
  466. package/src/domain/balance.ts +0 -123
  467. package/src/domain/component.ts +0 -6
  468. package/src/domain/error.ts +0 -27
  469. package/src/domain/index.ts +0 -21
  470. package/src/domain/instrument-operator.spec.ts +0 -35
  471. package/src/domain/instrument-operator.ts +0 -25
  472. package/src/domain/order-operator.spec.ts +0 -85
  473. package/src/domain/order-operator.ts +0 -23
  474. package/src/domain/order.spec.ts +0 -43
  475. package/src/domain/order.ts +0 -68
  476. package/src/domain/orderbook-operator.spec.ts +0 -40
  477. package/src/domain/orderbook-operator.ts +0 -15
  478. package/src/domain/orderbook.spec.ts +0 -26
  479. package/src/domain/orderbook.ts +0 -30
  480. package/src/domain/position-operator.spec.ts +0 -64
  481. package/src/domain/position-operator.ts +0 -71
  482. package/src/domain/position.spec.ts +0 -43
  483. package/src/domain/position.ts +0 -31
  484. package/src/domain/session-builder.ts +0 -158
  485. package/src/domain/session.spec.ts +0 -33
  486. package/src/domain/session.ts +0 -256
  487. package/src/domain/trade-operator.spec.ts +0 -35
  488. package/src/domain/trade-operator.ts +0 -15
  489. package/src/domain/trade.spec.ts +0 -21
  490. package/src/domain/trade.ts +0 -20
  491. package/src/shared/collections.spec.ts +0 -34
  492. package/src/shared/collections.ts +0 -154
  493. package/src/shared/logger.ts +0 -39
  494. package/src/shared/pipe.ts +0 -12
  495. package/src/shared/policy.ts +0 -5
  496. package/src/storage/cache.spec.ts +0 -18
  497. package/src/storage/cache.ts +0 -37
  498. package/src/storage/feed.ts +0 -124
  499. package/src/storage/measurement.ts +0 -56
  500. package/src/store/error.ts +0 -36
  501. package/src/store/index.ts +0 -9
  502. package/src/store/store-balance-event.spec.ts +0 -30
  503. package/src/store/store-balance-event.ts +0 -167
  504. package/src/store/store-event.ts +0 -8
  505. package/src/store/store-instrument-event.spec.ts +0 -26
  506. package/src/store/store-instrument-event.ts +0 -83
  507. package/src/store/store-order-event.spec.ts +0 -32
  508. package/src/store/store-order-event.ts +0 -219
  509. package/src/store/store-orderbook-event.spec.ts +0 -39
  510. package/src/store/store-orderbook-event.ts +0 -56
  511. package/src/store/store-position-event.ts +0 -121
  512. package/src/store/store-state.ts +0 -48
  513. package/src/store/store-trade-event.spec.ts +0 -62
  514. package/src/store/store-trade-event.ts +0 -42
  515. package/src/store/store.spec.ts +0 -182
  516. package/src/store/store.ts +0 -37
  517. package/dist/{domain → component}/ohlc.d.ts +0 -0
  518. package/dist/{domain → component}/ohlc.js +0 -0
  519. package/dist/{domain → component}/timeframe.d.ts +0 -0
  520. package/dist/{domain → component}/timeframe.js +1 -1
  521. /package/src/{domain → component}/timeframe.ts +0 -0
@@ -1,116 +0,0 @@
1
- import {
2
- Asset,
3
- Commission,
4
- commissionPercentOf,
5
- Instrument,
6
- Order
7
- } from '../../../domain';
8
- import { d, now } from '../../../shared';
9
- import {
10
- BalancePatchEvent,
11
- InstrumentPatchEvent,
12
- InstrumentSubscriptionEvent,
13
- OrderbookPatchEvent,
14
- Store
15
- } from '../../../store';
16
- import { PaperEngine } from './paper-engine';
17
-
18
- describe('PaperEngine', () => {
19
- const instrument = new Instrument(
20
- 0,
21
- new Asset('btc', 'binance', 8),
22
- new Asset('usdt', 'binance', 2),
23
- 'binance:btc-usdt',
24
- Commission.Zero
25
- );
26
-
27
- const commission = commissionPercentOf({
28
- maker: d(0.1),
29
- taker: d(0.1)
30
- });
31
-
32
- test('should open a new buy market order', () => {
33
- const store = new Store();
34
- const engine = new PaperEngine(store);
35
- const order = new Order(0, '1', instrument, d(1.0), 0);
36
-
37
- store.dispatch(
38
- new InstrumentPatchEvent(now(), instrument.base, instrument.quote, commission, ''),
39
- new BalancePatchEvent(instrument.base, d(1), d.Zero, now()),
40
- new BalancePatchEvent(instrument.quote, d(1000), d.Zero, now())
41
- );
42
-
43
- engine.open(order);
44
-
45
- const pendingOrder = store.snapshot.order.get(instrument.id)?.get(order.id) ?? fail();
46
- const balance = store.snapshot.balance.get(instrument.quote.id) ?? fail();
47
-
48
- expect(store.snapshot.order.asReadonlyArray().length).toEqual(1);
49
- expect(pendingOrder).toEqual(order);
50
- expect(balance.free).toEqual(d.Zero);
51
- expect(balance.locked).toEqual(d(1000));
52
- });
53
-
54
- test('should open a new sell market order', () => {
55
- const store = new Store();
56
- const engine = new PaperEngine(store);
57
- const order = new Order(0, '1', instrument, d(-0.6), 0);
58
-
59
- store.dispatch(
60
- new InstrumentPatchEvent(now(), instrument.base, instrument.quote, commission, ''),
61
- new BalancePatchEvent(instrument.base, d(1), d.Zero, now()),
62
- new BalancePatchEvent(instrument.quote, d(1000), d.Zero, now())
63
- );
64
-
65
- engine.open(order);
66
-
67
- const pendingOrder = store.snapshot.order.get(instrument.id)?.get(order.id) ?? fail();
68
- const balance = store.snapshot.balance.get(instrument.base.id) ?? fail();
69
-
70
- expect(store.snapshot.order.asReadonlyArray().length).toEqual(1);
71
- expect(pendingOrder).toEqual(order);
72
- expect(balance.free).toEqual(d(0.4));
73
- expect(balance.locked).toEqual(d(0.6));
74
- });
75
-
76
- test('should open and fill a new sell limit order', () => {
77
- const store = new Store();
78
- const engine = new PaperEngine(store);
79
- const order = new Order(0, '1', instrument, d(-0.6), 0, d(100));
80
-
81
- store.dispatch(
82
- new InstrumentPatchEvent(now(), instrument.base, instrument.quote, commission, ''),
83
- new BalancePatchEvent(instrument.base, d(1), d.Zero, now()),
84
- new BalancePatchEvent(instrument.quote, d(1000), d.Zero, now()),
85
- new InstrumentSubscriptionEvent(now(), instrument, true)
86
- );
87
-
88
- engine.open(order);
89
-
90
- const pendingOrder = store.snapshot.order.get(instrument.id)?.get(order.id) ?? fail();
91
- const baseBalance = store.snapshot.balance.get(instrument.base.id) ?? fail();
92
-
93
- expect(store.snapshot.order.asReadonlyArray().length).toEqual(1);
94
- expect(pendingOrder.state).toEqual('PENDING');
95
- expect(baseBalance.free).toEqual(d(0.4));
96
- expect(baseBalance.locked).toEqual(d(0.6));
97
-
98
- store.dispatch(
99
- new OrderbookPatchEvent(
100
- instrument,
101
- { rate: d(102), quantity: d(1), next: undefined },
102
- { rate: d(101), quantity: d(1), next: undefined },
103
- now()
104
- )
105
- );
106
-
107
- const quoteBalance = store.snapshot.balance.get(instrument.quote.id) ?? fail();
108
-
109
- expect(store.snapshot.order.asReadonlyArray().length).toEqual(1);
110
- expect(pendingOrder.state).toEqual('FILLED');
111
- expect(baseBalance.free).toEqual(d(0.4));
112
- expect(baseBalance.locked).toEqual(d.Zero);
113
- expect(quoteBalance.free).toEqual(d(1060.53));
114
- expect(quoteBalance.locked).toEqual(d.Zero);
115
- });
116
- });
@@ -1,151 +0,0 @@
1
- import { tap } from 'rxjs';
2
-
3
- import { Order, Orderbook, Trade } from '../../../domain';
4
- import { d, decimal } from '../../../shared';
5
- import {
6
- BalanceLockOrderEvent,
7
- BalanceTransactEvent,
8
- BalanceUnlockOrderEvent,
9
- OrderCanceledEvent,
10
- OrderCancelingEvent,
11
- OrderFilledEvent,
12
- OrderNewEvent,
13
- OrderPendingEvent,
14
- OrderRejectedEvent,
15
- Store
16
- } from '../../../store';
17
- import { instrumentNotSupportedError } from '../../../store/error';
18
-
19
- export class PaperEngine {
20
- constructor(private readonly store: Store) {
21
- store.changes$
22
- .pipe(
23
- tap(it => {
24
- if (it instanceof Orderbook) {
25
- this.onOrderbook(it);
26
- } else if (it instanceof Trade) {
27
- this.onTrade(it);
28
- }
29
- })
30
- )
31
- .subscribe();
32
- }
33
-
34
- public open(order: Order) {
35
- const { timestamp } = this.store.snapshot;
36
-
37
- try {
38
- this.store.dispatch(
39
- new OrderNewEvent(order, timestamp),
40
- new BalanceLockOrderEvent(order.id, order.instrument, timestamp)
41
- );
42
-
43
- this.store.dispatch(new OrderPendingEvent(order.id, order.instrument, timestamp));
44
- } catch (error) {
45
- this.store.dispatch(
46
- new BalanceUnlockOrderEvent(order.id, order.instrument, timestamp),
47
- new OrderRejectedEvent(order.id, order.instrument, timestamp)
48
- );
49
- }
50
- }
51
-
52
- public cancel(order: Order) {
53
- const { timestamp } = this.store.snapshot;
54
-
55
- this.store.dispatch(new OrderCancelingEvent(order.id, order.instrument, timestamp));
56
-
57
- this.store.dispatch(
58
- new BalanceUnlockOrderEvent(order.id, order.instrument, timestamp),
59
- new OrderCanceledEvent(order.id, order.instrument, timestamp)
60
- );
61
- }
62
-
63
- private onOrderbook(orderbook: Orderbook) {
64
- const orders = this.store.snapshot.order.get(orderbook.instrument.id);
65
- if (!orders) {
66
- return;
67
- }
68
-
69
- orders.asReadonlyArray().forEach(it => {
70
- if (it.state != 'PENDING') {
71
- return;
72
- }
73
-
74
- if (it.rate) {
75
- if (it.quantity.greaterThan(0) && it.rate.greaterThan(orderbook.asks.rate)) {
76
- this.completeOrder(it, orderbook.asks.rate);
77
- } else if (it.quantity.lessThan(0) && it.rate.lessThan(orderbook.bids.rate)) {
78
- this.completeOrder(it, orderbook.bids.rate);
79
- }
80
- } else {
81
- if (it.quantity.greaterThan(0)) {
82
- this.completeOrder(it, orderbook.asks.rate);
83
- } else if (it.quantity.lessThan(0)) {
84
- this.completeOrder(it, orderbook.bids.rate);
85
- }
86
- }
87
- });
88
- }
89
-
90
- private onTrade(trade: Trade) {
91
- const orders = this.store.snapshot.order.get(trade.instrument.id);
92
- if (!orders) {
93
- return;
94
- }
95
-
96
- orders.asReadonlyArray().forEach(it => {
97
- if (it.state != 'PENDING') {
98
- return;
99
- }
100
-
101
- if (it.rate) {
102
- if (it.quantity.greaterThan(0) && it.rate.greaterThan(trade.rate)) {
103
- this.completeOrder(it, trade.rate);
104
- } else if (it.quantity.lessThan(0) && it.rate.lessThan(trade.rate)) {
105
- this.completeOrder(it, trade.rate);
106
- }
107
- } else {
108
- this.completeOrder(it, trade.rate);
109
- }
110
- });
111
- }
112
-
113
- private completeOrder(order: Order, averageExecutionRate: decimal) {
114
- const { timestamp } = this.store.snapshot;
115
-
116
- const instrument = this.store.snapshot.universe.instrument.get(order.instrument.id);
117
- if (!instrument) {
118
- throw instrumentNotSupportedError(order.instrument);
119
- }
120
-
121
- const transacted = {
122
- base: d.Zero,
123
- quote: d.Zero
124
- };
125
-
126
- const qty = order.quantity.abs();
127
-
128
- if (order.quantity.greaterThan(0)) {
129
- transacted.base = transacted.base.plus(
130
- instrument.base.floor(instrument.commission.applyMakerFee(qty))
131
- );
132
- transacted.quote = transacted.quote.minus(
133
- instrument.quote.floor(averageExecutionRate.mul(qty))
134
- );
135
- } else if (order.quantity.lessThan(0)) {
136
- transacted.base = transacted.base.minus(instrument.base.floor(qty));
137
- transacted.quote = transacted.quote.plus(
138
- instrument.quote.floor(
139
- instrument.commission.applyMakerFee(averageExecutionRate.mul(qty))
140
- )
141
- );
142
- }
143
-
144
- this.store.dispatch(
145
- new BalanceUnlockOrderEvent(order.id, order.instrument, timestamp),
146
- new OrderFilledEvent(order.id, order.instrument, averageExecutionRate, timestamp),
147
- new BalanceTransactEvent(instrument.base, transacted.base, timestamp),
148
- new BalanceTransactEvent(instrument.quote, transacted.quote, timestamp)
149
- );
150
- }
151
- }
@@ -1,2 +0,0 @@
1
- export * from './paper-adapter';
2
- export * from './engine/paper-engine';
@@ -1,111 +0,0 @@
1
- import { assetOf, InstrumentSelector, Ohlc, Order } from '../../domain';
2
- import { d, decimal, timestamp } from '../../shared';
3
- import { BalancePatchEvent, Store } from '../../store';
4
- import { Adapter } from '..';
5
- import { AdapterFactory, FeedAsyncCallback } from '../adapter';
6
- import { noPaperEngineProvidedError } from '../error';
7
- import { PaperEngine } from './engine/paper-engine';
8
-
9
- export interface PaperOptions {
10
- balance: { [key: string]: decimal };
11
- }
12
-
13
- export function createPaperAdapterFactory(
14
- decoratedAdapterFactory: AdapterFactory,
15
- options: PaperOptions
16
- ): AdapterFactory {
17
- return (timeProvider, store, cache) =>
18
- new PaperAdapter(decoratedAdapterFactory(timeProvider, store, cache), store, options);
19
- }
20
-
21
- export class PaperAdapter extends Adapter {
22
- readonly name = this.decoratedAdapter.name;
23
- private engine?: PaperEngine;
24
-
25
- constructor(
26
- readonly decoratedAdapter: Adapter,
27
- readonly store: Store,
28
- readonly options: PaperOptions
29
- ) {
30
- super({
31
- timestamp: () => this.decoratedAdapter.timestamp()
32
- });
33
- }
34
-
35
- async awake(): Promise<void> {
36
- this.engine = this.createPaperEngine(this);
37
-
38
- await this.decoratedAdapter.awake();
39
- }
40
-
41
- dispose(): Promise<void> {
42
- return this.decoratedAdapter.dispose();
43
- }
44
-
45
- subscribe(instruments: InstrumentSelector[]): Promise<void> {
46
- return this.decoratedAdapter.subscribe(instruments);
47
- }
48
-
49
- async account(): Promise<void> {
50
- let subscribed = Object.values(this.store.snapshot.subscription.asset).filter(
51
- it => it.adapterName == this.name
52
- );
53
-
54
- for (const balance in this.options.balance) {
55
- const asset = assetOf(balance);
56
-
57
- if (asset.adapterName != this.name) {
58
- continue;
59
- }
60
-
61
- const free = this.options.balance[balance];
62
-
63
- subscribed = subscribed.filter(it => it.id != asset.id);
64
-
65
- this.store.dispatch(new BalancePatchEvent(asset, free, d.Zero, this.timestamp()));
66
- }
67
-
68
- for (const missingAsset of subscribed) {
69
- this.store.dispatch(
70
- new BalancePatchEvent(missingAsset, d.Zero, d.Zero, this.timestamp())
71
- );
72
- }
73
- }
74
-
75
- async open(order: Order): Promise<void> {
76
- if (!this.engine) {
77
- throw noPaperEngineProvidedError();
78
- }
79
-
80
- this.engine.open(order);
81
- }
82
-
83
- async cancel(order: Order): Promise<void> {
84
- if (!this.engine) {
85
- throw noPaperEngineProvidedError();
86
- }
87
-
88
- this.engine.cancel(order);
89
- }
90
-
91
- history(
92
- instrument: InstrumentSelector,
93
- timeframe: number,
94
- length: number
95
- ): Promise<Ohlc[]> {
96
- return this.decoratedAdapter.history(instrument, timeframe, length);
97
- }
98
-
99
- feed(
100
- instrument: InstrumentSelector,
101
- from: timestamp,
102
- to: timestamp,
103
- callback: FeedAsyncCallback
104
- ): Promise<void> {
105
- return this.decoratedAdapter.feed(instrument, from, to, callback);
106
- }
107
-
108
- createPaperEngine(adapter: PaperAdapter): PaperEngine {
109
- return this.decoratedAdapter.createPaperEngine(adapter);
110
- }
111
- }
package/src/cli/error.ts DELETED
@@ -1,5 +0,0 @@
1
- export function missingDescriptorParameterError(parameterName: string) {
2
- return new Error(
3
- `please set a "${parameterName}" date in session descriptor or provide the date as parameter.`
4
- );
5
- }
package/src/cli/test.ts DELETED
@@ -1,40 +0,0 @@
1
- import { join } from 'path';
2
-
3
- import { SessionBuilder } from '../domain/session-builder';
4
- import { Logger, now } from '../shared';
5
- import { spawn } from '..';
6
- import build from './build';
7
- import { buildDirectory } from './internal/workspace';
8
-
9
- export default async function (name: string, options: any) {
10
- if (await build()) {
11
- return;
12
- }
13
-
14
- await import(join(buildDirectory(), 'index'));
15
-
16
- const builder = new SessionBuilder().useSessionId(
17
- options.id ? Number(options.id) : now()
18
- );
19
-
20
- const rules = await spawn(name, builder);
21
-
22
- const startTime = performance.now();
23
-
24
- const [session, backtester] = builder.backtest({
25
- onBacktestStarted: () => Logger.info('backtest', `new session ${session.id} started`),
26
- onBacktestCompleted: async () => {
27
- await session.dispose();
28
-
29
- const seconds = ((performance.now() - startTime) / 1000).toFixed(3);
30
-
31
- Logger.info('backtest', `session ${session.id} completed in ${seconds}s`);
32
- }
33
- });
34
-
35
- await session.awake();
36
-
37
- rules(session).subscribe();
38
-
39
- backtester.tryContinue();
40
- }
@@ -1,26 +0,0 @@
1
- import { Subject } from 'rxjs';
2
-
3
- import { State } from '../store';
4
- import { Asset } from './asset';
5
- import { Balance } from './balance';
6
- import { balance } from './balance-operator';
7
- import { Component } from './component';
8
-
9
- describe('balance', () => {
10
- const timestamp = 0;
11
- const asset = new Asset('abc', 'xyz', 4);
12
- const state = new State();
13
-
14
- beforeEach(() => {
15
- state.balance.upsert(new Balance(timestamp, asset));
16
- });
17
-
18
- test('should pipe a balance snapshot when subscribed', done => {
19
- new Subject<Component>().pipe(balance(asset, state)).subscribe({
20
- next: it => {
21
- expect(it.asset).toEqual(asset);
22
- done();
23
- }
24
- });
25
- });
26
- });
@@ -1,15 +0,0 @@
1
- import { filter, map, Observable, startWith } from 'rxjs';
2
-
3
- import { State } from '../store';
4
- import { AssetSelector } from './asset';
5
- import { Balance } from './balance';
6
- import { Component } from './component';
7
-
8
- export function balance(selector: AssetSelector, state: State) {
9
- return (source$: Observable<Component>) =>
10
- source$.pipe(
11
- startWith(state.balance.get(selector.id)),
12
- filter(it => it instanceof Balance && (!selector || it.asset.id == selector.id)),
13
- map(it => it as Balance)
14
- );
15
- }
@@ -1,116 +0,0 @@
1
- import { d } from '../shared';
2
- import { Asset } from './asset';
3
- import { Balance } from './balance';
4
- import { Commission } from './commission';
5
- import { Instrument } from './instrument';
6
- import { Position } from './position';
7
-
8
- describe('Balance', () => {
9
- const asset = new Asset('abc', 'xyz', 4);
10
- const instrument = new Instrument(
11
- 0,
12
- new Asset('abc', 'xyz', 4),
13
- new Asset('def', 'xyz', 4),
14
- 'abc-def',
15
- Commission.Zero
16
- );
17
-
18
- test('should construct empty balance', () => {
19
- const sut = new Balance(0, asset);
20
-
21
- expect(sut.asset.id).toEqual('xyz:abc');
22
- expect(sut.free).toEqual(d.Zero);
23
- expect(sut.locked).toEqual(d.Zero);
24
- expect(Object.keys(sut.position).length).toEqual(0);
25
- });
26
-
27
- test('should construct balance', () => {
28
- const sut = new Balance(1, asset);
29
-
30
- sut.set(d(100), d(50));
31
-
32
- expect(sut.asset.id).toEqual('xyz:abc');
33
- expect(sut.free).toEqual(d(100));
34
- expect(sut.locked).toEqual(d(50));
35
- expect(sut.total).toEqual(d(150));
36
- expect(Object.keys(sut.position).length).toEqual(0);
37
- });
38
-
39
- test('should account positive amount', () => {
40
- const sut = new Balance(0, asset);
41
-
42
- sut.set(d(100), d.Zero);
43
- sut.account(d(10));
44
-
45
- expect(sut.free).toEqual(d(110));
46
- expect(sut.locked).toEqual(d.Zero);
47
- expect(sut.total).toEqual(d(110));
48
- });
49
-
50
- test('should account negative amount', () => {
51
- const sut = new Balance(0, asset);
52
-
53
- sut.set(d(100), d.Zero);
54
- sut.account(d(-10));
55
-
56
- expect(sut.free).toEqual(d(90));
57
- expect(sut.locked).toEqual(d.Zero);
58
- expect(sut.total).toEqual(d(90));
59
- });
60
-
61
- test('should throw for insufficient balance account amount', () => {
62
- const sut = new Balance(0, asset);
63
-
64
- sut.set(d(100), d.Zero);
65
- const fn = () => sut.account(d(-120));
66
-
67
- expect(fn).toThrowError();
68
- });
69
-
70
- test('should lock specific amount of available balance', () => {
71
- const sut = new Balance(0, asset);
72
-
73
- sut.set(d(100), d.Zero);
74
- sut.lock('key', d(10));
75
-
76
- expect(sut.free).toEqual(d(90));
77
- expect(sut.locked).toEqual(d(10));
78
- expect(sut.total).toEqual(d(100));
79
- });
80
-
81
- test('should throw for lock insufficient amount of available balance', () => {
82
- const sut = new Balance(0, asset);
83
-
84
- sut.set(d(30), d(50));
85
- const fn = () => sut.lock('key', d(100));
86
-
87
- expect(fn).toThrowError();
88
- });
89
-
90
- test('should lock and unlock specific amount of available balance', () => {
91
- const sut = new Balance(0, asset);
92
-
93
- sut.set(d(100), d.Zero);
94
- sut.lock('key', d(40));
95
- sut.tryUnlock('key');
96
-
97
- expect(sut.free).toEqual(d(100));
98
- expect(sut.locked).toEqual(d.Zero);
99
- expect(sut.total).toEqual(d(100));
100
- });
101
-
102
- test('should return correct estimated unrealized pnl', () => {
103
- const position = new Position(0, '1', instrument, 'CROSS', d(2511.81), d(10.31), 20);
104
-
105
- position.calculateEstimatedUnrealizedPnL(d(2576.44));
106
-
107
- const sut = new Balance(0, asset);
108
-
109
- sut.set(d(100), d.Zero);
110
- sut.position['1'] = position;
111
-
112
- expect(sut.getEstimatedUnrealizedPnL()).toEqual(d(0.2652));
113
- expect(sut.free).toEqual(d(100).add(d(0.2652)));
114
- expect(sut.total).toEqual(d(100).add(d(0.2652)));
115
- });
116
- });