mirror of
https://github.com/rclone/rclone.git
synced 2024-11-22 06:06:27 +08:00
91b54aafcc
Before this change it wasn't possible to see where transfers were going from and to in core/stats and core/transferred. When use in rclone mount in particular this made interpreting the stats very hard.
67 lines
1.8 KiB
Go
67 lines
1.8 KiB
Go
package accounting
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"io"
|
|
"testing"
|
|
|
|
"github.com/rclone/rclone/fs/rc"
|
|
"github.com/rclone/rclone/fstest/mockfs"
|
|
"github.com/rclone/rclone/fstest/mockobject"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestTransfer(t *testing.T) {
|
|
ctx := context.Background()
|
|
s := NewStats(ctx)
|
|
|
|
o := mockobject.Object("obj")
|
|
srcFs, err := mockfs.NewFs(ctx, "srcFs", "srcFs", nil)
|
|
require.NoError(t, err)
|
|
dstFs, err := mockfs.NewFs(ctx, "dstFs", "dstFs", nil)
|
|
require.NoError(t, err)
|
|
|
|
tr := newTransfer(s, o, srcFs, dstFs)
|
|
|
|
t.Run("Snapshot", func(t *testing.T) {
|
|
snap := tr.Snapshot()
|
|
assert.Equal(t, "obj", snap.Name)
|
|
assert.Equal(t, int64(0), snap.Size)
|
|
assert.Equal(t, int64(0), snap.Bytes)
|
|
assert.Equal(t, false, snap.Checked)
|
|
assert.Equal(t, false, snap.StartedAt.IsZero())
|
|
assert.Equal(t, true, snap.CompletedAt.IsZero())
|
|
assert.Equal(t, nil, snap.Error)
|
|
assert.Equal(t, "", snap.Group)
|
|
assert.Equal(t, "srcFs:srcFs", snap.SrcFs)
|
|
assert.Equal(t, "dstFs:dstFs", snap.DstFs)
|
|
})
|
|
|
|
t.Run("Done", func(t *testing.T) {
|
|
tr.Done(ctx, io.EOF)
|
|
snap := tr.Snapshot()
|
|
assert.Equal(t, "obj", snap.Name)
|
|
assert.Equal(t, int64(0), snap.Size)
|
|
assert.Equal(t, int64(0), snap.Bytes)
|
|
assert.Equal(t, false, snap.Checked)
|
|
assert.Equal(t, false, snap.StartedAt.IsZero())
|
|
assert.Equal(t, false, snap.CompletedAt.IsZero())
|
|
assert.Equal(t, true, errors.Is(snap.Error, io.EOF))
|
|
assert.Equal(t, "", snap.Group)
|
|
assert.Equal(t, "srcFs:srcFs", snap.SrcFs)
|
|
assert.Equal(t, "dstFs:dstFs", snap.DstFs)
|
|
})
|
|
|
|
t.Run("rcStats", func(t *testing.T) {
|
|
out := tr.rcStats()
|
|
assert.Equal(t, rc.Params{
|
|
"name": "obj",
|
|
"size": int64(0),
|
|
"srcFs": "srcFs:srcFs",
|
|
"dstFs": "dstFs:dstFs",
|
|
}, out)
|
|
})
|
|
}
|