Files
sqlite3/ext/csv/arg_test.go

113 lines
2.6 KiB
Go
Raw Normal View History

2023-11-23 09:54:18 +00:00
package csv
2024-01-03 00:54:30 +00:00
import (
"testing"
2023-11-23 09:54:18 +00:00
2024-10-22 23:32:57 +01:00
"github.com/ncruces/go-sqlite3/util/sql3util"
2024-01-03 00:54:30 +00:00
)
func Test_uintArg(t *testing.T) {
2023-12-02 12:03:31 +00:00
t.Parallel()
2023-11-23 09:54:18 +00:00
tests := []struct {
arg string
key string
val int
err bool
}{
{"columns 1", "columns 1", 0, true},
{"columns = 1", "columns", 1, false},
{"columns\t= 2", "columns", 2, false},
{" columns = 3", "columns", 3, false},
{" columns = -1", "columns", 0, true},
{" columns = 32768", "columns", 0, true},
}
for _, tt := range tests {
t.Run(tt.arg, func(t *testing.T) {
2024-10-22 23:32:57 +01:00
key, val := sql3util.NamedArg(tt.arg)
2023-11-23 09:54:18 +00:00
if key != tt.key {
2024-01-03 00:54:30 +00:00
t.Errorf("NamedArg() %v, want err %v", key, tt.key)
2023-11-23 09:54:18 +00:00
}
2024-01-03 00:54:30 +00:00
got, err := uintArg(key, val)
2023-11-23 09:54:18 +00:00
if (err != nil) != tt.err {
2024-01-03 00:54:30 +00:00
t.Fatalf("uintArg() error = %v, want err %v", err, tt.err)
2023-11-23 09:54:18 +00:00
}
if got != tt.val {
2024-01-03 00:54:30 +00:00
t.Errorf("uintArg() = %v, want %v", got, tt.val)
2023-11-23 09:54:18 +00:00
}
})
}
}
2024-01-03 00:54:30 +00:00
func Test_boolArg(t *testing.T) {
t.Parallel()
2023-11-23 09:54:18 +00:00
tests := []struct {
arg string
key string
val bool
err bool
}{
{"header", "header", true, false},
{"header\t= 1", "header", true, false},
{" header = 0", "header", false, false},
{" header = TrUe", "header", true, false},
{" header = FaLsE", "header", false, false},
{" header = Yes", "header", true, false},
{" header = nO", "header", false, false},
{" header = On", "header", true, false},
{" header = Off", "header", false, false},
{" header = T", "header", false, true},
{" header = f", "header", false, true},
}
for _, tt := range tests {
t.Run(tt.arg, func(t *testing.T) {
2024-10-22 23:32:57 +01:00
key, val := sql3util.NamedArg(tt.arg)
2023-11-23 09:54:18 +00:00
if key != tt.key {
2024-01-03 00:54:30 +00:00
t.Errorf("NamedArg() %v, want err %v", key, tt.key)
2023-11-23 09:54:18 +00:00
}
2024-01-03 00:54:30 +00:00
got, err := boolArg(key, val)
2023-11-23 09:54:18 +00:00
if (err != nil) != tt.err {
2024-01-03 00:54:30 +00:00
t.Fatalf("boolArg() error = %v, want err %v", err, tt.err)
2023-11-23 09:54:18 +00:00
}
if got != tt.val {
2024-01-03 00:54:30 +00:00
t.Errorf("boolArg() = %v, want %v", got, tt.val)
2023-11-23 09:54:18 +00:00
}
})
}
}
2024-01-03 00:54:30 +00:00
func Test_runeArg(t *testing.T) {
t.Parallel()
2023-11-23 09:54:18 +00:00
tests := []struct {
arg string
key string
val rune
err bool
}{
{"comma", "comma", 0, true},
{"comma\t= ,", "comma", ',', false},
{" comma = ;", "comma", ';', false},
{" comma = ;;", "comma", 0, true},
{` comma = '\t`, "comma", 0, true},
{` comma = '\t'`, "comma", '\t', false},
{` comma = "\t"`, "comma", '\t', false},
}
for _, tt := range tests {
t.Run(tt.arg, func(t *testing.T) {
2024-10-22 23:32:57 +01:00
key, val := sql3util.NamedArg(tt.arg)
2023-11-23 09:54:18 +00:00
if key != tt.key {
2024-01-03 00:54:30 +00:00
t.Errorf("NamedArg() %v, want err %v", key, tt.key)
2023-11-23 09:54:18 +00:00
}
2024-01-03 00:54:30 +00:00
got, err := runeArg(key, val)
2023-11-23 09:54:18 +00:00
if (err != nil) != tt.err {
2024-01-03 00:54:30 +00:00
t.Fatalf("runeArg() error = %v, want err %v", err, tt.err)
2023-11-23 09:54:18 +00:00
}
if got != tt.val {
2024-01-03 00:54:30 +00:00
t.Errorf("runeArg() = %v, want %v", got, tt.val)
2023-11-23 09:54:18 +00:00
}
})
}
}