Add test for LockingStore
This commit is contained in:
parent
b3fb3a3f5d
commit
4073f4ae64
|
@ -0,0 +1,82 @@
|
||||||
|
package lockingstore_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/tus/tusd"
|
||||||
|
. "github.com/tus/tusd/lockingstore"
|
||||||
|
)
|
||||||
|
|
||||||
|
type store struct {
|
||||||
|
calls int
|
||||||
|
}
|
||||||
|
|
||||||
|
func (store *store) NewUpload(info tusd.FileInfo) (string, error) {
|
||||||
|
return "", nil
|
||||||
|
}
|
||||||
|
func (store *store) WriteChunk(id string, offset int64, src io.Reader) (int64, error) {
|
||||||
|
store.calls += 1
|
||||||
|
return 0, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (store *store) GetInfo(id string) (tusd.FileInfo, error) {
|
||||||
|
store.calls += 1
|
||||||
|
return tusd.FileInfo{}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (store *store) GetReader(id string) (io.Reader, error) {
|
||||||
|
store.calls += 1
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (store *store) Terminate(id string) error {
|
||||||
|
store.calls += 1
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type locker struct {
|
||||||
|
lockCalls int
|
||||||
|
unlockCalls int
|
||||||
|
}
|
||||||
|
|
||||||
|
func (locker *locker) LockUpload(id string) error {
|
||||||
|
locker.lockCalls += 1
|
||||||
|
if id == "no" {
|
||||||
|
return tusd.ErrFileLocked
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (locker *locker) UnlockUpload(id string) error {
|
||||||
|
locker.unlockCalls += 1
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestLockingStore(t *testing.T) {
|
||||||
|
locker := new(locker)
|
||||||
|
store := new(store)
|
||||||
|
lstore := LockingStore{
|
||||||
|
DataStore: store,
|
||||||
|
Locker: locker,
|
||||||
|
}
|
||||||
|
|
||||||
|
lstore.NewUpload(tusd.FileInfo{})
|
||||||
|
lstore.WriteChunk("", 0, nil)
|
||||||
|
lstore.GetInfo("")
|
||||||
|
lstore.GetReader("")
|
||||||
|
lstore.Terminate("")
|
||||||
|
|
||||||
|
lstore.WriteChunk("no", 0, nil)
|
||||||
|
lstore.GetInfo("no")
|
||||||
|
lstore.GetReader("no")
|
||||||
|
lstore.Terminate("no")
|
||||||
|
|
||||||
|
if locker.lockCalls != 8 {
|
||||||
|
t.Error("expected 8 calls to LockUpload, but got %d", locker.lockCalls)
|
||||||
|
}
|
||||||
|
|
||||||
|
if locker.unlockCalls != 4 {
|
||||||
|
t.Error("expected 8 calls to UnlockUpload, but got %d", locker.unlockCalls)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue