mirror of
https://github.com/ditatompel/xmr-remote-nodes.git
synced 2025-01-08 05:52:10 +07:00
toSQL function for QueryProber struct
Make the unit test easier
This commit is contained in:
parent
acc70111c8
commit
8b5bdc7523
3 changed files with 124 additions and 29 deletions
|
@ -85,7 +85,6 @@ func TestQueryNodes_toSQL(t *testing.T) {
|
||||||
for _, tt := range tests {
|
for _, tt := range tests {
|
||||||
t.Run(tt.name, func(t *testing.T) {
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
gotArgs, gotWhere, gotSortBy, gotSortDirection := tt.query.toSQL()
|
gotArgs, gotWhere, gotSortBy, gotSortDirection := tt.query.toSQL()
|
||||||
|
|
||||||
if !equalArgs(gotArgs, tt.wantArgs) {
|
if !equalArgs(gotArgs, tt.wantArgs) {
|
||||||
t.Errorf("QueryNodes.toSQL() gotArgs = %v, want %v", gotArgs, tt.wantArgs)
|
t.Errorf("QueryNodes.toSQL() gotArgs = %v, want %v", gotArgs, tt.wantArgs)
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,7 +38,7 @@ func NewProber() ProberRepository {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add a new prober machine
|
// Add a new prober machine
|
||||||
func (repo *ProberRepo) Add(name string) (Prober, error) {
|
func (r *ProberRepo) Add(name string) (Prober, error) {
|
||||||
apiKey := uuid.New()
|
apiKey := uuid.New()
|
||||||
query := `
|
query := `
|
||||||
INSERT INTO tbl_prober (
|
INSERT INTO tbl_prober (
|
||||||
|
@ -50,7 +50,7 @@ func (repo *ProberRepo) Add(name string) (Prober, error) {
|
||||||
?,
|
?,
|
||||||
?
|
?
|
||||||
)`
|
)`
|
||||||
_, err := repo.db.Exec(query, name, apiKey, 0)
|
_, err := r.db.Exec(query, name, apiKey, 0)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return Prober{}, err
|
return Prober{}, err
|
||||||
}
|
}
|
||||||
|
@ -58,9 +58,9 @@ func (repo *ProberRepo) Add(name string) (Prober, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Edit an existing prober
|
// Edit an existing prober
|
||||||
func (repo *ProberRepo) Edit(id int, name string) error {
|
func (r *ProberRepo) Edit(id int, name string) error {
|
||||||
query := `UPDATE tbl_prober SET name = ? WHERE id = ?`
|
query := `UPDATE tbl_prober SET name = ? WHERE id = ?`
|
||||||
res, err := repo.db.Exec(query, name, id)
|
res, err := r.db.Exec(query, name, id)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -75,8 +75,8 @@ func (repo *ProberRepo) Edit(id int, name string) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Delete an existing prober
|
// Delete an existing prober
|
||||||
func (repo *ProberRepo) Delete(id int) error {
|
func (r *ProberRepo) Delete(id int) error {
|
||||||
res, err := repo.db.Exec(`DELETE FROM tbl_prober WHERE id = ?`, id)
|
res, err := r.db.Exec(`DELETE FROM tbl_prober WHERE id = ?`, id)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -96,33 +96,34 @@ type QueryProbers struct {
|
||||||
SortDirection string
|
SortDirection string
|
||||||
}
|
}
|
||||||
|
|
||||||
func (repo *ProberRepo) Probers(q QueryProbers) ([]Prober, error) {
|
func (q QueryProbers) toSQL() (args []interface{}, where, sortBy, sortDirection string) {
|
||||||
queryParams := []interface{}{}
|
wq := []string{}
|
||||||
whereQueries := []string{}
|
|
||||||
where := ""
|
|
||||||
|
|
||||||
if q.Search != "" {
|
if q.Search != "" {
|
||||||
whereQueries = append(whereQueries, "(name LIKE ? OR api_key LIKE ?)")
|
wq = append(wq, "(name LIKE ? OR api_key LIKE ?)")
|
||||||
queryParams = append(queryParams, "%"+q.Search+"%")
|
args = append(args, "%"+q.Search+"%", "%"+q.Search+"%")
|
||||||
queryParams = append(queryParams, "%"+q.Search+"%")
|
}
|
||||||
|
if len(wq) > 0 {
|
||||||
|
where = "WHERE " + strings.Join(wq, " AND ")
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(whereQueries) > 0 {
|
as := []string{"id", "last_submit_ts"}
|
||||||
where = "WHERE " + strings.Join(whereQueries, " AND ")
|
sortBy = "last_submit_ts"
|
||||||
}
|
if slices.Contains(as, q.SortBy) {
|
||||||
|
|
||||||
var probers []Prober
|
|
||||||
|
|
||||||
allowedSort := []string{"id", "last_submit_ts"}
|
|
||||||
sortBy := "last_submit_ts"
|
|
||||||
if slices.Contains(allowedSort, q.SortBy) {
|
|
||||||
sortBy = q.SortBy
|
sortBy = q.SortBy
|
||||||
}
|
}
|
||||||
sortDirection := "DESC"
|
sortDirection = "DESC"
|
||||||
if q.SortDirection == "asc" {
|
if q.SortDirection == "asc" {
|
||||||
sortDirection = "ASC"
|
sortDirection = "ASC"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return args, where, sortBy, sortDirection
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *ProberRepo) Probers(q QueryProbers) ([]Prober, error) {
|
||||||
|
args, where, sortBy, sortDirection := q.toSQL()
|
||||||
|
|
||||||
|
var probers []Prober
|
||||||
|
|
||||||
query := fmt.Sprintf(`
|
query := fmt.Sprintf(`
|
||||||
SELECT
|
SELECT
|
||||||
id,
|
id,
|
||||||
|
@ -134,7 +135,7 @@ func (repo *ProberRepo) Probers(q QueryProbers) ([]Prober, error) {
|
||||||
%s -- where clause if any
|
%s -- where clause if any
|
||||||
ORDER BY %s %s`, where, sortBy, sortDirection)
|
ORDER BY %s %s`, where, sortBy, sortDirection)
|
||||||
|
|
||||||
row, err := repo.db.Query(query, queryParams...)
|
row, err := r.db.Query(query, args...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return probers, err
|
return probers, err
|
||||||
}
|
}
|
||||||
|
@ -151,7 +152,7 @@ func (repo *ProberRepo) Probers(q QueryProbers) ([]Prober, error) {
|
||||||
return probers, nil
|
return probers, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (repo *ProberRepo) CheckApi(key string) (Prober, error) {
|
func (r *ProberRepo) CheckApi(key string) (Prober, error) {
|
||||||
var p Prober
|
var p Prober
|
||||||
query := `
|
query := `
|
||||||
SELECT
|
SELECT
|
||||||
|
@ -164,6 +165,6 @@ func (repo *ProberRepo) CheckApi(key string) (Prober, error) {
|
||||||
WHERE
|
WHERE
|
||||||
api_key = ?
|
api_key = ?
|
||||||
LIMIT 1`
|
LIMIT 1`
|
||||||
err := repo.db.QueryRow(query, key).Scan(&p.ID, &p.Name, &p.ApiKey, &p.LastSubmitTs)
|
err := r.db.QueryRow(query, key).Scan(&p.ID, &p.Name, &p.ApiKey, &p.LastSubmitTs)
|
||||||
return p, err
|
return p, err
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,11 +4,106 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func TestQueryProbers_toSQL(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
query QueryProbers
|
||||||
|
wantArgs []interface{}
|
||||||
|
wantWhere string
|
||||||
|
wantSortBy string
|
||||||
|
wantSortDirection string
|
||||||
|
}{
|
||||||
|
// TODO: Add test cases.
|
||||||
|
{
|
||||||
|
name: "Default query",
|
||||||
|
query: QueryProbers{
|
||||||
|
Search: "",
|
||||||
|
SortBy: "last_submit_ts",
|
||||||
|
SortDirection: "desc",
|
||||||
|
},
|
||||||
|
wantArgs: []interface{}{},
|
||||||
|
wantWhere: "",
|
||||||
|
wantSortBy: "last_submit_ts",
|
||||||
|
wantSortDirection: "DESC",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "With name or api_key query",
|
||||||
|
query: QueryProbers{
|
||||||
|
Search: "test",
|
||||||
|
SortBy: "last_submit_ts",
|
||||||
|
SortDirection: "desc",
|
||||||
|
},
|
||||||
|
wantArgs: []interface{}{"%test%", "%test%"},
|
||||||
|
wantWhere: "WHERE (name LIKE ? OR api_key LIKE ?)",
|
||||||
|
wantSortBy: "last_submit_ts",
|
||||||
|
wantSortDirection: "DESC",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "With sort direction",
|
||||||
|
query: QueryProbers{
|
||||||
|
Search: "test",
|
||||||
|
SortBy: "last_submit_ts",
|
||||||
|
SortDirection: "asc",
|
||||||
|
},
|
||||||
|
wantArgs: []interface{}{"%test%", "%test%"},
|
||||||
|
wantWhere: "WHERE (name LIKE ? OR api_key LIKE ?)",
|
||||||
|
wantSortBy: "last_submit_ts",
|
||||||
|
wantSortDirection: "ASC",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "With sort by ID",
|
||||||
|
query: QueryProbers{
|
||||||
|
Search: "test",
|
||||||
|
SortBy: "id",
|
||||||
|
SortDirection: "asc",
|
||||||
|
},
|
||||||
|
wantArgs: []interface{}{"%test%", "%test%"},
|
||||||
|
wantWhere: "WHERE (name LIKE ? OR api_key LIKE ?)",
|
||||||
|
wantSortBy: "id",
|
||||||
|
wantSortDirection: "ASC",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "With invalid sort by name and direction",
|
||||||
|
query: QueryProbers{
|
||||||
|
Search: "test",
|
||||||
|
SortBy: "invalid",
|
||||||
|
SortDirection: "invalid",
|
||||||
|
},
|
||||||
|
wantArgs: []interface{}{"%test%", "%test%"},
|
||||||
|
wantWhere: "WHERE (name LIKE ? OR api_key LIKE ?)",
|
||||||
|
wantSortBy: "last_submit_ts",
|
||||||
|
wantSortDirection: "DESC",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
q := QueryProbers{
|
||||||
|
Search: tt.query.Search,
|
||||||
|
SortBy: tt.query.SortBy,
|
||||||
|
SortDirection: tt.query.SortDirection,
|
||||||
|
}
|
||||||
|
gotArgs, gotWhere, gotSortBy, gotSortDirection := q.toSQL()
|
||||||
|
if !equalArgs(gotArgs, tt.wantArgs) {
|
||||||
|
t.Errorf("QueryNodes.toSQL() gotArgs = %v, want %v", gotArgs, tt.wantArgs)
|
||||||
|
}
|
||||||
|
if gotWhere != tt.wantWhere {
|
||||||
|
t.Errorf("QueryProbers.toSQL() gotWhere = %v, want %v", gotWhere, tt.wantWhere)
|
||||||
|
}
|
||||||
|
if gotSortBy != tt.wantSortBy {
|
||||||
|
t.Errorf("QueryProbers.toSQL() gotSortBy = %v, want %v", gotSortBy, tt.wantSortBy)
|
||||||
|
}
|
||||||
|
if gotSortDirection != tt.wantSortDirection {
|
||||||
|
t.Errorf("QueryProbers.toSQL() gotSortDirection = %v, want %v", gotSortDirection, tt.wantSortDirection)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// TODO: Add database test table and then clean it up
|
// TODO: Add database test table and then clean it up
|
||||||
|
|
||||||
func TestProberRepo_CheckApi(t *testing.T) {
|
func TestProberRepo_CheckApi(t *testing.T) {
|
||||||
if !testMySQL {
|
if !testMySQL {
|
||||||
t.Skip("Skip test, not connected to database")
|
t.Skip("Skip integration test, not connected to database")
|
||||||
}
|
}
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
name string
|
name string
|
||||||
|
|
Loading…
Reference in a new issue