@quantform/core 0.4.11 → 0.5.15

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 (490) hide show
  1. package/dist/adapter/adapter-aggregate.d.ts +7 -3
  2. package/dist/adapter/adapter-aggregate.js +17 -18
  3. package/dist/adapter/adapter-aggregate.js.map +1 -1
  4. package/dist/adapter/adapter.d.ts +21 -21
  5. package/dist/adapter/adapter.js +8 -40
  6. package/dist/adapter/adapter.js.map +1 -1
  7. package/dist/adapter/backtester/backtester-adapter.d.ts +9 -7
  8. package/dist/adapter/backtester/backtester-adapter.js +15 -13
  9. package/dist/adapter/backtester/backtester-adapter.js.map +1 -1
  10. package/dist/{tests → adapter/backtester}/backtester-adapter.spec.d.ts +0 -0
  11. package/dist/adapter/backtester/backtester-adapter.spec.js +82 -0
  12. package/dist/adapter/backtester/backtester-adapter.spec.js.map +1 -0
  13. package/dist/adapter/backtester/backtester-cursor.d.ts +3 -4
  14. package/dist/adapter/backtester/backtester-cursor.js +2 -1
  15. package/dist/adapter/backtester/backtester-cursor.js.map +1 -1
  16. package/dist/adapter/backtester/backtester-cursor.spec.js +17 -18
  17. package/dist/adapter/backtester/backtester-cursor.spec.js.map +1 -1
  18. package/dist/adapter/backtester/backtester-streamer.d.ts +4 -1
  19. package/dist/adapter/backtester/backtester-streamer.js +39 -18
  20. package/dist/adapter/backtester/backtester-streamer.js.map +1 -1
  21. package/dist/adapter/backtester/backtester-streamer.spec.js +13 -13
  22. package/dist/adapter/backtester/backtester-streamer.spec.js.map +1 -1
  23. package/dist/adapter/backtester/index.js +5 -1
  24. package/dist/adapter/backtester/index.js.map +1 -1
  25. package/dist/adapter/error.d.ts +2 -0
  26. package/dist/adapter/error.js +12 -0
  27. package/dist/adapter/error.js.map +1 -0
  28. package/dist/adapter/index.js +5 -1
  29. package/dist/adapter/index.js.map +1 -1
  30. package/dist/adapter/paper/engine/paper-engine.d.ts +11 -0
  31. package/dist/adapter/paper/engine/paper-engine.js +103 -0
  32. package/dist/adapter/paper/engine/paper-engine.js.map +1 -0
  33. package/dist/adapter/paper/{simulator/paper-spot-simulator.spec.d.ts → engine/paper-engine.spec.d.ts} +0 -0
  34. package/dist/adapter/paper/engine/paper-engine.spec.js +54 -0
  35. package/dist/adapter/paper/engine/paper-engine.spec.js.map +1 -0
  36. package/dist/adapter/paper/index.d.ts +1 -2
  37. package/dist/adapter/paper/index.js +6 -3
  38. package/dist/adapter/paper/index.js.map +1 -1
  39. package/dist/adapter/paper/paper-adapter.d.ts +7 -7
  40. package/dist/adapter/paper/paper-adapter.js +21 -19
  41. package/dist/adapter/paper/paper-adapter.js.map +1 -1
  42. package/dist/adapter/paper/paper-adapter.spec.js +35 -15
  43. package/dist/adapter/paper/paper-adapter.spec.js.map +1 -1
  44. package/dist/bootstrap.js +32 -15
  45. package/dist/bootstrap.js.map +1 -1
  46. package/dist/cli/build.d.ts +1 -0
  47. package/dist/cli/build.js +16 -0
  48. package/dist/cli/build.js.map +1 -0
  49. package/dist/cli/dev.d.ts +1 -0
  50. package/dist/cli/dev.js +17 -0
  51. package/dist/cli/dev.js.map +1 -0
  52. package/dist/cli/index.d.ts +2 -0
  53. package/dist/cli/index.js +72 -0
  54. package/dist/cli/index.js.map +1 -0
  55. package/dist/cli/internal/workspace.d.ts +8 -0
  56. package/dist/cli/internal/workspace.js +14 -0
  57. package/dist/cli/internal/workspace.js.map +1 -0
  58. package/dist/cli/pull.d.ts +1 -0
  59. package/dist/cli/pull.js +52 -0
  60. package/dist/cli/pull.js.map +1 -0
  61. package/dist/cli/run.d.ts +1 -0
  62. package/dist/cli/run.js +19 -0
  63. package/dist/cli/run.js.map +1 -0
  64. package/dist/cli/test.d.ts +1 -0
  65. package/dist/cli/test.js +41 -0
  66. package/dist/cli/test.js.map +1 -0
  67. package/dist/domain/asset.d.ts +6 -5
  68. package/dist/domain/asset.js +22 -16
  69. package/dist/domain/asset.js.map +1 -1
  70. package/dist/domain/asset.spec.js +32 -32
  71. package/dist/domain/asset.spec.js.map +1 -1
  72. package/dist/domain/balance.d.ts +11 -10
  73. package/dist/domain/balance.js +38 -32
  74. package/dist/domain/balance.js.map +1 -1
  75. package/dist/domain/balance.operator.d.ts +6 -0
  76. package/dist/domain/balance.operator.js +10 -0
  77. package/dist/domain/balance.operator.js.map +1 -0
  78. package/dist/{ipc.spec.d.ts → domain/balance.operator.spec.d.ts} +0 -0
  79. package/dist/domain/balance.operator.spec.js +23 -0
  80. package/dist/domain/balance.operator.spec.js.map +1 -0
  81. package/dist/domain/balance.spec.js +69 -9
  82. package/dist/domain/balance.spec.js.map +1 -1
  83. package/dist/domain/candle.d.ts +2 -15
  84. package/dist/domain/candle.js +3 -66
  85. package/dist/domain/candle.js.map +1 -1
  86. package/dist/domain/candle.operator.d.ts +9 -0
  87. package/dist/domain/candle.operator.js +64 -0
  88. package/dist/domain/candle.operator.js.map +1 -0
  89. package/dist/{shared/policy.spec.d.ts → domain/candle.operator.spec.d.ts} +0 -0
  90. package/dist/domain/candle.operator.spec.js +111 -0
  91. package/dist/domain/candle.operator.spec.js.map +1 -0
  92. package/dist/domain/candle.spec.js +11 -53
  93. package/dist/domain/candle.spec.js.map +1 -1
  94. package/dist/domain/commission.d.ts +4 -1
  95. package/dist/domain/commission.js +2 -2
  96. package/dist/domain/commission.js.map +1 -1
  97. package/dist/{shared/topic.spec.d.ts → domain/commission.spec.d.ts} +0 -0
  98. package/dist/domain/commission.spec.js +30 -0
  99. package/dist/domain/commission.spec.js.map +1 -0
  100. package/dist/domain/component.d.ts +2 -0
  101. package/dist/domain/error.d.ts +5 -0
  102. package/dist/domain/error.js +24 -0
  103. package/dist/domain/error.js.map +1 -0
  104. package/dist/domain/index.d.ts +8 -1
  105. package/dist/domain/index.js +13 -2
  106. package/dist/domain/index.js.map +1 -1
  107. package/dist/domain/instrument.d.ts +4 -2
  108. package/dist/domain/instrument.js +18 -9
  109. package/dist/domain/instrument.js.map +1 -1
  110. package/dist/domain/instrument.operator.d.ts +6 -0
  111. package/dist/domain/instrument.operator.js +14 -0
  112. package/dist/domain/instrument.operator.js.map +1 -0
  113. package/dist/{shared/worker.spec.d.ts → domain/instrument.operator.spec.d.ts} +0 -0
  114. package/dist/domain/instrument.operator.spec.js +24 -0
  115. package/dist/domain/instrument.operator.spec.js.map +1 -0
  116. package/dist/domain/instrument.spec.js +22 -30
  117. package/dist/domain/instrument.spec.js.map +1 -1
  118. package/dist/domain/order.d.ts +15 -16
  119. package/dist/domain/order.js +39 -26
  120. package/dist/domain/order.js.map +1 -1
  121. package/dist/domain/order.operator.d.ts +7 -0
  122. package/dist/domain/order.operator.js +14 -0
  123. package/dist/domain/order.operator.js.map +1 -0
  124. package/dist/{store/event/store-balance.event.spec.d.ts → domain/order.operator.spec.d.ts} +0 -0
  125. package/dist/domain/order.operator.spec.js +64 -0
  126. package/dist/domain/order.operator.spec.js.map +1 -0
  127. package/dist/{store/event/store-candle.event.spec.d.ts → domain/order.spec.d.ts} +0 -0
  128. package/dist/domain/order.spec.js +33 -0
  129. package/dist/domain/order.spec.js.map +1 -0
  130. package/dist/domain/orderbook.d.ts +2 -0
  131. package/dist/domain/orderbook.js +2 -0
  132. package/dist/domain/orderbook.js.map +1 -1
  133. package/dist/domain/orderbook.operator.d.ts +6 -0
  134. package/dist/domain/orderbook.operator.js +10 -0
  135. package/dist/domain/orderbook.operator.js.map +1 -0
  136. package/dist/{store/event/store-instrument.event.spec.d.ts → domain/orderbook.operator.spec.d.ts} +0 -0
  137. package/dist/domain/orderbook.operator.spec.js +22 -0
  138. package/dist/domain/orderbook.operator.spec.js.map +1 -0
  139. package/dist/{store/event/store-order.event.spec.d.ts → domain/orderbook.spec.d.ts} +0 -0
  140. package/dist/domain/orderbook.spec.js +13 -0
  141. package/dist/domain/orderbook.spec.js.map +1 -0
  142. package/dist/domain/position.d.ts +6 -10
  143. package/dist/domain/position.js +10 -31
  144. package/dist/domain/position.js.map +1 -1
  145. package/dist/domain/position.operator.d.ts +10 -0
  146. package/dist/domain/position.operator.js +38 -0
  147. package/dist/domain/position.operator.js.map +1 -0
  148. package/dist/{store/event/store-trade.event.spec.d.ts → domain/position.operator.spec.d.ts} +0 -0
  149. package/dist/domain/position.operator.spec.js +48 -0
  150. package/dist/domain/position.operator.spec.js.map +1 -0
  151. package/dist/domain/position.spec.js +21 -17
  152. package/dist/domain/position.spec.js.map +1 -1
  153. package/dist/domain/session.d.ts +18 -35
  154. package/dist/domain/session.js +27 -53
  155. package/dist/domain/session.js.map +1 -1
  156. package/dist/domain/session.spec.js +1 -1
  157. package/dist/domain/session.spec.js.map +1 -1
  158. package/dist/domain/trade.d.ts +3 -1
  159. package/dist/domain/trade.js +2 -0
  160. package/dist/domain/trade.js.map +1 -1
  161. package/dist/domain/trade.operator.d.ts +6 -0
  162. package/dist/domain/trade.operator.js +10 -0
  163. package/dist/domain/trade.operator.js.map +1 -0
  164. package/dist/domain/trade.operator.spec.d.ts +1 -0
  165. package/dist/domain/trade.operator.spec.js +24 -0
  166. package/dist/domain/trade.operator.spec.js.map +1 -0
  167. package/dist/domain/trade.spec.d.ts +1 -0
  168. package/dist/domain/trade.spec.js +13 -0
  169. package/dist/domain/trade.spec.js.map +1 -0
  170. package/dist/index.d.ts +0 -1
  171. package/dist/index.js +5 -2
  172. package/dist/index.js.map +1 -1
  173. package/dist/indicator/atr.js.map +1 -1
  174. package/dist/indicator/cross.spec.js +2 -2
  175. package/dist/indicator/cross.spec.js.map +1 -1
  176. package/dist/indicator/donchian.js.map +1 -1
  177. package/dist/indicator/ema.js.map +1 -1
  178. package/dist/indicator/ema.spec.js +1 -1
  179. package/dist/indicator/ema.spec.js.map +1 -1
  180. package/dist/indicator/envelope.js.map +1 -1
  181. package/dist/indicator/index.js +5 -1
  182. package/dist/indicator/index.js.map +1 -1
  183. package/dist/indicator/macd.js.map +1 -1
  184. package/dist/indicator/min-max.js.map +1 -1
  185. package/dist/indicator/rma.js.map +1 -1
  186. package/dist/indicator/sma.js.map +1 -1
  187. package/dist/indicator/sma.spec.js +1 -1
  188. package/dist/indicator/sma.spec.js.map +1 -1
  189. package/dist/indicator/swma.js.map +1 -1
  190. package/dist/indicator/tma.js.map +1 -1
  191. package/dist/indicator/tma.spec.js +1 -1
  192. package/dist/indicator/tma.spec.js.map +1 -1
  193. package/dist/indicator/trailing.spec.js +2 -2
  194. package/dist/indicator/trailing.spec.js.map +1 -1
  195. package/dist/indicator/truerange.js.map +1 -1
  196. package/dist/indicator/truerange.spec.js +1 -1
  197. package/dist/indicator/truerange.spec.js.map +1 -1
  198. package/dist/indicator/window.js.map +1 -1
  199. package/dist/indicator/wma.js.map +1 -1
  200. package/dist/indicator/wma.spec.js +1 -1
  201. package/dist/indicator/wma.spec.js.map +1 -1
  202. package/dist/shared/collections.d.ts +10 -0
  203. package/dist/shared/collections.js +33 -0
  204. package/dist/shared/collections.js.map +1 -0
  205. package/dist/shared/datetime.d.ts +0 -1
  206. package/dist/shared/datetime.js +1 -12
  207. package/dist/shared/datetime.js.map +1 -1
  208. package/dist/shared/decimals.d.ts +1 -1
  209. package/dist/shared/decimals.js +4 -5
  210. package/dist/shared/decimals.js.map +1 -1
  211. package/dist/shared/decimals.spec.js +2 -1
  212. package/dist/shared/decimals.spec.js.map +1 -1
  213. package/dist/shared/index.d.ts +1 -3
  214. package/dist/shared/index.js +6 -4
  215. package/dist/shared/index.js.map +1 -1
  216. package/dist/shared/io.js.map +1 -1
  217. package/dist/shared/policy.d.ts +0 -1
  218. package/dist/shared/policy.js +1 -11
  219. package/dist/shared/policy.js.map +1 -1
  220. package/dist/storage/cache.d.ts +9 -0
  221. package/dist/storage/cache.js +32 -0
  222. package/dist/storage/cache.js.map +1 -0
  223. package/dist/storage/cache.spec.d.ts +1 -0
  224. package/dist/storage/cache.spec.js +18 -0
  225. package/dist/storage/cache.spec.js.map +1 -0
  226. package/dist/storage/feed.d.ts +3 -4
  227. package/dist/storage/feed.js +16 -6
  228. package/dist/storage/feed.js.map +1 -1
  229. package/dist/storage/index.d.ts +1 -0
  230. package/dist/storage/index.js +6 -1
  231. package/dist/storage/index.js.map +1 -1
  232. package/dist/storage/storage.d.ts +2 -0
  233. package/dist/storage/storage.js +6 -1
  234. package/dist/storage/storage.js.map +1 -1
  235. package/dist/store/index.d.ts +8 -2
  236. package/dist/store/index.js +13 -3
  237. package/dist/store/index.js.map +1 -1
  238. package/dist/store/store-balance.event.d.ts +33 -0
  239. package/dist/store/store-balance.event.js +90 -0
  240. package/dist/store/store-balance.event.js.map +1 -0
  241. package/dist/store/store-balance.event.spec.d.ts +1 -0
  242. package/dist/store/{event/store-balance.event.spec.js → store-balance.event.spec.js} +8 -8
  243. package/dist/store/store-balance.event.spec.js.map +1 -0
  244. package/dist/store/{event/store-instrument.event.d.ts → store-instrument.event.d.ts} +5 -8
  245. package/dist/store/store-instrument.event.js +52 -0
  246. package/dist/store/store-instrument.event.js.map +1 -0
  247. package/dist/store/store-instrument.event.spec.d.ts +1 -0
  248. package/dist/store/store-instrument.event.spec.js +22 -0
  249. package/dist/store/store-instrument.event.spec.js.map +1 -0
  250. package/dist/store/store-order.event.d.ts +59 -0
  251. package/dist/store/store-order.event.js +181 -0
  252. package/dist/store/store-order.event.js.map +1 -0
  253. package/dist/store/store-order.event.spec.d.ts +1 -0
  254. package/dist/store/{event/store-order.event.spec.js → store-order.event.spec.js} +8 -8
  255. package/dist/store/store-order.event.spec.js.map +1 -0
  256. package/dist/store/{event/store-orderbook.event.d.ts → store-orderbook.event.d.ts} +4 -5
  257. package/dist/store/store-orderbook.event.js +42 -0
  258. package/dist/store/store-orderbook.event.js.map +1 -0
  259. package/dist/store/{event/store-position.event.d.ts → store-position.event.d.ts} +5 -7
  260. package/dist/store/store-position.event.js +77 -0
  261. package/dist/store/store-position.event.js.map +1 -0
  262. package/dist/store/store-state.d.ts +27 -0
  263. package/dist/store/store-state.js +29 -0
  264. package/dist/store/store-state.js.map +1 -0
  265. package/dist/store/{event/store-trade.event.d.ts → store-trade.event.d.ts} +4 -5
  266. package/dist/store/store-trade.event.js +25 -0
  267. package/dist/store/store-trade.event.js.map +1 -0
  268. package/dist/store/store-trade.event.spec.d.ts +1 -0
  269. package/dist/store/{event/store-trade.event.spec.js → store-trade.event.spec.js} +14 -14
  270. package/dist/store/store-trade.event.spec.js.map +1 -0
  271. package/dist/store/store.d.ts +4 -25
  272. package/dist/store/store.event.d.ts +6 -0
  273. package/dist/store/{event/store.event.js → store.event.js} +0 -0
  274. package/dist/store/store.event.js.map +1 -0
  275. package/dist/store/store.js +7 -195
  276. package/dist/store/store.js.map +1 -1
  277. package/dist/store/store.spec.d.ts +1 -0
  278. package/dist/store/store.spec.js +119 -0
  279. package/dist/store/store.spec.js.map +1 -0
  280. package/dist/tsconfig.tsbuildinfo +1 -1
  281. package/{jestconfig.unit.json → jestconfig.json} +1 -2
  282. package/package.json +24 -20
  283. package/src/adapter/adapter-aggregate.ts +31 -34
  284. package/src/adapter/adapter.ts +26 -49
  285. package/src/adapter/backtester/backtester-adapter.spec.ts +124 -0
  286. package/src/adapter/backtester/backtester-adapter.ts +30 -17
  287. package/src/adapter/backtester/backtester-cursor.spec.ts +18 -19
  288. package/src/adapter/backtester/backtester-cursor.ts +7 -7
  289. package/src/adapter/backtester/backtester-streamer.spec.ts +19 -19
  290. package/src/adapter/backtester/backtester-streamer.ts +50 -20
  291. package/src/adapter/error.ts +9 -0
  292. package/src/adapter/paper/engine/paper-engine.spec.ts +92 -0
  293. package/src/adapter/paper/engine/paper-engine.ts +135 -0
  294. package/src/adapter/paper/index.ts +1 -2
  295. package/src/adapter/paper/paper-adapter.spec.ts +55 -17
  296. package/src/adapter/paper/paper-adapter.ts +27 -24
  297. package/src/bootstrap.ts +57 -21
  298. package/src/cli/build.ts +15 -0
  299. package/src/cli/dev.ts +18 -0
  300. package/src/cli/index.ts +81 -0
  301. package/src/cli/internal/workspace.ts +18 -0
  302. package/src/cli/pull.ts +71 -0
  303. package/src/cli/run.ts +22 -0
  304. package/src/cli/test.ts +53 -0
  305. package/src/domain/asset.spec.ts +33 -29
  306. package/src/domain/asset.ts +27 -21
  307. package/src/domain/balance.operator.spec.ts +25 -0
  308. package/src/domain/balance.operator.ts +15 -0
  309. package/src/domain/balance.spec.ts +97 -9
  310. package/src/domain/balance.ts +48 -41
  311. package/src/domain/candle.operator.spec.ts +125 -0
  312. package/src/domain/candle.operator.ts +106 -0
  313. package/src/domain/candle.spec.ts +12 -67
  314. package/src/domain/candle.ts +2 -104
  315. package/src/domain/commission.spec.ts +33 -0
  316. package/src/domain/commission.ts +2 -2
  317. package/src/domain/component.ts +2 -0
  318. package/src/domain/error.ts +25 -0
  319. package/src/domain/index.ts +8 -1
  320. package/src/domain/instrument.operator.spec.ts +28 -0
  321. package/src/domain/instrument.operator.ts +25 -0
  322. package/src/domain/instrument.spec.ts +22 -30
  323. package/src/domain/instrument.ts +21 -11
  324. package/src/domain/order.operator.spec.ts +81 -0
  325. package/src/domain/order.operator.ts +23 -0
  326. package/src/domain/order.spec.ts +43 -0
  327. package/src/domain/order.ts +46 -47
  328. package/src/domain/orderbook.operator.spec.ts +28 -0
  329. package/src/domain/orderbook.operator.ts +15 -0
  330. package/src/domain/orderbook.spec.ts +17 -0
  331. package/src/domain/orderbook.ts +5 -1
  332. package/src/domain/position.operator.spec.ts +58 -0
  333. package/src/domain/position.operator.ts +61 -0
  334. package/src/domain/position.spec.ts +28 -24
  335. package/src/domain/position.ts +17 -47
  336. package/src/domain/session.spec.ts +1 -1
  337. package/src/domain/session.ts +57 -197
  338. package/src/domain/trade.operator.spec.ts +31 -0
  339. package/src/domain/trade.operator.ts +15 -0
  340. package/src/domain/trade.spec.ts +17 -0
  341. package/src/domain/trade.ts +6 -2
  342. package/src/index.ts +0 -1
  343. package/src/indicator/atr.ts +1 -0
  344. package/src/indicator/cross.spec.ts +3 -2
  345. package/src/indicator/donchian.ts +1 -0
  346. package/src/indicator/ema.spec.ts +2 -1
  347. package/src/indicator/ema.ts +1 -0
  348. package/src/indicator/envelope.ts +1 -0
  349. package/src/indicator/macd.ts +1 -0
  350. package/src/indicator/min-max.ts +1 -0
  351. package/src/indicator/rma.ts +1 -0
  352. package/src/indicator/sma.spec.ts +2 -1
  353. package/src/indicator/sma.ts +1 -0
  354. package/src/indicator/swma.ts +1 -0
  355. package/src/indicator/tma.spec.ts +2 -1
  356. package/src/indicator/tma.ts +1 -0
  357. package/src/indicator/trailing.spec.ts +3 -2
  358. package/src/indicator/truerange.spec.ts +2 -1
  359. package/src/indicator/truerange.ts +1 -0
  360. package/src/indicator/window.ts +1 -0
  361. package/src/indicator/wma.spec.ts +2 -1
  362. package/src/indicator/wma.ts +1 -0
  363. package/src/shared/collections.ts +35 -0
  364. package/src/shared/datetime.ts +0 -12
  365. package/src/shared/decimals.spec.ts +2 -1
  366. package/src/shared/decimals.ts +6 -6
  367. package/src/shared/index.ts +1 -3
  368. package/src/shared/io.ts +0 -2
  369. package/src/shared/policy.ts +0 -13
  370. package/src/storage/cache.spec.ts +18 -0
  371. package/src/storage/cache.ts +35 -0
  372. package/src/storage/feed.ts +26 -16
  373. package/src/storage/index.ts +1 -0
  374. package/src/storage/storage.ts +11 -0
  375. package/src/store/index.ts +8 -2
  376. package/src/store/{event/store-balance.event.spec.ts → store-balance.event.spec.ts} +7 -7
  377. package/src/store/store-balance.event.ts +124 -0
  378. package/src/store/store-instrument.event.spec.ts +25 -0
  379. package/src/store/store-instrument.event.ts +72 -0
  380. package/src/store/store-order.event.spec.ts +28 -0
  381. package/src/store/store-order.event.ts +214 -0
  382. package/src/store/store-orderbook.event.ts +54 -0
  383. package/src/store/store-position.event.ts +102 -0
  384. package/src/store/store-state.ts +48 -0
  385. package/src/store/{event/store-trade.event.spec.ts → store-trade.event.spec.ts} +15 -15
  386. package/src/store/store-trade.event.ts +36 -0
  387. package/src/store/store.event.ts +8 -0
  388. package/src/store/store.spec.ts +180 -0
  389. package/src/store/store.ts +11 -208
  390. package/tsconfig.json +2 -2
  391. package/dist/adapter/paper/simulator/paper-margin-simulator.d.ts +0 -10
  392. package/dist/adapter/paper/simulator/paper-margin-simulator.js +0 -69
  393. package/dist/adapter/paper/simulator/paper-margin-simulator.js.map +0 -1
  394. package/dist/adapter/paper/simulator/paper-simulator.d.ts +0 -16
  395. package/dist/adapter/paper/simulator/paper-simulator.js +0 -93
  396. package/dist/adapter/paper/simulator/paper-simulator.js.map +0 -1
  397. package/dist/adapter/paper/simulator/paper-spot-simulator.d.ts +0 -13
  398. package/dist/adapter/paper/simulator/paper-spot-simulator.js +0 -81
  399. package/dist/adapter/paper/simulator/paper-spot-simulator.js.map +0 -1
  400. package/dist/adapter/paper/simulator/paper-spot-simulator.spec.js +0 -49
  401. package/dist/adapter/paper/simulator/paper-spot-simulator.spec.js.map +0 -1
  402. package/dist/domain/statement.d.ts +0 -4
  403. package/dist/domain/statement.js +0 -87
  404. package/dist/domain/statement.js.map +0 -1
  405. package/dist/ipc.d.ts +0 -33
  406. package/dist/ipc.js +0 -244
  407. package/dist/ipc.js.map +0 -1
  408. package/dist/ipc.spec.js +0 -57
  409. package/dist/ipc.spec.js.map +0 -1
  410. package/dist/shared/policy.spec.js +0 -26
  411. package/dist/shared/policy.spec.js.map +0 -1
  412. package/dist/shared/task.d.ts +0 -6
  413. package/dist/shared/task.js +0 -25
  414. package/dist/shared/task.js.map +0 -1
  415. package/dist/shared/topic.d.ts +0 -14
  416. package/dist/shared/topic.js +0 -40
  417. package/dist/shared/topic.js.map +0 -1
  418. package/dist/shared/topic.spec.js +0 -43
  419. package/dist/shared/topic.spec.js.map +0 -1
  420. package/dist/shared/worker.d.ts +0 -10
  421. package/dist/shared/worker.js +0 -46
  422. package/dist/shared/worker.js.map +0 -1
  423. package/dist/shared/worker.spec.js +0 -18
  424. package/dist/shared/worker.spec.js.map +0 -1
  425. package/dist/store/event/index.d.ts +0 -8
  426. package/dist/store/event/index.js +0 -21
  427. package/dist/store/event/index.js.map +0 -1
  428. package/dist/store/event/store-balance.event.d.ts +0 -37
  429. package/dist/store/event/store-balance.event.js +0 -119
  430. package/dist/store/event/store-balance.event.js.map +0 -1
  431. package/dist/store/event/store-balance.event.spec.js.map +0 -1
  432. package/dist/store/event/store-candle.event.d.ts +0 -18
  433. package/dist/store/event/store-candle.event.js +0 -63
  434. package/dist/store/event/store-candle.event.js.map +0 -1
  435. package/dist/store/event/store-candle.event.spec.js +0 -23
  436. package/dist/store/event/store-candle.event.spec.js.map +0 -1
  437. package/dist/store/event/store-instrument.event.js +0 -78
  438. package/dist/store/event/store-instrument.event.js.map +0 -1
  439. package/dist/store/event/store-instrument.event.spec.js +0 -21
  440. package/dist/store/event/store-instrument.event.spec.js.map +0 -1
  441. package/dist/store/event/store-order.event.d.ts +0 -61
  442. package/dist/store/event/store-order.event.js +0 -205
  443. package/dist/store/event/store-order.event.js.map +0 -1
  444. package/dist/store/event/store-order.event.spec.js.map +0 -1
  445. package/dist/store/event/store-orderbook.event.js +0 -65
  446. package/dist/store/event/store-orderbook.event.js.map +0 -1
  447. package/dist/store/event/store-position.event.js +0 -97
  448. package/dist/store/event/store-position.event.js.map +0 -1
  449. package/dist/store/event/store-trade.event.js +0 -47
  450. package/dist/store/event/store-trade.event.js.map +0 -1
  451. package/dist/store/event/store-trade.event.spec.js.map +0 -1
  452. package/dist/store/event/store.event.d.ts +0 -5
  453. package/dist/store/event/store.event.js.map +0 -1
  454. package/dist/store/store.state.d.ts +0 -21
  455. package/dist/store/store.state.js +0 -21
  456. package/dist/store/store.state.js.map +0 -1
  457. package/dist/tests/backtester-adapter.spec.js +0 -60
  458. package/dist/tests/backtester-adapter.spec.js.map +0 -1
  459. package/dist/tests/session.spec.d.ts +0 -0
  460. package/dist/tests/session.spec.js +0 -1
  461. package/dist/tests/session.spec.js.map +0 -1
  462. package/jestconfig.integration.json +0 -12
  463. package/src/adapter/paper/simulator/paper-margin-simulator.ts +0 -108
  464. package/src/adapter/paper/simulator/paper-simulator.ts +0 -120
  465. package/src/adapter/paper/simulator/paper-spot-simulator.spec.ts +0 -87
  466. package/src/adapter/paper/simulator/paper-spot-simulator.ts +0 -134
  467. package/src/domain/statement.ts +0 -118
  468. package/src/ipc.spec.ts +0 -73
  469. package/src/ipc.ts +0 -321
  470. package/src/shared/policy.spec.ts +0 -29
  471. package/src/shared/task.ts +0 -30
  472. package/src/shared/topic.spec.ts +0 -34
  473. package/src/shared/topic.ts +0 -43
  474. package/src/shared/worker.spec.ts +0 -25
  475. package/src/shared/worker.ts +0 -55
  476. package/src/store/event/index.ts +0 -8
  477. package/src/store/event/store-balance.event.ts +0 -161
  478. package/src/store/event/store-candle.event.spec.ts +0 -30
  479. package/src/store/event/store-candle.event.ts +0 -71
  480. package/src/store/event/store-instrument.event.spec.ts +0 -25
  481. package/src/store/event/store-instrument.event.ts +0 -84
  482. package/src/store/event/store-order.event.spec.ts +0 -28
  483. package/src/store/event/store-order.event.ts +0 -218
  484. package/src/store/event/store-orderbook.event.ts +0 -70
  485. package/src/store/event/store-position.event.ts +0 -109
  486. package/src/store/event/store-trade.event.ts +0 -52
  487. package/src/store/event/store.event.ts +0 -6
  488. package/src/store/store.state.ts +0 -43
  489. package/src/tests/backtester-adapter.spec.ts +0 -87
  490. package/src/tests/session.spec.ts +0 -121
