Unverified 提交 d166b2cf 作者: Whyrusleeping 提交者: GitHub

Merge pull request #4958 from ipfs/feat/ci/timeouts

ci: Add more timeouts to the jenkins pipeline
...@@ -2,6 +2,12 @@ import groovy.transform.Field ...@@ -2,6 +2,12 @@ import groovy.transform.Field
/* SETTINGS */ /* SETTINGS */
// in minutes
def sharness_timeout = 15
def gotest_timeout = 10
def build_timeout = 20
def check_timeout = 4
def test = 'go test -v ./...' def test = 'go test -v ./...'
def fast_build_platforms = [ def fast_build_platforms = [
...@@ -64,21 +70,27 @@ def gobuild_step(list) { ...@@ -64,21 +70,27 @@ def gobuild_step(list) {
/* PIPELINE */ /* PIPELINE */
ansiColor('xterm') { withEnv(['TERM=xterm-color']) { timeout(time: 30, unit: 'MINUTES') { ansiColor('xterm') { withEnv(['TERM=xterm-color']) {
stage('Checks') { stage('Checks') {
parallel( parallel(
'go fmt': { 'go fmt': {
setupStep('linux') { run -> setupStep('linux') { run ->
run 'make test_go_fmt' timeout(time: check_timeout, unit: 'MINUTES') {
run 'make test_go_fmt'
}
} }
}, },
'go vet': { 'go vet': {
setupStep('linux') { run -> setupStep('linux') { run ->
run 'go vet ./...' timeout(time: check_timeout, unit: 'MINUTES') {
run 'go vet ./...'
}
} }
}, },
'go build': { 'go build': {
gobuild_step(fast_build_platforms) timeout(time: check_timeout, unit: 'MINUTES') {
gobuild_step(fast_build_platforms)
}
} }
) )
} }
...@@ -86,84 +98,96 @@ ansiColor('xterm') { withEnv(['TERM=xterm-color']) { timeout(time: 30, unit: 'MI ...@@ -86,84 +98,96 @@ ansiColor('xterm') { withEnv(['TERM=xterm-color']) { timeout(time: 30, unit: 'MI
stage('Tests') { stage('Tests') {
parallel( parallel(
'go build (other platforms)': { 'go build (other platforms)': {
gobuild_step(build_platforms) timeout(time: build_timeout, unit: 'MINUTES') {
gobuild_step(build_platforms)
}
}, },
windows: { windows: {
setupStep('windows') { run -> setupStep('windows') { run ->
run 'go get -v github.com/jstemmer/go-junit-report github.com/whyrusleeping/gx github.com/whyrusleeping/gx-go' timeout(time: gotest_timeout, unit: 'MINUTES') {
run "gx install --global" run 'go get -v github.com/jstemmer/go-junit-report github.com/whyrusleeping/gx github.com/whyrusleeping/gx-go'
run "gx install --global"
try {
run test + ' -tags="nofuse" > output & type output' try {
run 'type output | go-junit-report > junit-report-windows.xml' run test + ' -tags="nofuse" > output & type output'
} catch (err) { run 'type output | go-junit-report > junit-report-windows.xml'
throw err } catch (err) {
} finally { throw err
/* IGNORE TEST FAILS */ } finally {
/* junit allowEmptyResults: true, testResults: 'junit-report-*.xml' */ /* IGNORE TEST FAILS */
/* junit allowEmptyResults: true, testResults: 'junit-report-*.xml' */
}
} }
} }
}, },
linux: { linux: {
setupStep('linux') { run -> setupStep('linux') { run ->
run 'go get -v github.com/jstemmer/go-junit-report' timeout(time: gotest_timeout, unit: 'MINUTES') {
run "make gx-deps" run 'go get -v github.com/jstemmer/go-junit-report'
run "make gx-deps"
try {
run test + ' -tags="nofuse" 2>&1 | tee output' try {
run 'cat output | go-junit-report > junit-report-linux.xml' run test + ' -tags="nofuse" 2>&1 | tee output'
} catch (err) { run 'cat output | go-junit-report > junit-report-linux.xml'
throw err } catch (err) {
} finally { throw err
junit allowEmptyResults: true, testResults: 'junit-report-*.xml' } finally {
junit allowEmptyResults: true, testResults: 'junit-report-*.xml'
}
} }
} }
}, },
linuxSharness: { linuxSharness: {
setupStep('linux') { run -> setupStep('linux') { run ->
run 'go get -v github.com/jstemmer/go-junit-report' timeout(time: sharness_timeout, unit: 'MINUTES') {
run "make gx-deps" run 'go get -v github.com/jstemmer/go-junit-report'
run "make gx-deps"
try {
run "make -j12 -Otarget test/sharness/test-results/sharness.xml CONTINUE_ON_S_FAILURE=1 TEST_NO_FUSE=1 TEST_NO_DOCKER=1" try {
} catch (err) { run "make -j12 -Otarget test/sharness/test-results/sharness.xml CONTINUE_ON_S_FAILURE=1 TEST_NO_FUSE=1 TEST_NO_DOCKER=1"
throw err } catch (err) {
} finally { throw err
junit allowEmptyResults: true, testResults: 'test/sharness/test-results/sharness.xml' } finally {
junit allowEmptyResults: true, testResults: 'test/sharness/test-results/sharness.xml'
}
} }
} }
}, },
macOS: { macOS: {
setupStep('macos') { run -> setupStep('macos') { run ->
run 'go get -v github.com/jstemmer/go-junit-report' timeout(time: gotest_timeout, unit: 'MINUTES') {
run "make gx-deps" run 'go get -v github.com/jstemmer/go-junit-report'
run "make gx-deps"
try {
run test + ' -tags="nofuse" 2>&1 | tee output' try {
run 'cat output | go-junit-report > junit-report-macos.xml' run test + ' -tags="nofuse" 2>&1 | tee output'
} catch (err) { run 'cat output | go-junit-report > junit-report-macos.xml'
throw err } catch (err) {
} finally { throw err
/* IGNORE TEST FAILS */ } finally {
/* junit 'junit-report-*.xml' */ /* IGNORE TEST FAILS */
/* junit 'junit-report-*.xml' */
}
} }
} }
}, },
macSharness: { macSharness: {
setupStep('macos') { run -> setupStep('macos') { run ->
run 'go get -v github.com/jstemmer/go-junit-report' timeout(time: sharness_timeout, unit: 'MINUTES') {
run "make gx-deps" run 'go get -v github.com/jstemmer/go-junit-report'
run "make gx-deps"
try {
run "make -j12 test/sharness/test-results/sharness.xml CONTINUE_ON_S_FAILURE=1 TEST_NO_FUSE=1" try {
} catch (err) { run "make -j12 test/sharness/test-results/sharness.xml CONTINUE_ON_S_FAILURE=1 TEST_NO_FUSE=1"
throw err } catch (err) {
} finally { throw err
/* IGNORE TEST FAILS */ } finally {
/* junit allowEmptyResults: true, testResults: 'test/sharness/test-results/sharness.xml' */ /* IGNORE TEST FAILS */
/* junit allowEmptyResults: true, testResults: 'test/sharness/test-results/sharness.xml' */
}
} }
} }
}, },
) )
} }
}}} }}
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论