From 4899c226f70ccc1bb4ac8489a2b8ff000003bc97 Mon Sep 17 00:00:00 2001 From: jojoliang Date: Wed, 9 Dec 2020 10:18:31 +0800 Subject: [PATCH] update test --- costesting/ci_test.go | 2 ++ example/object/put_with_timeout.go | 59 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 61 insertions(+) create mode 100644 example/object/put_with_timeout.go diff --git a/costesting/ci_test.go b/costesting/ci_test.go index 915c830..dcc85f9 100644 --- a/costesting/ci_test.go +++ b/costesting/ci_test.go @@ -226,6 +226,7 @@ func (s *CosTestSuite) TestVersionAndReplication() { } _, err := s.Client.Bucket.PutVersioning(context.Background(), opt) assert.Nil(s.T(), err, "PutVersioning Failed") + time.Sleep(time.Second) v, _, err := s.Client.Bucket.GetVersioning(context.Background()) assert.Nil(s.T(), err, "GetVersioning Failed") assert.Equal(s.T(), "Enabled", v.Status, "Get Wrong Version status") @@ -248,6 +249,7 @@ func (s *CosTestSuite) TestVersionAndReplication() { _, err = s.Client.Bucket.PutBucketReplication(context.Background(), repOpt) assert.Nil(s.T(), err, "PutBucketReplication Failed") + time.Sleep(time.Second) vr, _, err := s.Client.Bucket.GetBucketReplication(context.Background()) assert.Nil(s.T(), err, "GetBucketReplication Failed") for _, r := range vr.Rule { diff --git a/example/object/put_with_timeout.go b/example/object/put_with_timeout.go new file mode 100644 index 0000000..e86b8a4 --- /dev/null +++ b/example/object/put_with_timeout.go @@ -0,0 +1,59 @@ +package main + +import ( + "context" + "fmt" + "net/url" + "os" + "time" + + "net/http" + + "github.com/tencentyun/cos-go-sdk-v5" + "github.com/tencentyun/cos-go-sdk-v5/debug" +) + +func log_status(err error) { + if err == nil { + return + } + if cos.IsNotFoundError(err) { + // WARN + fmt.Println("WARN: Resource is not existed") + } else if e, ok := cos.IsCOSError(err); ok { + fmt.Printf("ERROR: Code: %v\n", e.Code) + fmt.Printf("ERROR: Message: %v\n", e.Message) + fmt.Printf("ERROR: Resource: %v\n", e.Resource) + fmt.Printf("ERROR: RequestId: %v\n", e.RequestID) + // ERROR + } else { + fmt.Printf("ERROR: %v\n", err) + // ERROR + } +} + +func main() { + u, _ := url.Parse("https://test-1259654469.cos.ap-guangzhou.myqcloud.com") + b := &cos.BaseURL{BucketURL: u} + c := cos.NewClient(b, &http.Client{ + Transport: &cos.AuthorizationTransport{ + SecretID: os.Getenv("COS_SECRETID"), + SecretKey: os.Getenv("COS_SECRETKEY"), + Transport: &debug.DebugRequestTransport{ + RequestHeader: true, + // Notice when put a large file and set need the request body, might happend out of memory error. + RequestBody: false, + ResponseHeader: true, + ResponseBody: false, + }, + }, + Timeout: 5 * time.Second, // HTTP超时时间 + }) + + // Case1 上传对象 + name := "test/example" + // Case3 通过本地文件上传对象 + ctx, _ := context.WithTimeout(context.Background(), 2*time.Second) // context超时时间 + _, err := c.Object.PutFromFile(ctx, name, "./test", nil) // 请求的超时时间为 min{context超时时间, HTTP超时时间} + log_status(err) +}