Domain64 and DB backing tested

This commit is contained in:
Matt Jadud
2025-11-30 14:06:55 -05:00
parent f72c6b020f
commit 460f2734ef
11 changed files with 407 additions and 82 deletions

View File

@@ -6,15 +6,17 @@ import (
_ "embed"
"testing"
"github.com/jpillora/go-tld"
_ "modernc.org/sqlite"
)
//go:embed schema.sql
//go:embed sqlc/schema.sql
var ddl string
func setup() *sql.DB {
ctx := context.Background()
// db, err := sql.Open("sqlite", "sqlc/test.sqlite")
db, err := sql.Open("sqlite", ":memory:")
if err != nil {
// TODO
@@ -39,3 +41,99 @@ func TestNewDomain64Map(t *testing.T) {
t.Error("DB should not be nil")
}
}
func TestURLToRFQDN(t *testing.T) {
M, _ := NewDomain64Map(nil)
simple, _ := tld.Parse("https://jadud.com/")
rfqdn := M.URLToRFQDN(simple)
if rfqdn != "com.jadud/" {
t.Errorf("Expected `com.jadud/`, got %s", rfqdn)
}
}
func TestURLToDomain64(t *testing.T) {
db := setup()
M, _ := NewDomain64Map(db)
simple, _ := tld.Parse("https://jadud.com/")
d64, _ := M.URLToDomain64(simple)
if d64.TLD != 1 {
t.Errorf("expected TLD == 1, got %d", d64.TLD)
}
if d64.Domain != 1 {
t.Errorf("expected domain == 1, got %d", d64.Domain)
}
}
func TestURLToDomain64_02(t *testing.T) {
db := setup()
M, _ := NewDomain64Map(db)
simple1, _ := tld.Parse("https://jadud.com/")
simple2, _ := tld.Parse("https://another.com/")
d64_1, _ := M.URLToDomain64(simple1)
d64_2, _ := M.URLToDomain64(simple2)
if d64_1.TLD != 1 {
t.Errorf("expected TLD == 1, got %d", d64_1.TLD)
}
if d64_1.Domain != 1 {
t.Errorf("expected domain == 1, got %d", d64_1.Domain)
}
if d64_2.TLD != 1 {
t.Errorf("expected TLD == 1, got %d", d64_2.TLD)
}
if d64_2.Domain != 2 {
t.Errorf("expected domain == 2, got %d", d64_2.Domain)
}
}
func TestURLToDomain64_03(t *testing.T) {
db := setup()
M, _ := NewDomain64Map(db)
var tests = []struct {
url string
tld int64
domain int64
subdomain int64
path int64
d64 int64
}{
{"https://jadud.com/", 1, 1, 0, 0, 0x0100000100000000},
{"https://research.jadud.com/", 1, 1, 1, 0, 0x0100000101000000},
{"https://teaching.jadud.com/", 1, 1, 2, 0, 0x0100000102000000},
{"https://teaching.jadud.com/classes", 1, 1, 2, 1, 0x0100000102000001},
{"https://teaching.jadud.com/other-classes", 1, 1, 2, 2, 0x0100000102000002},
{"https://research.jadud.com/papers", 1, 1, 1, 1, 0x0100000101000001},
{"https://research.jadud.com/experiments", 1, 1, 1, 2, 0x0100000101000002},
{"https://teaching.another.com/classes", 1, 2, 1, 1, 0x0100000201000001},
{"https://teaching.jadud.org/classes", 2, 1, 1, 1, 0x0200000101000001},
// The ordering here matters; if we see a "bare" domain after first seeing the
// subdomain, I expect the numbering to come out right. That is, subdomain <- 0 and
// path <- 0. That is because of "" and "/" checking on subdomain and path, respectively.
{"https://jadud.org/", 2, 1, 0, 0, 0x0200000100000000},
}
for _, tt := range tests {
parsed, _ := tld.Parse(tt.url)
d64, _ := M.URLToDomain64(parsed)
if d64.TLD != tt.tld {
t.Errorf("%s TLD expected %d given %d", tt.url, tt.tld, d64.TLD)
}
if d64.Domain != tt.domain {
t.Errorf("%s Domain expected %d given %d", tt.url, tt.domain, d64.Domain)
}
if d64.Subdomain != tt.subdomain {
t.Errorf("%s Subdomain expected %d given %d", tt.url, tt.subdomain, d64.Subdomain)
}
if d64.Path != tt.path {
t.Errorf("%s Path expected %d given %d", tt.url, tt.path, d64.Path)
}
if d64.ToInt64() != tt.d64 {
t.Errorf("%s int64 value expected %d given %d", tt.url, tt.d64, d64.ToInt64())
}
}
}