From 0c663b7f567d75bf2abd61ba99dc526b84ce4594 Mon Sep 17 00:00:00 2001 From: Deividas Petraitis Date: Mon, 23 Sep 2024 17:37:15 +0300 Subject: [PATCH] SQS-417 | Fix orderbook order Quantity parsing (#519) --- domain/orderbook/order.go | 5 +-- domain/orderbook/order_test.go | 77 ++++++++++++++++++++++++++++++++++ 2 files changed, 79 insertions(+), 3 deletions(-) create mode 100644 domain/orderbook/order_test.go diff --git a/domain/orderbook/order.go b/domain/orderbook/order.go index d5c89df81..dd48b1f22 100644 --- a/domain/orderbook/order.go +++ b/domain/orderbook/order.go @@ -2,7 +2,6 @@ package orderbookdomain import ( "fmt" - "strconv" "github.com/osmosis-labs/osmosis/osmomath" ) @@ -34,12 +33,12 @@ type Order struct { // Status returns the status of the order based on the percent filled. func (o Order) Status(percentFilled float64) (OrderStatus, error) { - quantity, err := strconv.Atoi(o.Quantity) + quantity, err := osmomath.NewDecFromStr(o.Quantity) if err != nil { return "", fmt.Errorf("error parsing quantity: %w", err) } - if quantity == 0 || percentFilled == 1 { + if quantity.IsZero() || percentFilled == 1 { return StatusFilled, nil } diff --git a/domain/orderbook/order_test.go b/domain/orderbook/order_test.go new file mode 100644 index 000000000..8a0e69afe --- /dev/null +++ b/domain/orderbook/order_test.go @@ -0,0 +1,77 @@ +package orderbookdomain_test + +import ( + "testing" + + orderbookdomain "github.com/osmosis-labs/sqs/domain/orderbook" + + "github.com/stretchr/testify/assert" +) + +func TestOrderStatus(t *testing.T) { + tests := []struct { + name string + order orderbookdomain.Order + percentFilled float64 + expected orderbookdomain.OrderStatus + expectError bool + }{ + { + name: "Valid quantity, percentFilled = 0", + order: orderbookdomain.Order{Quantity: "100.0"}, + percentFilled: 0, + expected: orderbookdomain.StatusOpen, + expectError: false, + }, + { + name: "Valid quantity, percentFilled = 1", + order: orderbookdomain.Order{Quantity: "100.0"}, + percentFilled: 1, + expected: orderbookdomain.StatusFilled, + expectError: false, + }, + { + name: "Valid quantity, percentFilled < 1", + order: orderbookdomain.Order{Quantity: "100.0"}, + percentFilled: 0.5, + expected: orderbookdomain.StatusPartiallyFilled, + expectError: false, + }, + { + name: "Zero quantity", + order: orderbookdomain.Order{Quantity: "0"}, + percentFilled: 1, + expected: orderbookdomain.StatusFilled, + expectError: false, + }, + { + name: "Invalid quantity string", + order: orderbookdomain.Order{Quantity: "invalid"}, + percentFilled: 1, + expectError: true, + }, + { + name: "Empty quantity string", + order: orderbookdomain.Order{Quantity: ""}, + percentFilled: 1, + expectError: true, + }, + { + name: "Out of range quantity string", + order: orderbookdomain.Order{Quantity: "101960000000000000000"}, + expected: orderbookdomain.StatusFilled, + percentFilled: 1, + expectError: false, + }, + } + + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + status, err := tt.order.Status(tt.percentFilled) + if tt.expectError { + assert.Error(t, err) + } + assert.Equal(t, tt.expected, status) + }) + } +}