mirror of
https://github.com/rclone/rclone.git
synced 2025-01-05 05:49:33 +01:00
list: add WithListP helper to implement List for ListP backends
This commit is contained in:
parent
96afeb1435
commit
fe2dc38aff
@ -1,6 +1,11 @@
|
|||||||
package list
|
package list
|
||||||
|
|
||||||
import "github.com/rclone/rclone/fs"
|
import (
|
||||||
|
"context"
|
||||||
|
|
||||||
|
"github.com/rclone/rclone/fs"
|
||||||
|
"github.com/rclone/rclone/fs/accounting"
|
||||||
|
)
|
||||||
|
|
||||||
// Listing helpers used by backends
|
// Listing helpers used by backends
|
||||||
|
|
||||||
@ -41,3 +46,16 @@ func (lh *Helper) Add(entry fs.DirEntry) error {
|
|||||||
func (lh *Helper) Flush() error {
|
func (lh *Helper) Flush() error {
|
||||||
return lh.send(1)
|
return lh.send(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// WithListP implements the List interface with ListP
|
||||||
|
//
|
||||||
|
// It should be used in backends which support ListP to implement
|
||||||
|
// List.
|
||||||
|
func WithListP(ctx context.Context, dir string, list fs.ListPer) (entries fs.DirEntries, err error) {
|
||||||
|
err = list.ListP(ctx, dir, func(newEntries fs.DirEntries) error {
|
||||||
|
accounting.Stats(ctx).Listed(int64(len(newEntries)))
|
||||||
|
entries = append(entries, newEntries...)
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
return entries, err
|
||||||
|
}
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
package list
|
package list
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
@ -88,3 +90,56 @@ func TestListRHelperFlush(t *testing.T) {
|
|||||||
assert.True(t, callbackInvoked, "Callback should be invoked on flush")
|
assert.True(t, callbackInvoked, "Callback should be invoked on flush")
|
||||||
assert.Len(t, helper.entries, 0, "Entries should be cleared after flush")
|
assert.Len(t, helper.entries, 0, "Entries should be cleared after flush")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type mockListPfs struct {
|
||||||
|
t *testing.T
|
||||||
|
entries fs.DirEntries
|
||||||
|
err error
|
||||||
|
errorAfter int
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *mockListPfs) ListP(ctx context.Context, dir string, callback fs.ListRCallback) (err error) {
|
||||||
|
assert.Equal(f.t, "dir", dir)
|
||||||
|
count := 0
|
||||||
|
for entries := f.entries; len(entries) > 0; entries = entries[2:] {
|
||||||
|
err = callback(entries[:2])
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
count += 2
|
||||||
|
if f.err != nil && count >= f.errorAfter {
|
||||||
|
return f.err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// check interface
|
||||||
|
var _ fs.ListPer = (*mockListPfs)(nil)
|
||||||
|
|
||||||
|
func TestListWithListP(t *testing.T) {
|
||||||
|
ctx := context.Background()
|
||||||
|
var entries fs.DirEntries
|
||||||
|
for i := 0; i < 26; i++ {
|
||||||
|
entries = append(entries, mockobject.New(fmt.Sprintf("%c", 'A'+i)))
|
||||||
|
}
|
||||||
|
t.Run("NoError", func(t *testing.T) {
|
||||||
|
f := &mockListPfs{
|
||||||
|
t: t,
|
||||||
|
entries: entries,
|
||||||
|
}
|
||||||
|
gotEntries, err := WithListP(ctx, "dir", f)
|
||||||
|
require.NoError(t, err)
|
||||||
|
assert.Equal(t, entries, gotEntries)
|
||||||
|
})
|
||||||
|
t.Run("Error", func(t *testing.T) {
|
||||||
|
f := &mockListPfs{t: t,
|
||||||
|
entries: entries,
|
||||||
|
err: errors.New("BOOM"),
|
||||||
|
errorAfter: 10,
|
||||||
|
}
|
||||||
|
gotEntries, err := WithListP(ctx, "dir", f)
|
||||||
|
assert.Equal(t, f.err, err)
|
||||||
|
assert.Equal(t, entries[:10], gotEntries)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user