@@ -1,16 +1,4 @@
1
- import {
2
- concat,
3
- filter,
4
- last,
5
- map,
6
- mergeMap,
7
- Observable,
8
- share,
9
- skipLast,
10
- withLatestFrom
11
- } from 'rxjs';
12
1
  import { timestamp } from '../shared';
13
- import { tf } from './timeframe';
14
2
 
15
3
  export class Candle {
16
4
  constructor(
@@ -18,7 +6,8 @@ export class Candle {
18
6
  public open: number,
19
7
  public high: number,
20
8
  public low: number,
21
- public close: number
9
+ public close: number,
10
+ public volume?: number
22
11
  ) {}
23
12
 
24
13
  apply(value: number) {
@@ -27,94 +16,3 @@ export class Candle {
27
16
  this.close = value;
28
17
  }
29
18
  }
30
-
31
- export class CandleBuilder {
32
- private _candle: Candle;
33
-
34
- get candle(): Candle {
35
- return this._candle;
36
- }
37
-
38
- constructor(readonly timeframe: number) {}
39
-
40
- append(value: number, timestamp: timestamp): Candle {
41
- const frame = tf(timestamp, this.timeframe);
42
-
43
- if (!this._candle) {
44
- this._candle = new Candle(frame, value, value, value, value);
45
-
46
- return null;
47
- }
48
-
49
- if (this.candle.timestamp == frame) {
50
- this.candle.apply(value);
51
-
52
- return null;
53
- }
54
-
55
- const previous = this._candle;
56
-
57
- this._candle = new Candle(frame, value, value, value, value);
58
- return previous;
59
- }
60
- }
61
-
62
- export function candle<T extends { timestamp: number }>(
63
- timeframe: number,
64
- fn: (x: T) => number
65
- ) {
66
- return function (source: Observable<T>): Observable<Candle> {
67
- const builder = new CandleBuilder(timeframe);
68
- let candle: Candle;
69
-
70
- return source.pipe(
71
- filter(it => {
72
- return (candle = builder.append(fn(it), it.timestamp)) != null;
73
- }),
74
- map(_ => candle),
75
- share()
76
- );
77
- };
78
- }
79
-
80
- export function mergeCandle<T extends { timestamp: number }>(
81
- timeframe: number,
82
- fn: (x: T) => number,
83
- history$: Observable<Candle>
84
- ) {
85
- return function (source$: Observable<T>): Observable<Candle> {
86
- const builder = new CandleBuilder(timeframe);
87
- let hasMergedHistory = false;
88
-
89
- return concat(
90
- history$.pipe(skipLast(1)),
91
- source$.pipe(
92
- withLatestFrom(history$.pipe(last())),
93
- mergeMap(([it, history]) => {
94
- const completed = builder.append(fn(it), it.timestamp);
95
-
96
- if (completed) {
97
- if (completed.timestamp == history.timestamp) {
98
- completed.open = history.open;
99
- completed.high = Math.max(completed.high, history.high);
100
- completed.low = Math.min(completed.low, history.low);
101
-
102
- hasMergedHistory = true;
103
- } else if (completed.timestamp > history.timestamp) {
104
- if (!hasMergedHistory) {
105
- hasMergedHistory = true;
106
- return [history, completed];
107
- }
108
- } else if (completed.timestamp < history.timestamp) {
109
- throw new Error('invalid candle sequence, input data is to old.');
110
- }
111
-
112
- return [completed];
113
- }
114
-
115
- return [];
116
- })
117
- )
118
- );
119
- };
120
- }
@@ -0,0 +1,33 @@
1
+ import { commissionPercentOf } from './commission';
2
+
3
+ describe('Commission', () => {
4
+ test('should construct a Commission', () => {
5
+ const sut = commissionPercentOf({
6
+ maker: 0.1,
7
+ taker: 0.2
8
+ });
9
+
10
+ expect(sut.makerRate).toEqual(0.001);
11
+ expect(sut.takerRate).toEqual(0.002);
12
+ });
13
+
14
+ test('should calculate a maker fee', () => {
15
+ const sut = commissionPercentOf({
16
+ maker: 0.1,
17
+ taker: 0.2
18
+ });
19
+
20
+ expect(sut.calculateMakerFee(2000)).toEqual(2);
21
+ expect(sut.applyMakerFee(2000)).toEqual(1998);
22
+ });
23
+
24
+ test('should calculate a taker fee', () => {
25
+ const sut = commissionPercentOf({
26
+ maker: 0.1,
27
+ taker: 0.2
28
+ });
29
+
30
+ expect(sut.calculateTakerFee(2000)).toEqual(4);
31
+ expect(sut.applyTakerFee(2000)).toEqual(1996);
32
+ });
33
+ });
@@ -18,6 +18,6 @@ export class Commission {
18
18
  }
19
19
  }
20
20
 
21
- export function commissionPercentOf(maker: number, taker: number) {
22
- return new Commission(maker / 100.0, taker / 100.0);
21
+ export function commissionPercentOf(fees: { maker: number; taker: number }) {
22
+ return new Commission(fees.maker / 100.0, fees.taker / 100.0);
23
23
  }
@@ -1,5 +1,7 @@
1
1
  import { timestamp } from '../shared';
2
2
 
3
3
  export interface Component {
4
+ id: string;
5
+ kind: string;
4
6
  timestamp: timestamp;
5
7
  }
@@ -0,0 +1,25 @@
1
+ export function insufficientFundsError(
2
+ assetName: string,
3
+ requiredAmount: number,
4
+ availableAmount: number
5
+ ) {
6
+ return new Error(
7
+ `insufficient funds of ${assetName} has: ${availableAmount} requires: ${requiredAmount}`
8
+ );
9
+ }
10
+
11
+ export function invalidArgumentError(value: any) {
12
+ throw new Error(`invalid argument: ${value}`);
13
+ }
14
+
15
+ export function invalidAssetSelectorError(selector: string) {
16
+ throw new Error(`invalid asset selector: ${selector}`);
17
+ }
18
+
19
+ export function invalidInstrumentSelectorError(selector: string) {
20
+ throw new Error(`invalid instrument selector: ${selector}`);
21
+ }
22
+
23
+ export function adapterMismatchError() {
24
+ return new Error('adapters must be the same');
25
+ }
@@ -1,13 +1,20 @@
1
1
  export * from './asset';
2
2
  export * from './balance';
3
+ export * from './balance.operator';
4
+ export * from './error';
3
5
  export * from './candle';
6
+ export * from './candle.operator';
4
7
  export * from './commission';
5
8
  export * from './component';
6
9
  export * from './instrument';
10
+ export * from './instrument.operator';
7
11
  export * from './order';
12
+ export * from './order.operator';
8
13
  export * from './orderbook';
14
+ export * from './orderbook.operator';
9
15
  export * from './position';
16
+ export * from './position.operator';
10
17
  export * from './session';
11
- export * from './statement';
12
18
  export * from './timeframe';
13
19
  export * from './trade';
20
+ export * from './trade.operator';
@@ -0,0 +1,28 @@
1
+ import { Subject } from 'rxjs';
2
+
3
+ import { State } from '../store';
4
+ import { Asset } from './asset';
5
+ import { Component } from './component';
6
+ import { Instrument, instrumentOf } from './instrument';
7
+ import { instrument } from './instrument.operator';
8
+
9
+ describe('instrument', () => {
10
+ const state = new State();
11
+
12
+ beforeEach(() => {
13
+ state.universe.instrument.upsert(
14
+ new Instrument(new Asset('abc', 'xyz', 4), new Asset('def', 'xyz', 4), 'abc-def')
15
+ );
16
+ });
17
+
18
+ test('should pipe an instrument on subscription', done => {
19
+ new Subject<Component>()
20
+ .pipe(instrument(instrumentOf('xyz:abc-def'), state))
21
+ .subscribe({
22
+ next: it => {
23
+ expect(it.id).toEqual('xyz:abc-def');
24
+ done();
25
+ }
26
+ });
27
+ });
28
+ });
@@ -0,0 +1,25 @@
1
+ import { distinctUntilChanged, filter, map, Observable, startWith } from 'rxjs';
2
+
3
+ import { State } from '../store';
4
+ import { Component } from './component';
5
+ import { Instrument, InstrumentSelector } from './instrument';
6
+
7
+ export function instrument(selector: InstrumentSelector, state: State) {
8
+ return (source$: Observable<Component>) =>
9
+ source$.pipe(
10
+ startWith(state.universe.instrument.get(selector.id)),
11
+ filter(it => it instanceof Instrument && it.id == selector.id),
12
+ map(it => it as Instrument)
13
+ );
14
+ }
15
+
16
+ export function instruments(state: State) {
17
+ return (source$: Observable<Component>) =>
18
+ source$.pipe(
19
+ filter(it => it instanceof Instrument),
20
+ map(() => state.universe.instrument.asReadonlyArray()),
21
+ startWith(state.universe.instrument.asReadonlyArray()),
22
+ filter(it => it.length > 0),
23
+ distinctUntilChanged((lhs, rhs) => lhs.length == rhs.length)
24
+ );
25
+ }
@@ -1,8 +1,8 @@
1
1
  import { Asset, assetOf } from './asset';
2
2
  import { Instrument, instrumentOf } from './instrument';
3
3
 
4
- describe('instrument tests', () => {
5
- test('should instantiate proper instrument', () => {
4
+ describe('Instrument', () => {
5
+ test('should construct a instrument', () => {
6
6
  const sut = new Instrument(
7
7
  new Asset('abc', 'xyz', 4),
8
8
  new Asset('def', 'xyz', 4),
@@ -10,63 +10,55 @@ describe('instrument tests', () => {
10
10
  );
11
11
 
12
12
  expect(sut.base.name).toEqual('abc');
13
- expect(sut.base.adapter).toEqual('xyz');
13
+ expect(sut.base.adapterName).toEqual('xyz');
14
14
  expect(sut.quote.name).toEqual('def');
15
- expect(sut.quote.adapter).toEqual('xyz');
16
- expect(sut.toString()).toEqual('xyz:abc-def');
15
+ expect(sut.quote.adapterName).toEqual('xyz');
16
+ expect(sut.id).toEqual('xyz:abc-def');
17
17
  });
18
18
  });
19
19
 
20
- describe('instrument selector tests', () => {
21
- test('should instantiate proper instrument selector', () => {
20
+ describe('InstrumentSelector', () => {
21
+ test('should construct a instrument selector', () => {
22
22
  const sut = instrumentOf('xyz:abc-def');
23
23
 
24
24
  expect(sut.base.name).toEqual('abc');
25
- expect(sut.base.adapter).toEqual('xyz');
25
+ expect(sut.base.adapterName).toEqual('xyz');
26
26
  expect(sut.quote.name).toEqual('def');
27
- expect(sut.quote.adapter).toEqual('xyz');
28
- expect(sut.toString()).toEqual('xyz:abc-def');
27
+ expect(sut.quote.adapterName).toEqual('xyz');
28
+ expect(sut.id).toEqual('xyz:abc-def');
29
29
  });
30
30
 
31
- test('should instantiate proper instrument selector capital case', () => {
31
+ test('should construct a instrument selector capital case', () => {
32
32
  const sut = instrumentOf('XYZ:ABC-DEF');
33
33
 
34
34
  expect(sut.base.name).toEqual('abc');
35
- expect(sut.base.adapter).toEqual('xyz');
35
+ expect(sut.base.adapterName).toEqual('xyz');
36
36
  expect(sut.quote.name).toEqual('def');
37
- expect(sut.quote.adapter).toEqual('xyz');
38
- expect(sut.toString()).toEqual('xyz:abc-def');
37
+ expect(sut.quote.adapterName).toEqual('xyz');
38
+ expect(sut.id).toEqual('xyz:abc-def');
39
39
  });
40
40
 
41
41
  test('should throw invalid format message for missing separator', () => {
42
- const fn = () => {
43
- instrumentOf('xyzabc-def');
44
- };
42
+ const fn = () => instrumentOf('xyzabc-def');
45
43
 
46
- expect(fn).toThrow(Error);
44
+ expect(fn).toThrowError();
47
45
  });
48
46
 
49
47
  test('should throw invalid format message for multiple separators', () => {
50
- const fn = () => {
51
- instrumentOf('xyz:abc:-def');
52
- };
48
+ const fn = () => instrumentOf('xyz:abc:-def');
53
49
 
54
- expect(fn).toThrow(Error);
50
+ expect(fn).toThrowError();
55
51
  });
56
52
 
57
53
  test('should throw invalid format message for missing pair name', () => {
58
- const fn = () => {
59
- instrumentOf('xyz:');
60
- };
54
+ const fn = () => instrumentOf('xyz:');
61
55
 
62
- expect(fn).toThrow(Error);
56
+ expect(fn).toThrowError();
63
57
  });
64
58
 
65
59
  test('should throw invalid format message for missing adapter name', () => {
66
- const fn = () => {
67
- assetOf(':abc-def');
68
- };
60
+ const fn = () => assetOf(':abc-def');
69
61
 
70
- expect(fn).toThrow(Error);
62
+ expect(fn).toThrowError();
71
63
  });
72
64
  });
@@ -1,11 +1,13 @@
1
1
  import { timestamp } from '../shared';
2
- import { Asset, AssetSelector } from './asset';
2
+ import { Asset, AssetSelector, AssetSelectorSeparator } from './asset';
3
3
  import { Commission } from './commission';
4
4
  import { Component } from './component';
5
+ import { adapterMismatchError, invalidInstrumentSelectorError } from './error';
5
6
 
6
- export class InstrumentSelector {
7
- private readonly id: string;
7
+ export const InstrumentSelectorSeparator = '-';
8
8
 
9
+ export class InstrumentSelector {
10
+ readonly id: string;
9
11
  readonly base: AssetSelector;
10
12
  readonly quote: AssetSelector;
11
13
 
@@ -13,7 +15,7 @@ export class InstrumentSelector {
13
15
  this.base = new AssetSelector(base.toLowerCase(), adapter.toLowerCase());
14
16
  this.quote = new AssetSelector(quote.toLowerCase(), adapter.toLowerCase());
15
17
 
16
- this.id = `${this.base.toString()}-${this.quote.name}`;
18
+ this.id = `${this.base.id}${InstrumentSelectorSeparator}${this.quote.name}`;
17
19
  }
18
20
 
19
21
  toString(): string {
@@ -25,23 +27,31 @@ export class InstrumentSelector {
25
27
  * Represents trading market which is made up by two trading assets (base and quoted).
26
28
  */
27
29
  export class Instrument extends InstrumentSelector implements Component {
30
+ kind = 'instrument';
28
31
  timestamp: timestamp;
29
32
  commission: Commission;
30
33
  cross: Instrument;
31
34
  leverage?: number = null;
32
35
 
33
36
  constructor(readonly base: Asset, readonly quote: Asset, readonly raw: string) {
34
- super(base.name, quote.name, base.adapter);
37
+ super(base.name, quote.name, base.adapterName);
35
38
 
36
- if (base.adapter != quote.adapter) {
37
- throw new Error('Adapter mismatch!');
39
+ if (base.adapterName != quote.adapterName) {
40
+ throw adapterMismatchError();
38
41
  }
39
42
  }
40
43
  }
41
44
 
42
- export function instrumentOf(instrument: string): InstrumentSelector {
43
- const section = instrument.split(':');
44
- const asset = section[1].split('-');
45
+ export function instrumentOf(selector: string): InstrumentSelector {
46
+ const [adapterName, asset, ...rest] = selector.split(AssetSelectorSeparator);
47
+ if (!adapterName || !asset || rest.length) {
48
+ throw invalidInstrumentSelectorError(selector);
49
+ }
50
+
51
+ const [baseAssetName, quoteAssetName] = asset.split(InstrumentSelectorSeparator);
52
+ if (!baseAssetName || !quoteAssetName) {
53
+ throw invalidInstrumentSelectorError(selector);
54
+ }
45
55
 
46
- return new InstrumentSelector(asset[0], asset[1], section[0]);
56
+ return new InstrumentSelector(baseAssetName, quoteAssetName, adapterName);
47
57
  }
@@ -0,0 +1,81 @@
1
+ import { BehaviorSubject, map, Subject } from 'rxjs';
2
+
3
+ import { InnerSet, State } from '../store';
4
+ import { Asset } from './asset';
5
+ import { Component } from './component';
6
+ import { Instrument } from './instrument';
7
+ import { Order } from './order';
8
+ import { order, orders } from './order.operator';
9
+
10
+ const instrument = new Instrument(
11
+ new Asset('abc', 'xyz', 4),
12
+ new Asset('def', 'xyz', 4),
13
+ 'abc-def'
14
+ );
15
+
16
+ describe('order', () => {
17
+ test('should pipe an order', done => {
18
+ new BehaviorSubject<Component>(Order.market(instrument, -100))
19
+ .pipe(order(instrument))
20
+ .subscribe({
21
+ next: it => {
22
+ expect(it.instrument).toEqual(instrument);
23
+ expect(it.quantity).toEqual(-100);
24
+ done();
25
+ }
26
+ });
27
+ });
28
+
29
+ test('should skip a pipe', done => {
30
+ new BehaviorSubject<Component>(instrument).pipe(order(instrument)).subscribe({
31
+ next: () => fail(),
32
+ complete: done()
33
+ });
34
+ });
35
+ });
36
+
37
+ describe('positions', () => {
38
+ let state: State;
39
+ let order1: Order, order2: Order, order3: Order;
40
+
41
+ beforeEach(() => {
42
+ state = new State();
43
+
44
+ order1 = Order.market(instrument, -100);
45
+ order2 = Order.limit(instrument, 100, 10);
46
+ order3 = Order.market(instrument, 100);
47
+
48
+ state.order.upsert(new InnerSet<Order>(instrument.id, [order1, order2, order3]));
49
+ });
50
+
51
+ test('should pipe all orders on subscription start', done => {
52
+ order1.state = 'NEW';
53
+ order2.state = 'NEW';
54
+ order3.state = 'NEW';
55
+
56
+ new Subject<Component>().pipe(orders(instrument, state)).subscribe({
57
+ next: it => {
58
+ expect(it.length).toEqual(3);
59
+ done();
60
+ }
61
+ });
62
+ });
63
+
64
+ test('should pipe pending orders on subscription start', done => {
65
+ order1.state = 'NEW';
66
+ order2.state = 'PENDING';
67
+ order3.state = 'PENDING';
68
+
69
+ new Subject<Component>()
70
+ .pipe(
71
+ orders(instrument, state),
72
+ map(it => it.filter(order => order.state === 'PENDING'))
73
+ )
74
+ .subscribe({
75
+ next: it => {
76
+ expect(it.length).toEqual(2);
77
+ done();
78
+ }
79
+ });
80
+ });
81
+ });
@@ -0,0 +1,23 @@
1
+ import { filter, map, Observable, startWith } from 'rxjs';
2
+
3
+ import { State } from '../store';
4
+ import { Component } from './component';
5
+ import { InstrumentSelector } from './instrument';
6
+ import { Order } from './order';
7
+
8
+ export function order(selector: InstrumentSelector) {
9
+ return (source$: Observable<Component>) =>
10
+ source$.pipe(
11
+ filter(it => it instanceof Order && it.instrument.id == selector.id),
12
+ map(it => it as Order)
13
+ );
14
+ }
15
+
16
+ export function orders(selector: InstrumentSelector, state: State) {
17
+ return (source$: Observable<Component>) =>
18
+ source$.pipe(
19
+ filter(it => it instanceof Order && it.instrument.id == selector.id),
20
+ map(() => state.order.get(selector.id).asReadonlyArray()),
21
+ startWith(state.order.get(selector.id).asReadonlyArray())
22
+ );
23
+ }
@@ -0,0 +1,43 @@
1
+ import { Asset } from './asset';
2
+ import { Instrument } from './instrument';
3
+ import { Order } from './order';
4
+
5
+ describe('Order', () => {
6
+ const instrument = new Instrument(
7
+ new Asset('abc', 'xyz', 4),
8
+ new Asset('def', 'xyz', 4),
9
+ 'abc-def'
10
+ );
11
+
12
+ test('should construct a market buy order', () => {
13
+ const sut = Order.market(instrument, 100);
14
+
15
+ expect(sut.quantity).toEqual(100);
16
+ expect(sut.rate).toEqual(undefined);
17
+ expect(sut.type).toEqual('MARKET');
18
+ });
19
+
20
+ test('should construct a market sell order', () => {
21
+ const sut = Order.market(instrument, -100);
22
+
23
+ expect(sut.quantity).toEqual(-100);
24
+ expect(sut.rate).toEqual(undefined);
25
+ expect(sut.type).toEqual('MARKET');
26
+ });
27
+
28
+ test('should construct a limit buy order', () => {
29
+ const sut = Order.limit(instrument, 100, 2000);
30
+
31
+ expect(sut.quantity).toEqual(100);
32
+ expect(sut.rate).toEqual(2000);
33
+ expect(sut.type).toEqual('LIMIT');
34
+ });
35
+
36
+ test('should construct a limit sell order', () => {
37
+ const sut = Order.limit(instrument, -100, 2000);
38
+
39
+ expect(sut.quantity).toEqual(-100);
40
+ expect(sut.rate).toEqual(2000);
41
+ expect(sut.type).toEqual('LIMIT');
42
+ });
43
+ });