2024-05-30 12:19:03 +00:00
|
|
|
package monero
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"reflect"
|
|
|
|
"strconv"
|
|
|
|
"testing"
|
2024-07-06 18:28:44 +00:00
|
|
|
|
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/config"
|
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/database"
|
2024-10-31 15:45:26 +00:00
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/paging"
|
2024-05-30 12:19:03 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
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
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-07-29 15:44:10 +00:00
|
|
|
// Single test:
|
|
|
|
// go test -race ./internal/monero -run=TestQueryNodes_toSQL -v
|
2024-05-30 12:19:03 +00:00
|
|
|
func TestQueryNodes_toSQL(t *testing.T) {
|
|
|
|
tests := []struct {
|
2024-10-31 15:45:26 +00:00
|
|
|
name string
|
|
|
|
query QueryNodes
|
|
|
|
wantArgs []interface{}
|
|
|
|
wantWhere string
|
|
|
|
wantSortBy string
|
|
|
|
wantSortDir string
|
2024-05-30 12:19:03 +00:00
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "Default query",
|
|
|
|
query: QueryNodes{
|
2024-10-31 15:45:26 +00:00
|
|
|
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: -1,
|
2024-05-30 12:19:03 +00:00
|
|
|
},
|
2024-10-31 15:45:26 +00:00
|
|
|
wantArgs: []interface{}{},
|
|
|
|
wantWhere: "",
|
|
|
|
wantSortBy: "last_checked",
|
|
|
|
wantSortDir: "DESC",
|
2024-05-30 12:19:03 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "With host query",
|
|
|
|
query: QueryNodes{
|
2024-10-31 15:45:26 +00:00
|
|
|
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: -1,
|
2024-05-30 12:19:03 +00:00
|
|
|
},
|
2024-10-31 15:45:26 +00:00
|
|
|
wantArgs: []interface{}{"%test%", "%test%"},
|
|
|
|
wantWhere: "WHERE (hostname LIKE ? OR ip_addr LIKE ?)",
|
|
|
|
wantSortBy: "last_checked",
|
|
|
|
wantSortDir: "DESC",
|
2024-05-30 12:19:03 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
2024-08-05 11:27:00 +00:00
|
|
|
gotArgs, gotWhere := tt.query.toSQL()
|
2024-05-30 12:19:03 +00:00
|
|
|
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)
|
|
|
|
}
|
2024-08-05 11:27:00 +00:00
|
|
|
if tt.query.SortBy != tt.wantSortBy {
|
|
|
|
t.Errorf("QueryNodes.toSQL() gotSortBy = %v, want %v", tt.query.SortBy, tt.wantSortBy)
|
2024-05-30 12:19:03 +00:00
|
|
|
}
|
2024-10-31 15:45:26 +00:00
|
|
|
if tt.query.SortDir != tt.wantSortDir {
|
|
|
|
t.Errorf("QueryNodes.toSQL() gotSortDir = %v, want %v", tt.query.SortDir, tt.wantSortDir)
|
2024-05-30 12:19:03 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-07-29 15:44:10 +00:00
|
|
|
// Single bench test:
|
|
|
|
// go test ./internal/monero -bench QueryNodes_toSQL -benchmem -run=^$ -v
|
|
|
|
func Benchmark_QueryNodes_toSQL(b *testing.B) {
|
2024-08-05 11:27:00 +00:00
|
|
|
q := QueryNodes{
|
2024-10-31 15:45:26 +00:00
|
|
|
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: -1,
|
2024-08-05 11:27:00 +00:00
|
|
|
}
|
2024-07-29 15:44:10 +00:00
|
|
|
for i := 0; i < b.N; i++ {
|
2024-08-05 11:27:00 +00:00
|
|
|
_, _ = q.toSQL()
|
2024-07-29 15:44:10 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// equalArgs is helper function for testing.
|
|
|
|
//
|
|
|
|
// This returns true if two slices of interface{} are equal.
|
2024-05-30 12:19:03 +00:00
|
|
|
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
|
|
|
|
}
|