Add leases manager interface
Add leases manager to the leases package and use the interface on the client and service. Signed-off-by: Derek McGowan <derek@mcgstyle.net>
This commit is contained in:
@@ -21,6 +21,7 @@ import (
|
||||
|
||||
"github.com/boltdb/bolt"
|
||||
"github.com/containerd/containerd/errdefs"
|
||||
"github.com/containerd/containerd/leases"
|
||||
"github.com/pkg/errors"
|
||||
)
|
||||
|
||||
@@ -44,49 +45,51 @@ func TestLeases(t *testing.T) {
|
||||
},
|
||||
}
|
||||
|
||||
var leases []Lease
|
||||
var ll []leases.Lease
|
||||
|
||||
for _, tc := range testCases {
|
||||
if err := db.Update(func(tx *bolt.Tx) error {
|
||||
lease, err := NewLeaseManager(tx).Create(ctx, tc.ID, nil)
|
||||
lease, err := NewLeaseManager(tx).Create(ctx, leases.WithID(tc.ID))
|
||||
if err != nil {
|
||||
if tc.Cause != nil && errors.Cause(err) == tc.Cause {
|
||||
return nil
|
||||
}
|
||||
return err
|
||||
}
|
||||
leases = append(leases, lease)
|
||||
ll = append(ll, lease)
|
||||
return nil
|
||||
}); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
}
|
||||
|
||||
var listed []Lease
|
||||
var listed []leases.Lease
|
||||
// List leases, check same
|
||||
if err := db.View(func(tx *bolt.Tx) error {
|
||||
var err error
|
||||
listed, err = NewLeaseManager(tx).List(ctx, false)
|
||||
listed, err = NewLeaseManager(tx).List(ctx)
|
||||
return err
|
||||
}); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
if len(listed) != len(leases) {
|
||||
t.Fatalf("Expected %d lease, got %d", len(leases), len(listed))
|
||||
if len(listed) != len(ll) {
|
||||
t.Fatalf("Expected %d lease, got %d", len(ll), len(listed))
|
||||
}
|
||||
for i := range listed {
|
||||
if listed[i].ID != leases[i].ID {
|
||||
t.Fatalf("Expected lease ID %s, got %s", leases[i].ID, listed[i].ID)
|
||||
if listed[i].ID != ll[i].ID {
|
||||
t.Fatalf("Expected lease ID %s, got %s", ll[i].ID, listed[i].ID)
|
||||
}
|
||||
if listed[i].CreatedAt != leases[i].CreatedAt {
|
||||
t.Fatalf("Expected lease created at time %s, got %s", leases[i].CreatedAt, listed[i].CreatedAt)
|
||||
if listed[i].CreatedAt != ll[i].CreatedAt {
|
||||
t.Fatalf("Expected lease created at time %s, got %s", ll[i].CreatedAt, listed[i].CreatedAt)
|
||||
}
|
||||
}
|
||||
|
||||
for _, tc := range testCases {
|
||||
if err := db.Update(func(tx *bolt.Tx) error {
|
||||
return NewLeaseManager(tx).Delete(ctx, tc.ID)
|
||||
return NewLeaseManager(tx).Delete(ctx, leases.Lease{
|
||||
ID: tc.ID,
|
||||
})
|
||||
}); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
@@ -94,7 +97,7 @@ func TestLeases(t *testing.T) {
|
||||
|
||||
if err := db.View(func(tx *bolt.Tx) error {
|
||||
var err error
|
||||
listed, err = NewLeaseManager(tx).List(ctx, false)
|
||||
listed, err = NewLeaseManager(tx).List(ctx)
|
||||
return err
|
||||
}); err != nil {
|
||||
t.Fatal(err)
|
||||
|
||||
Reference in New Issue
Block a user