mirror of
https://github.com/c9s/bbgo.git
synced 2024-11-25 00:05:15 +00:00
trade: support custom order by column
This commit is contained in:
parent
be27d32bd8
commit
9fb273e6a1
|
@ -2,6 +2,7 @@ package service
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"fmt"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
@ -32,7 +33,11 @@ type QueryTradesOptions struct {
|
||||||
|
|
||||||
// ASC or DESC
|
// ASC or DESC
|
||||||
Ordering string
|
Ordering string
|
||||||
Limit uint64
|
|
||||||
|
// OrderByColumn is the column name to order by
|
||||||
|
// Currently we only support traded_at and gid column.
|
||||||
|
OrderByColumn string
|
||||||
|
Limit uint64
|
||||||
}
|
}
|
||||||
|
|
||||||
type TradingVolume struct {
|
type TradingVolume struct {
|
||||||
|
@ -304,12 +309,29 @@ func (s *TradeService) Query(options QueryTradesOptions) ([]types.Trade, error)
|
||||||
sel = sel.Where(sq.Eq{"exchange": options.Sessions})
|
sel = sel.Where(sq.Eq{"exchange": options.Sessions})
|
||||||
}
|
}
|
||||||
|
|
||||||
if options.Ordering != "" {
|
var orderByColumn string
|
||||||
sel = sel.OrderBy("traded_at " + options.Ordering)
|
switch options.OrderByColumn {
|
||||||
} else {
|
case "":
|
||||||
sel = sel.OrderBy("traded_at ASC")
|
orderByColumn = "traded_at"
|
||||||
|
case "traded_at", "gid":
|
||||||
|
orderByColumn = options.OrderByColumn
|
||||||
|
default:
|
||||||
|
return nil, fmt.Errorf("invalid order by column: %s", options.OrderByColumn)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var ordering string
|
||||||
|
|
||||||
|
switch strings.ToUpper(options.Ordering) {
|
||||||
|
case "":
|
||||||
|
ordering = "ASC"
|
||||||
|
case "ASC", "DESC":
|
||||||
|
ordering = strings.ToUpper(options.Ordering)
|
||||||
|
default:
|
||||||
|
return nil, fmt.Errorf("invalid ordering: %s", options.Ordering)
|
||||||
|
}
|
||||||
|
|
||||||
|
sel = sel.OrderBy(orderByColumn + " " + ordering)
|
||||||
|
|
||||||
if options.Limit > 0 {
|
if options.Limit > 0 {
|
||||||
sel = sel.Limit(options.Limit)
|
sel = sel.Limit(options.Limit)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
package service
|
package service
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"database/sql"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/DATA-DOG/go-sqlmock"
|
||||||
"github.com/jmoiron/sqlx"
|
"github.com/jmoiron/sqlx"
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
|
@ -87,3 +89,32 @@ func Test_queryTradesSQL(t *testing.T) {
|
||||||
}))
|
}))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestTradeService_Query(t *testing.T) {
|
||||||
|
db, mock, err := sqlmock.New()
|
||||||
|
if !assert.NoError(t, err) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
defer db.Close()
|
||||||
|
|
||||||
|
sqlxDB := sqlx.NewDb(db, "mysql")
|
||||||
|
defer sqlxDB.Close()
|
||||||
|
|
||||||
|
s := NewTradeService(sqlxDB)
|
||||||
|
|
||||||
|
_, err = s.Query(QueryTradesOptions{Ordering: "test_ordering"})
|
||||||
|
assert.Error(t, err)
|
||||||
|
assert.Equal(t, "invalid ordering: test_ordering", err.Error())
|
||||||
|
|
||||||
|
_, err = s.Query(QueryTradesOptions{OrderByColumn: "invalid_column"})
|
||||||
|
assert.Error(t, err)
|
||||||
|
assert.Equal(t, "invalid order by column: invalid_column", err.Error())
|
||||||
|
|
||||||
|
mock.ExpectQuery("SELECT \\* FROM trades ORDER BY gid DESC").WillReturnError(sql.ErrNoRows)
|
||||||
|
_, err = s.Query(QueryTradesOptions{Ordering: "DESC", OrderByColumn: "gid"})
|
||||||
|
assert.Equal(t, sql.ErrNoRows, err)
|
||||||
|
|
||||||
|
mock.ExpectQuery("SELECT \\* FROM trades ORDER BY traded_at ASC").WillReturnError(sql.ErrNoRows)
|
||||||
|
_, err = s.Query(QueryTradesOptions{Ordering: "ASC", OrderByColumn: "traded_at"})
|
||||||
|
assert.Equal(t, sql.ErrNoRows, err)
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user