test/Jenkinsfile
2022-08-02 18:19:51 +02:00

71 lines
1.7 KiB
Groovy

def remote = [:]
remote.name = 'workstation'
remote.host = 'workstation'
remote.user = 'dany'
remote.identityFile = '/var/jenkins_home/.ssh/id_rsa'
remote.allowAnyHosts = true
remote.agent = false
remote.logLevel = 'INFO'
def build_antd()
{
sh '''
cat << EOF >> "$WORKSPACE"/build_antd.sh
printenv
uname -a
EOF
'''
docker.image("xsangle/ci-tools:latest-" + env.arch).withRun("bash $WORKSPACE/build_antd.sh")
}
pipeline{
agent { node{ label'master' }}
options {
// Limit build history with buildDiscarder option:
// daysToKeepStr: history is only kept up to this many days.
// numToKeepStr: only this many build logs are kept.
// artifactDaysToKeepStr: artifacts are only kept up to this many days.
// artifactNumToKeepStr: only this many builds have their artifacts kept.
buildDiscarder(logRotator(numToKeepStr: "1"))
// Enable timestamps in build log console
timestamps()
// Maximum time to run the whole pipeline before canceling it
timeout(time: 1, unit: 'HOURS')
// Use Jenkins ANSI Color Plugin for log console
ansiColor('xterm')
// Limit build concurrency to 1 per branch
disableConcurrentBuilds()
}
stages
{
stage('Test')
{
steps {
script {
env.arch = "arm64"
}
build_antd()
}
}
stage('Remote SSH') {
steps {
sshCommand remote: remote, command: '''
set -e
echo $WORKSPACE
pwd
export WORKSPACE="jenkins/workspace/test"
cd $WORKSPACE
bash test.sh
'''
sshCommand remote: remote, command: '''
for i in {1..5}; do
echo -n "Loop $i ";
date ;
sleep 1;
done
'''
}
}
}
}