apps/easel/db_test.go 2.8 K raw
1
package main
2
3
import (
4
	"database/sql"
5
	"strings"
6
	"testing"
7
	"time"
8
9
	sharedsqlite "github.com/stevedylandev/andromeda/pkg/sqlite"
10
)
11
12
func openEaselTestDB(t *testing.T) *sql.DB {
13
	t.Helper()
14
	db, err := sharedsqlite.Open("file:easel-test?mode=memory&cache=shared", easelSchema)
15
	if err != nil {
16
		t.Fatal(err)
17
	}
18
	return db
19
}
20
21
func daily(date string, id int64) *DailyArtwork {
22
	return &DailyArtwork{Date: date, ArtworkID: id, Title: "Title", ImageID: "img", FetchedAt: "now"}
23
}
24
25
func TestDailyArtworkDBHelpers(t *testing.T) {
26
	db := openEaselTestDB(t)
27
	defer db.Close()
28
	ok, err := insertDaily(db, daily("2024-01-01", 1))
29
	if err != nil || !ok {
30
		t.Fatalf("insert %v err %v", ok, err)
31
	}
32
	ok, err = insertDaily(db, daily("2024-01-01", 2))
33
	if err != nil || ok {
34
		t.Fatalf("duplicate %v err %v", ok, err)
35
	}
36
	if got, err := getDaily(db, "2024-01-01"); err != nil || got == nil || got.ArtworkID != 1 {
37
		t.Fatalf("get %#v err %v", got, err)
38
	}
39
	if exists, err := artworkIDExists(db, 1); err != nil || !exists {
40
		t.Fatalf("exists %v err %v", exists, err)
41
	}
42
	if exists, err := artworkIDExists(db, 99); err != nil || exists {
43
		t.Fatalf("missing exists %v err %v", exists, err)
44
	}
45
	if _, err := insertDaily(db, daily("2024-01-03", 3)); err != nil {
46
		t.Fatal(err)
47
	}
48
	list, err := listDaily(db, 10)
49
	if err != nil {
50
		t.Fatal(err)
51
	}
52
	if len(list) != 2 || list[0].Date != "2024-01-03" {
53
		t.Fatalf("list order %#v", list)
54
	}
55
	missing, err := missingDates(db, []string{"2024-01-01", "2024-01-02", "2024-01-03"})
56
	if err != nil {
57
		t.Fatal(err)
58
	}
59
	if len(missing) != 1 || missing[0] != "2024-01-02" {
60
		t.Fatalf("missing %#v", missing)
61
	}
62
}
63
64
func TestAICAndSchedulerHelpers(t *testing.T) {
65
	params := buildAICParams([]string{"Painting", "Print"}, []string{"war"})
66
	if !strings.Contains(params, "painting") || strings.Contains(params, "Painting") {
67
		t.Fatalf("classifications not lowercased: %s", params)
68
	}
69
	if lower("AbC!") != "abc!" {
70
		t.Fatal("lower failed")
71
	}
72
	title, img, artist := "Mona", "image-id", "Artist"
73
	d := rawToDaily(&rawArtwork{ID: 42, Title: &title, ImageID: &img, ArtistTitle: &artist}, "2024-01-01", "fetched")
74
	if d == nil || d.Title != title || d.ImageID != img || !d.ArtistTitle.Valid {
75
		t.Fatalf("daily %#v", d)
76
	}
77
	if rawToDaily(&rawArtwork{ID: 1}, "2024-01-01", "now") != nil {
78
		t.Fatal("missing image should return nil")
79
	}
80
	if rawToDaily(&rawArtwork{ID: 1, ImageID: &img}, "2024-01-01", "now").Title != "Untitled" {
81
		t.Fatal("expected untitled fallback")
82
	}
83
84
	app := &App{TZ: time.UTC}
85
	dates := app.pastNDates(3)
86
	if len(dates) != 3 {
87
		t.Fatalf("dates %#v", dates)
88
	}
89
	if today := time.Now().UTC().Format("2006-01-02"); dates[0] == today {
90
		t.Fatal("past dates included today")
91
	}
92
	if _, ok := parseDate("2024-02-29"); !ok {
93
		t.Fatal("valid date rejected")
94
	}
95
	if _, ok := parseDate("2024-02-30"); ok {
96
		t.Fatal("invalid date accepted")
97
	}
98
}