瀏覽代碼

storage: extend timeout for slow CI

1. extend timeout

2. print out stacktrace. When it fails again, we can get more confidence that the
failure is caused by slow IO.
Xiang Li 10 年之前
父節點
當前提交
0cba12d991
共有 1 個文件被更改,包括 6 次插入1 次删除
  1. 6 1
      storage/kvstore_test.go

+ 6 - 1
storage/kvstore_test.go

@@ -20,6 +20,7 @@ import (
 	"math"
 	"os"
 	"reflect"
+	"runtime"
 	"testing"
 	"time"
 
@@ -455,7 +456,11 @@ func TestTxnBlockBackendForceCommit(t *testing.T) {
 	s.TxnEnd(id)
 	select {
 	case <-done:
-	case <-time.After(time.Second):
+	case <-time.After(5 * time.Second): // wait 5 seconds for CI with slow IO
+		// print out stack traces of all routines if there is a failure
+		stackTrace := make([]byte, 8*1024)
+		n := runtime.Stack(stackTrace, true)
+		t.Error(string(stackTrace[:n]))
 		t.Fatalf("failed to execute ForceCommit")
 	}
 }