Namespace repo contract
parent
443c9b9376
commit
1c15742710
@ -0,0 +1,53 @@
|
||||
package namespace
|
||||
|
||||
import (
|
||||
"github.com/matryer/is"
|
||||
"testing"
|
||||
"time"
|
||||
)
|
||||
|
||||
func RepositoryContract(fac func() Repository, t *testing.T) {
|
||||
basicNamespaceContract(fac, t)
|
||||
}
|
||||
|
||||
func basicNamespaceContract(fac func() Repository, t *testing.T) {
|
||||
is := is.New(t)
|
||||
r := fac()
|
||||
|
||||
all, err := r.All()
|
||||
|
||||
is.NoErr(err)
|
||||
is.Equal(len(all), 0)
|
||||
|
||||
ns := Namespace{
|
||||
23,
|
||||
"n1",
|
||||
time.Now(),
|
||||
time.Duration(time.Hour * 3),
|
||||
FileSizeQuota{1000, 0},
|
||||
Usage{1, 2, 3, 4, 5},
|
||||
}
|
||||
|
||||
ns1, _ := r.Create(ns)
|
||||
ns.Name = "n2"
|
||||
ns2, _ := r.Create(ns)
|
||||
is.True(ns1 != ns2)
|
||||
|
||||
all, err = r.All()
|
||||
|
||||
is.NoErr(err)
|
||||
is.Equal(len(all), 2)
|
||||
|
||||
is.Equal(ns.ID, int64(23))
|
||||
|
||||
ns3, _ := r.GetByName("n2")
|
||||
|
||||
is.Equal(ns3, ns2)
|
||||
|
||||
is.NoErr(r.Delete(ns2.ID))
|
||||
|
||||
all, err = r.All()
|
||||
|
||||
is.NoErr(err)
|
||||
is.Equal(len(all), 1)
|
||||
}
|
@ -0,0 +1,16 @@
|
||||
package namespace
|
||||
|
||||
import (
|
||||
"caj-larsson/bog/dataswamp/namespace"
|
||||
"path"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestFileRepo(t *testing.T) {
|
||||
fac := func() namespace.Repository {
|
||||
d := t.TempDir()
|
||||
db_path := path.Join(d, "db.sql")
|
||||
return NewRepository(db_path)
|
||||
}
|
||||
namespace.RepositoryContract(fac, t)
|
||||
}
|
Loading…
Reference in New Issue