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: -1, }, 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: -1, }, 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: -1, } 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 }