Skip to content

Commit

Permalink
SQS-375 | Unit test createFormattedLimitOrder (#492)
Browse files Browse the repository at this point in the history
* SQS-375 | Unit test createFormattedLimitOrder

Introduces unit tests for Orderbook usecase createFormattedLimitOrder
method.

* SQS-377 | Unit test ProcessPool

Introduces unit tests for Orderbook usecase ProcessPool
method.

* SQS-378 | Test GetActiveOrders

Implements tests for GetActiveOrders orderbook usecase method

* SQS-379 | processOrderBookActiveOrders

Implements tests for processOrderBookActiveOrders orderbook usecase method.
As a side effect introduces some helper methods and refactors some test
cases.
  • Loading branch information
deividaspetraitis authored Sep 9, 2024
1 parent 142faa7 commit ec649ca
Show file tree
Hide file tree
Showing 24 changed files with 2,462 additions and 218 deletions.
5 changes: 5 additions & 0 deletions .swaggo
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
// Swagger overrides file
// @link https://github.com/swaggo/swag?tab=readme-ov-file#use-global-overrides-to-support-a-custom-type

// Replace all Dec with string
replace osmomath.Dec string
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ generate-mocks: mockery
bin/mockery --config mockery.yaml

swagger-gen:
$(HOME)/go/bin/swag init -g app/main.go
$(HOME)/go/bin/swag init -g app/main.go --pd --overridesFile ./.swaggo

run:
go run -ldflags="-X github.com/osmosis-labs/sqs/version=${VERSION}" app/*.go --config config.json
Expand Down
208 changes: 205 additions & 3 deletions docs/docs.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,44 @@ const docTemplate = `{
"host": "{{.Host}}",
"basePath": "{{.BasePath}}",
"paths": {
"/passthrough/active-orders": {
"get": {
"description": "The returned data represents all active orders for all orderbooks available for the specified address.",
"produces": [
"application/json"
],
"summary": "Returns all active orderbook orders associated with the given address.",
"parameters": [
{
"type": "string",
"description": "Osmo wallet address",
"name": "userOsmoAddress",
"in": "query",
"required": true
}
],
"responses": {
"200": {
"description": "List of active orders for all available orderboooks for the given address",
"schema": {
"$ref": "#/definitions/github_com_osmosis-labs_sqs_orderbook_types.GetActiveOrdersResponse"
}
},
"400": {
"description": "Response error",
"schema": {
"$ref": "#/definitions/domain.ResponseError"
}
},
"500": {
"description": "Response error",
"schema": {
"$ref": "#/definitions/domain.ResponseError"
}
}
}
}
},
"/passthrough/portfolio-assets/{address}": {
"get": {
"description": "The returned data represents the potfolio asset breakdown by category for the specified address.",
Expand All @@ -35,13 +73,13 @@ const docTemplate = `{
"200": {
"description": "Portfolio assets by-category and capitalization of the entire account value",
"schema": {
"type": "struct"
"$ref": "#/definitions/github_com_osmosis-labs_sqs_domain_passthrough.PortfolioAssetsResult"
}
},
"500": {
"description": "Response error",
"schema": {
"type": "struct"
"$ref": "#/definitions/domain.ResponseError"
}
}
}
Expand Down Expand Up @@ -113,7 +151,7 @@ const docTemplate = `{
"200": {
"description": "Canonical Orderbook Pool ID for the given base and quote",
"schema": {
"type": "struct"
"$ref": "#/definitions/domain.CanonicalOrderBooksResult"
}
}
}
Expand Down Expand Up @@ -436,6 +474,14 @@ const docTemplate = `{
}
}
},
"domain.ResponseError": {
"type": "object",
"properties": {
"message": {
"type": "string"
}
}
},
"domain.Token": {
"type": "object",
"properties": {
Expand Down Expand Up @@ -464,6 +510,159 @@ const docTemplate = `{
}
}
},
"github_com_cosmos_cosmos-sdk_types.Coin": {
"type": "object",
"properties": {
"amount": {
"$ref": "#/definitions/types.Int"
},
"denom": {
"type": "string"
}
}
},
"github_com_osmosis-labs_sqs_domain_orderbook.Asset": {
"type": "object",
"properties": {
"symbol": {
"type": "string"
}
}
},
"github_com_osmosis-labs_sqs_domain_orderbook.LimitOrder": {
"type": "object",
"properties": {
"base_asset": {
"$ref": "#/definitions/github_com_osmosis-labs_sqs_domain_orderbook.Asset"
},
"claim_bounty": {
"type": "string"
},
"etas": {
"type": "string"
},
"order_direction": {
"type": "string"
},
"order_id": {
"type": "integer"
},
"orderbookAddress": {
"type": "string"
},
"output": {
"type": "string"
},
"owner": {
"type": "string"
},
"percentClaimed": {
"type": "string"
},
"percentFilled": {
"type": "string"
},
"placed_at": {
"type": "integer"
},
"placed_quantity": {
"type": "string"
},
"placed_tx": {
"type": "string"
},
"price": {
"type": "string"
},
"quantity": {
"type": "string"
},
"quote_asset": {
"$ref": "#/definitions/github_com_osmosis-labs_sqs_domain_orderbook.Asset"
},
"status": {
"$ref": "#/definitions/github_com_osmosis-labs_sqs_domain_orderbook.OrderStatus"
},
"tick_id": {
"type": "integer"
},
"totalFilled": {
"type": "string"
}
}
},
"github_com_osmosis-labs_sqs_domain_orderbook.OrderStatus": {
"type": "string",
"enum": [
"open",
"partiallyFilled",
"filled",
"fullyClaimed",
"cancelled"
],
"x-enum-varnames": [
"StatusOpen",
"StatusPartiallyFilled",
"StatusFilled",
"StatusFullyClaimed",
"StatusCancelled"
]
},
"github_com_osmosis-labs_sqs_domain_passthrough.AccountCoinsResult": {
"type": "object",
"properties": {
"cap_value": {
"type": "string"
},
"coin": {
"$ref": "#/definitions/github_com_cosmos_cosmos-sdk_types.Coin"
}
}
},
"github_com_osmosis-labs_sqs_domain_passthrough.PortfolioAssetsCategoryResult": {
"type": "object",
"properties": {
"account_coins_result": {
"description": "AccountCoinsResult represents coins only from user balances (contrary to TotalValueCap).",
"type": "array",
"items": {
"$ref": "#/definitions/github_com_osmosis-labs_sqs_domain_passthrough.AccountCoinsResult"
}
},
"capitalization": {
"description": "Capitalization represents the total value of the assets in the portfolio.\nincludes capitalization of user balances, value in locks, bonding or unbonding\nas well as the concentrated positions.",
"type": "string"
},
"is_best_effort": {
"type": "boolean"
}
}
},
"github_com_osmosis-labs_sqs_domain_passthrough.PortfolioAssetsResult": {
"type": "object",
"properties": {
"categories": {
"type": "object",
"additionalProperties": {
"$ref": "#/definitions/github_com_osmosis-labs_sqs_domain_passthrough.PortfolioAssetsCategoryResult"
}
}
}
},
"github_com_osmosis-labs_sqs_orderbook_types.GetActiveOrdersResponse": {
"type": "object",
"properties": {
"is_best_effort": {
"type": "boolean"
},
"orders": {
"type": "array",
"items": {
"$ref": "#/definitions/github_com_osmosis-labs_sqs_domain_orderbook.LimitOrder"
}
}
}
},
"sqsdomain.CandidatePool": {
"type": "object",
"properties": {
Expand Down Expand Up @@ -508,6 +707,9 @@ const docTemplate = `{
}
}
}
},
"types.Int": {
"type": "object"
}
}
}`
Expand Down
Loading

0 comments on commit ec649ca

Please sign in to comment.