-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathmulti_download_test.go
60 lines (51 loc) · 2.04 KB
/
multi_download_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
package api_tests
import (
"os"
"sync"
"testing"
"github.com/0chain/gosdk/zboxcore/sdk"
"github.com/0chain/system_test/internal/api/model"
"github.com/0chain/system_test/internal/api/util/client"
"github.com/0chain/system_test/internal/api/util/test"
"github.com/stretchr/testify/require"
)
func TestMultiDownload(testSetup *testing.T) {
t := test.NewSystemTest(testSetup)
t.Parallel()
t.SetSmokeTests("Multi download should work")
t.Run("Multi download should work", func(t *test.SystemTest) {
wallet := createWallet(t)
sdkClient.SetWallet(t, wallet)
blobberRequirements := model.DefaultBlobberRequirements(wallet.Id, wallet.PublicKey)
allocationBlobbers := apiClient.GetAllocationBlobbers(t, wallet, &blobberRequirements, client.HttpOkStatus)
allocationID := apiClient.CreateAllocation(t, wallet, allocationBlobbers, client.TxSuccessfulStatus)
ops := make([]sdk.OperationRequest, 0, 10)
for i := 0; i < 10; i++ {
op := sdkClient.AddUploadOperation(t, "", "")
ops = append(ops, op)
}
sdkClient.MultiOperation(t, allocationID, ops)
alloc, err := sdk.GetAllocation(allocationID)
require.NoError(t, err, "error getting allocation")
err = os.MkdirAll("temp_download", os.ModePerm)
require.NoError(t, err, "error creating temp dir")
defer func() {
err = os.RemoveAll("temp_download")
require.NoError(t, err, "error removing temp dir")
}()
wg := &sync.WaitGroup{}
for i := 0; i < 9; i++ {
sdkClient.DownloadFileWithParam(t, alloc, ops[i].FileMeta.RemotePath, "temp_download/", wg, false)
}
sdkClient.DownloadFileWithParam(t, alloc, ops[9].FileMeta.RemotePath, "temp_download/", wg, true)
wg.Wait()
files, err := os.ReadDir("temp_download")
require.NoError(t, err, "error reading temp dir")
require.Equal(t, 10, len(files), "files count mismatch expected %v actual %v", 10, len(files))
for _, file := range files {
sz, err := file.Info()
require.NoError(t, err, "error getting file info")
require.Equal(t, int64(1024), sz.Size(), "file size mismatch expected %v actual %v", 1024, sz.Size())
}
})
}