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