github.com/qjfoidnh/BaiduPCS-Go@v0.0.0-20231011165705-caa18a3765f3/requester/uploader/block_test.go (about)

     1  package uploader_test
     2  
     3  import (
     4  	"fmt"
     5  	"github.com/qjfoidnh/BaiduPCS-Go/pcsutil/cachepool"
     6  	"github.com/qjfoidnh/BaiduPCS-Go/requester/rio"
     7  	"github.com/qjfoidnh/BaiduPCS-Go/requester/transfer"
     8  	"github.com/qjfoidnh/BaiduPCS-Go/requester/uploader"
     9  	"io"
    10  	"testing"
    11  )
    12  
    13  var (
    14  	blockList = uploader.SplitBlock(10000, 999)
    15  )
    16  
    17  func TestSplitBlock(t *testing.T) {
    18  	for k, e := range blockList {
    19  		fmt.Printf("%d %#v\n", k, e)
    20  	}
    21  }
    22  
    23  func TestSplitUnitRead(t *testing.T) {
    24  	var size int64 = 65536*2+3432
    25  	buffer := rio.NewBuffer(cachepool.RawMallocByteSlice(int(size)))
    26  	unit := uploader.NewBufioSplitUnit(buffer, transfer.Range{Begin: 2, End: size}, nil, nil)
    27  
    28  	buf := cachepool.RawMallocByteSlice(1022)
    29  	for {
    30  		n, err := unit.Read(buf)
    31  		if err != nil {
    32  			if err == io.EOF {
    33  				break
    34  			}
    35  			t.Fatalf("read error: %s\n", err)
    36  		}
    37  		fmt.Printf("n: %d, left: %d\n", n, unit.Left())
    38  	}
    39  }