Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ stream.latestTradeDetail$.subscribe((v) => {})
- [ ] Export fund flow
- [ ] User fee rate
* Trade Interface
- [ ] Trade order test
- [x] Trade order test
- [x] Trade order
- [ ] Bulk order
- [x] One-Click Close All Positions
Expand Down
44 changes: 44 additions & 0 deletions src/bingx-client/services/trade.service.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
import { AccountInterface } from 'bingx-api/bingx/account/account.interface';
import { BingxTradeOrderTestEndpoint } from 'bingx-api/bingx/endpoints/bingx-trade-order-test-endpoint';
import { OrderSideEnum, OrderTypeEnum } from 'bingx-api/bingx/enums';
import { BingxCreateTradeOrderInterface } from 'bingx-api/bingx/interfaces/trade-order.interface';
import { RequestExecutorInterface } from 'bingx-api/bingx/request-executor/request-executor.interface';
import { TradeService } from 'bingx-api/bingx-client/services/trade.service';

describe('TradeService', () => {
describe('createTradeOrderTest', () => {
it('executes the test order endpoint with the order payload', async () => {
const requestExecutor: jest.Mocked<RequestExecutorInterface> = {
execute: jest.fn().mockResolvedValue({ code: 0, data: {} }),
};
const account: AccountInterface = {
getApiKey: jest.fn().mockReturnValue('api-key'),
sign: jest.fn().mockReturnValue({
toString: () => 'signature',
secretKey: () => 'secret',
}),
};
const order: BingxCreateTradeOrderInterface = {
symbol: 'BTC-USDT',
type: OrderTypeEnum.MARKET,
side: OrderSideEnum.BUY,
quantity: '0.01',
};

await new TradeService(requestExecutor).createTradeOrderTest(
order,
account,
);

expect(requestExecutor.execute).toHaveBeenCalledTimes(1);

const endpoint = requestExecutor.execute.mock.calls[0][0];
expect(endpoint).toBeInstanceOf(BingxTradeOrderTestEndpoint);
expect(endpoint.path()).toBe('/openApi/swap/v2/trade/order/test');
expect(endpoint.method()).toBe('post');
expect(endpoint.parameters().asRecord()).toEqual(
expect.objectContaining(order),
);
});
});
});
3 changes: 2 additions & 1 deletion src/bingx-client/services/trade.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import { BingxSwitchLeverageEndpoint } from 'bingx-api/bingx/endpoints/bingx-swi
import { OrderPositionSideEnum } from 'bingx-api/bingx';
import { BingxUserHistoryOrdersEndpoint } from 'bingx-api/bingx/endpoints/bingx-user-history-orders-endpoint';
import { BingxCancelOrderEndpoint } from 'bingx-api/bingx/endpoints/bingx-cancel-order-endpoint';
import { BingxTradeOrderTestEndpoint } from 'bingx-api/bingx/endpoints/bingx-trade-order-test-endpoint';

export class TradeService {
constructor(private readonly requestExecutor: RequestExecutorInterface) {}
Expand All @@ -30,7 +31,7 @@ export class TradeService {
account: AccountInterface,
) {
return this.requestExecutor.execute(
new BingxTradeOrderEndpoint(order, account),
new BingxTradeOrderTestEndpoint(order, account),
);
}

Expand Down
1 change: 1 addition & 0 deletions src/bingx/endpoints/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ export * from './bingx-perpetual-swap-positions-endpoint';
export * from './bingx-request.interface';
export * from './bingx-response.interface';
export * from './bingx-trade-order-endpoint';
export { BingxTradeOrderTestEndpoint } from './bingx-trade-order-test-endpoint';
export * from './endpoint.interface';
export * from './endpoint';
export * from './bingx-user-history-orders-endpoint';
Expand Down