test: add ListRetries config parameter to integration tests

Occasionally the b2 tests fail because the integration tests don't
retry hard enough with their new setting of -list-retries 3. Override
this setting to 5 for the b2 tests only.
This commit is contained in:
Nick Craig-Wood 2020-10-25 16:15:41 +00:00
parent cf0bdad5de
commit bed83b0b64
3 changed files with 39 additions and 31 deletions

View file

@ -27,15 +27,16 @@ type Test struct {
// //
// FIXME make bucket based remotes set sub-dir automatically??? // FIXME make bucket based remotes set sub-dir automatically???
type Backend struct { type Backend struct {
Backend string // name of the backend directory Backend string // name of the backend directory
Remote string // name of the test remote Remote string // name of the test remote
FastList bool // set to test with -fast-list FastList bool // set to test with -fast-list
Short bool // set to test with -short Short bool // set to test with -short
OneOnly bool // set to run only one backend test at once OneOnly bool // set to run only one backend test at once
MaxFile string // file size limit MaxFile string // file size limit
CleanUp bool // when running clean, run cleanup first CleanUp bool // when running clean, run cleanup first
Ignore []string // test names to ignore the failure of Ignore []string // test names to ignore the failure of
Tests []string // paths of tests to run, blank for all Tests []string // paths of tests to run, blank for all
ListRetries int // -list-retries if > 0
} }
// includeTest returns true if this backend should be included in this // includeTest returns true if this backend should be included in this
@ -79,16 +80,17 @@ func (b *Backend) MakeRuns(t *Test) (runs []*Run) {
continue continue
} }
run := &Run{ run := &Run{
Remote: b.Remote, Remote: b.Remote,
Backend: b.Backend, Backend: b.Backend,
Path: t.Path, Path: t.Path,
FastList: fastlist, FastList: fastlist,
Short: (b.Short && t.Short), Short: (b.Short && t.Short),
NoRetries: t.NoRetries, NoRetries: t.NoRetries,
OneOnly: b.OneOnly, OneOnly: b.OneOnly,
NoBinary: t.NoBinary, NoBinary: t.NoBinary,
SizeLimit: int64(maxSize), SizeLimit: int64(maxSize),
Ignore: ignore, Ignore: ignore,
ListRetries: b.ListRetries,
} }
if t.AddBackend { if t.AddBackend {
run.Path = path.Join(run.Path, b.Backend) run.Path = path.Join(run.Path, b.Backend)

View file

@ -20,6 +20,7 @@ backends:
- backend: "b2" - backend: "b2"
remote: "TestB2:" remote: "TestB2:"
fastlist: true fastlist: true
listretries: 5
- backend: "crypt" - backend: "crypt"
remote: "TestCryptDrive:" remote: "TestCryptDrive:"
fastlist: true fastlist: true

View file

@ -35,16 +35,17 @@ var (
// if retries are needed. // if retries are needed.
type Run struct { type Run struct {
// Config // Config
Remote string // name of the test remote Remote string // name of the test remote
Backend string // name of the backend Backend string // name of the backend
Path string // path to the source directory Path string // path to the source directory
FastList bool // add -fast-list to tests FastList bool // add -fast-list to tests
Short bool // add -short Short bool // add -short
NoRetries bool // don't retry if set NoRetries bool // don't retry if set
OneOnly bool // only run test for this backend at once OneOnly bool // only run test for this backend at once
NoBinary bool // set to not build a binary NoBinary bool // set to not build a binary
SizeLimit int64 // maximum test file size SizeLimit int64 // maximum test file size
Ignore map[string]struct{} Ignore map[string]struct{}
ListRetries int // -list-retries if > 0
// Internals // Internals
CmdLine []string CmdLine []string
CmdString string CmdString string
@ -336,8 +337,12 @@ func (r *Run) Init() {
r.CmdLine = []string{"./" + r.BinaryName()} r.CmdLine = []string{"./" + r.BinaryName()}
} }
r.CmdLine = append(r.CmdLine, prefix+"v", prefix+"timeout", timeout.String(), "-remote", r.Remote) r.CmdLine = append(r.CmdLine, prefix+"v", prefix+"timeout", timeout.String(), "-remote", r.Remote)
if *listRetries > 0 { listRetries := *listRetries
r.CmdLine = append(r.CmdLine, "-list-retries", fmt.Sprint(*listRetries)) if r.ListRetries > 0 {
listRetries = r.ListRetries
}
if listRetries > 0 {
r.CmdLine = append(r.CmdLine, "-list-retries", fmt.Sprint(listRetries))
} }
r.Try = 1 r.Try = 1
if *verbose { if *verbose {