mirror of
https://github.com/ditatompel/xmr-remote-nodes.git
synced 2025-01-08 05:52:10 +07:00
Christian Ditaputratama
f0a10208e2
DEPRECATED: Using int value for CORS is deprecated, please use "on" to filter CORS capable nodes. Leave CORS empty to disable CORS filter.
150 lines
3.6 KiB
Go
150 lines
3.6 KiB
Go
package monero
|
|
|
|
import (
|
|
"os"
|
|
"reflect"
|
|
"strconv"
|
|
"testing"
|
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/config"
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/database"
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/paging"
|
|
)
|
|
|
|
var testMySQL = true
|
|
|
|
// TODO: Add database test table and then clean it up
|
|
func init() {
|
|
// load test db config from OS environment variable
|
|
//
|
|
// Example:
|
|
// TEST_DB_HOST=127.0.0.1 \
|
|
// TEST_DB_PORT=3306 \
|
|
// TEST_DB_USER=testuser \
|
|
// TEST_DB_PASSWORD=testpass \
|
|
// TEST_DB_NAME=testdb go test ./... -v
|
|
//
|
|
// To run benchmark only, add `-bench=. -run=^#` to the `go test` command
|
|
config.DBCfg().Host = os.Getenv("TEST_DB_HOST")
|
|
config.DBCfg().Port, _ = strconv.Atoi(os.Getenv("TEST_DB_PORT"))
|
|
config.DBCfg().User = os.Getenv("TEST_DB_USER")
|
|
config.DBCfg().Password = os.Getenv("TEST_DB_PASSWORD")
|
|
config.DBCfg().Name = os.Getenv("TEST_DB_NAME")
|
|
|
|
if err := database.ConnectDB(); err != nil {
|
|
testMySQL = false
|
|
}
|
|
}
|
|
|
|
// Single test:
|
|
// go test -race ./internal/monero -run=TestQueryNodes_toSQL -v
|
|
func TestQueryNodes_toSQL(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
query QueryNodes
|
|
wantArgs []interface{}
|
|
wantWhere string
|
|
wantSortBy string
|
|
wantSortDir string
|
|
}{
|
|
{
|
|
name: "Default query",
|
|
query: QueryNodes{
|
|
Paging: paging.Paging{
|
|
Limit: 10,
|
|
Page: 1,
|
|
SortBy: "last_checked",
|
|
SortDir: "desc",
|
|
SortDirection: "desc", // deprecated
|
|
},
|
|
Host: "",
|
|
Nettype: "any",
|
|
Protocol: "any",
|
|
CC: "any",
|
|
Status: -1,
|
|
CORS: "",
|
|
},
|
|
wantArgs: []interface{}{},
|
|
wantWhere: "",
|
|
wantSortBy: "last_checked",
|
|
wantSortDir: "DESC",
|
|
},
|
|
{
|
|
name: "With host query",
|
|
query: QueryNodes{
|
|
Paging: paging.Paging{
|
|
Limit: 10,
|
|
Page: 1,
|
|
SortBy: "last_checked",
|
|
SortDir: "desc",
|
|
SortDirection: "desc", // deprecated
|
|
},
|
|
Host: "test",
|
|
Nettype: "any",
|
|
Protocol: "any",
|
|
CC: "any",
|
|
Status: -1,
|
|
CORS: "",
|
|
},
|
|
wantArgs: []interface{}{"%test%", "%test%"},
|
|
wantWhere: "WHERE (hostname LIKE ? OR ip_addr LIKE ?)",
|
|
wantSortBy: "last_checked",
|
|
wantSortDir: "DESC",
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
gotArgs, gotWhere := tt.query.toSQL()
|
|
if !equalArgs(gotArgs, tt.wantArgs) {
|
|
t.Errorf("QueryNodes.toSQL() gotArgs = %v, want %v", gotArgs, tt.wantArgs)
|
|
}
|
|
if gotWhere != tt.wantWhere {
|
|
t.Errorf("QueryNodes.toSQL() gotWhere = %v, want %v", gotWhere, tt.wantWhere)
|
|
}
|
|
if tt.query.SortBy != tt.wantSortBy {
|
|
t.Errorf("QueryNodes.toSQL() gotSortBy = %v, want %v", tt.query.SortBy, tt.wantSortBy)
|
|
}
|
|
if tt.query.SortDir != tt.wantSortDir {
|
|
t.Errorf("QueryNodes.toSQL() gotSortDir = %v, want %v", tt.query.SortDir, tt.wantSortDir)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
// Single bench test:
|
|
// go test ./internal/monero -bench QueryNodes_toSQL -benchmem -run=^$ -v
|
|
func Benchmark_QueryNodes_toSQL(b *testing.B) {
|
|
q := QueryNodes{
|
|
Paging: paging.Paging{
|
|
Limit: 10,
|
|
Page: 1,
|
|
SortBy: "last_checked",
|
|
SortDir: "desc",
|
|
SortDirection: "desc", // deprecated
|
|
},
|
|
Host: "test",
|
|
Nettype: "any",
|
|
Protocol: "any",
|
|
CC: "any",
|
|
Status: -1,
|
|
CORS: "",
|
|
}
|
|
for i := 0; i < b.N; i++ {
|
|
_, _ = q.toSQL()
|
|
}
|
|
}
|
|
|
|
// equalArgs is helper function for testing.
|
|
//
|
|
// This returns true if two slices of interface{} are equal.
|
|
func equalArgs(a, b []interface{}) bool {
|
|
if len(a) != len(b) {
|
|
return false
|
|
}
|
|
for i, v := range a {
|
|
if !reflect.DeepEqual(v, b[i]) {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|