* License for the specific language governing permissions and limitations
* under the License.
*/
+
+/* Change log:
+ * 1. Bug 745 : Jayant Madavi, Mrityunjay Yadav : JM00553988@techmahindra.com : 23-july-2019 : Improvement to the code, typically we have 2 * or more branches whose build gets triggered, ex master & release branch, the previous code was removing any/all docker.
+ * Now removing previous docker of the same branch, so that the other branch failed docker should not be removed. It also
+ * acts as clean-up for previous docker remove failure.
+ * 2. Feature 7829 : Mrityunjay Yadav, Jayant Madavi: MY00514913@techmahindra.com : 19-Aug-2019 : Added a parameters & function to invoke Robot test.
+ */
properties([
parameters([
string(defaultValue: '', description: '', name: 'UPSTREAM_JOB_NAME'),
string(defaultValue: '', description: '', name: 'UPSTREAM_JOB_NUMBER'),
string(defaultValue: '', description: '', name: 'UPSTREAM_JOB_NUMBER'),
- string(defaultValue: 'dpkg1', description: '', name: 'GPG_KEY_NAME'),
+ string(defaultValue: 'OSMETSI', description: '', name: 'GPG_KEY_NAME'),
string(defaultValue: 'artifactory-osm', description: '', name: 'ARTIFACTORY_SERVER'),
string(defaultValue: 'osm-stage_4', description: '', name: 'DOWNSTREAM_STAGE_NAME'),
- booleanParam(defaultValue: false, description: '', name: 'SAVE_CONTAINER_ON_FAIL'),
+ string(defaultValue: 'releaseseven-daily', description: '', name: 'DOCKER_TAG'),
+ booleanParam(defaultValue: true, description: '', name: 'SAVE_CONTAINER_ON_FAIL'),
booleanParam(defaultValue: false, description: '', name: 'SAVE_CONTAINER_ON_PASS'),
- booleanParam(defaultValue: false, description: '', name: 'DO_STAGE_4'),
+ booleanParam(defaultValue: true, description: '', name: 'SAVE_ARTIFACTS_ON_SMOKE_SUCCESS'),
+ booleanParam(defaultValue: true, description: '', name: 'DO_STAGE_4'),
booleanParam(defaultValue: true, description: '', name: 'DO_BUILD'),
booleanParam(defaultValue: true, description: '', name: 'DO_INSTALL'),
booleanParam(defaultValue: true, description: '', name: 'DO_SMOKE'),
+ booleanParam(defaultValue: true, description: '', name: 'DO_DOCKERPUSH'),
booleanParam(defaultValue: false, description: '', name: 'SAVE_ARTIFACTS_OVERRIDE'),
+ string(defaultValue: '/home/jenkins/hive/openstack-etsi.rc', description: '', name: 'HIVE_VIM_1'),
+ booleanParam(defaultValue: false, description: '', name: 'DO_ROBOT'),
+ string(defaultValue: 'sanity', description: 'smoke/vim/sanity/comprehensive are the options', name: 'TEST_NAME'),
+ string(defaultValue: '/home/jenkins/hive/robot-systest.cfg', description: '', name: 'ROBOT_VIM'),
])
])
"""
}
-def run_systest(stackName,tagName,testName) {
- sh """
- tempdir=$(mktemp -d)
- docker run -ti --network net${stackName} -v $tempdir:/usr/share/osm-devops/systest/reports osm/osmclient:${tagName} make -C /usr/share/osm-devops/systest ${testName}
- cp $tempdir/*.xml .
- """
+def run_systest(stackName,tagName,testName,envfile=null) {
+ tempdir = sh(returnStdout: true, script: "mktemp -d").trim()
+ if ( !envfile )
+ {
+ sh(script: "touch ${tempdir}/env")
+ envfile="${tempdir}/env"
+ }
+ sh "docker run --network net${stackName} --env-file ${envfile} -v ${tempdir}:/usr/share/osm-devops/systest/reports opensourcemano/osmclient:${tagName} make -C /usr/share/osm-devops/systest ${testName}"
+ sh "cp ${tempdir}/* ."
junit '*.xml'
}
+def run_robot_systest(stackName,tagName,testName,envfile=null) {
+ tempdir = sh(returnStdout: true, script: "mktemp -d").trim()
+ if ( !envfile )
+ {
+ sh(script: "touch ${tempdir}/env")
+ envfile="${tempdir}/env"
+ }
+ sh "docker run --network net${stackName} --env-file ${envfile} -v ${tempdir}:/usr/share/osm-devops/robot-systest/reports opensourcemano/osmclient:${tagName} bash -C /usr/share/osm-devops/robot-systest/run_test.sh --do_install -t ${testName}"
+ sh "cp ${tempdir}/* ."
+ outputDirectory = sh(returnStdout: true, script: "pwd").trim()
+ println ("Present Directory is : ${outputDirectory}")
+ step([
+ $class : 'RobotPublisher',
+ outputPath : "${outputDirectory}",
+ outputFileName : "*.xml",
+ disableArchiveOutput : false,
+ reportFileName : "report.html",
+ logFileName : "log.html",
+ passThreshold : 0,
+ unstableThreshold: 0,
+ otherFiles : "*.png",
+ ])
+}
+
node("${params.NODE}") {
sh 'env'
upstream_main_job += '-merge'
container_name_prefix = "osm-${tag_or_branch}"
container_name = "${container_name_prefix}"
+
+ keep_artifacts = false
if ( JOB_NAME.contains('merge') ) {
container_name += "-merge"
+
+ // On a merge job, we keep artifacts on smoke success
+ keep_artifacts = params.SAVE_ARTIFACTS_ON_SMOKE_SUCCESS
}
container_name += "-${BUILD_NUMBER}"
// grab all stable upstream builds based on the
dir("${RELEASE}") {
- def list = ["RO", "openvim", "osmclient", "IM", "devops", "MON", "N2VC", "NBI", "common", "LCM", "POL"]
+ def list = ["RO", "openvim", "osmclient", "IM", "devops", "MON", "N2VC", "NBI", "common", "LCM", "POL", "LW-UI"]
for (component in list) {
step ([$class: 'CopyArtifact',
projectName: "${component}${upstream_main_job}/${GERRIT_BRANCH}"])
// the upstream job name contains suffix with the project. Need this stripped off
def project_without_branch = params.UPSTREAM_JOB_NAME.split('/')[0]
+ // Remove the previous artifact for this component. Use the new upstream artifact
+ sh "rm -rf pool/${component}"
+
ci_helper.get_archive(params.ARTIFACTORY_SERVER,component,GERRIT_BRANCH, "${project_without_branch} :: ${GERRIT_BRANCH}", build_num)
sh "rm -rf dists"
rm -f changelog/changelog-osm.html
[ ! -d changelog ] || for mdgchange in \$(ls changelog); do cat changelog/\$mdgchange >> changelog/changelog-osm.html; done
"""
+ RELEASE_DIR = sh(returnStdout:true, script: 'pwd').trim()
}
// start an apache server to serve up the images
http_server_name = "${container_name}-apache"
pwd = sh(returnStdout:true, script: 'pwd').trim()
repo_base_url = ci_helper.start_http_server(pwd,http_server_name)
}
- }
- error = null
- if ( params.DO_BUILD ) {
- stage("Build") {
- sh "make -C docker clean"
- sh "make -j4 -C docker CMD_DOCKER_ARGS= TAG=${container_name} RELEASE=${params.RELEASE} REPOSITORY_BASE=${repo_base_url} REPOSITORY_KEY=${params.REPO_KEY_NAME} REPOSITORY=${params.REPO_DISTRO}"
- }
+ // now pull the devops package and install in temporary location
+ tempdir = sh(returnStdout: true, script: "mktemp -d").trim()
+ osm_devops_dpkg = sh(returnStdout: true, script: "find . -name osm-devops*.deb").trim()
+ sh "dpkg -x ${osm_devops_dpkg} ${tempdir}"
+ OSM_DEVOPS="${tempdir}/usr/share/osm-devops"
}
- try {
- if ( params.DO_INSTALL ) {
- stage("Install") {
-
- //will by default always delete containers on complete
- //sh "jenkins/system/delete_old_containers.sh ${container_name_prefix}"
-
- commit_id = ''
- repo_distro = ''
- repo_key_name = ''
- release = ''
-
- if ( params.COMMIT_ID )
- {
- commit_id = "-b ${params.COMMIT_ID}"
- }
+ dir(OSM_DEVOPS) {
+ error = null
+ if ( params.DO_BUILD ) {
+ stage("Build") {
+ sh "make -C docker clean"
+ sh "make -C docker Q= CMD_DOCKER_ARGS= TAG=${container_name} RELEASE=${params.RELEASE} REPOSITORY_BASE=${repo_base_url} REPOSITORY_KEY=${params.REPO_KEY_NAME} REPOSITORY=${params.REPO_DISTRO}"
+ }
+ }
- if ( params.REPO_DISTRO )
- {
- repo_distro = "-r ${params.REPO_DISTRO}"
+ try {
+ if ( params.DO_INSTALL ) {
+ stage("Install") {
+
+ //will by default always delete containers on complete
+ //sh "jenkins/system/delete_old_containers.sh ${container_name_prefix}"
+
+ commit_id = ''
+ repo_distro = ''
+ repo_key_name = ''
+ release = ''
+
+ if ( params.COMMIT_ID )
+ {
+ commit_id = "-b ${params.COMMIT_ID}"
+ }
+
+ if ( params.REPO_DISTRO )
+ {
+ repo_distro = "-r ${params.REPO_DISTRO}"
+ }
+
+ if ( params.REPO_KEY_NAME )
+ {
+ repo_key_name = "-k ${params.REPO_KEY_NAME}"
+ }
+
+ if ( params.RELEASE )
+ {
+ release = "-R ${params.RELEASE}"
+ }
+
+ if ( params.REPOSITORY_BASE )
+ {
+ repo_base_url = "-u ${params.REPOSITORY_BASE}"
+ }
+ if ( params.DO_STAGE_4 ) {
+ try {
+ sh "docker stack list |grep \"${container_name_prefix}\"| awk '{ print \$1 }'| xargs docker stack rm"
+ }
+ catch (caughtError) {
+ println("Caught error: docker stack rm failed!")
+ }
+ }
+ sh """
+ export PATH=$PATH:/snap/bin
+ installers/full_install_osm.sh -y -s ${container_name} --test --nolxd --nodocker --nojuju --nohostports --nohostclient \
+ --nodockerbuild -t ${container_name} \
+ -w /tmp/osm \
+ ${commit_id} \
+ ${repo_distro} \
+ ${repo_base_url} \
+ ${repo_key_name} \
+ ${release} \
+ ${params.BUILD_FROM_SOURCE}
+ """
}
+ }
- if ( params.REPO_KEY_NAME )
- {
- repo_key_name = "-k ${params.REPO_KEY_NAME}"
+ stage_archive = false
+ if ( params.DO_SMOKE ) {
+ stage("OSM Health") {
+ sh "installers/osm_health.sh -s ${container_name}"
}
-
- if ( params.RELEASE )
- {
- release = "-R ${params.RELEASE}"
+ stage("Smoke") {
+ run_systest(container_name,container_name,"smoke")
+ // archive smoke success until stage_4 is ready
+
+ if ( ! currentBuild.result.equals('UNSTABLE') ) {
+ stage_archive = keep_artifacts
+ } else {
+ error = new Exception("Smoke test failed")
+ currentBuild.result = 'FAILURE'
+ }
}
-
- sh """
- export PATH=$PATH:/snap/bin
- installers/full_install_osm.sh -y -s ${container_name} --test --nolxd --nodocker --nojuju --nohostports --nohostclient \
- --nodockerbuild -t ${container_name} \
- -w /tmp/osm \
- ${commit_id} \
- ${repo_distro} \
- ${repo_base_url} \
- ${repo_key_name} \
- ${release} \
- ${params.BUILD_FROM_SOURCE}
- """
}
- }
- if ( params.DO_SMOKE ) {
- stage("OSM Health") {
- sh "installers/osm_health.sh -s ${container_name}"
- }
- stage("Smoke") {
- run_systest(container_name,container_name,"smoke")
- }
- }
-
- stage_4_archive = false
- if ( params.DO_STAGE_4 ) {
- stage("stage_4") {
- def downstream_params = [
- string(name: 'CONTAINER_NAME', value: container_name),
- string(name: 'NODE', value: NODE_NAME.split()[0]),
- ]
- stage_4_result = build job: "${params.DOWNSTREAM_STAGE_NAME}/${GERRIT_BRANCH}", parameters: downstream_params, propagate: false
- currentBuild.result = stage_4_result.result
-
- if ( stage_4_result.getResult().equals('SUCCESS') ) {
- stage_4_archive = true;
+ if ( params.DO_STAGE_4 ) {
+ // override stage_archive to only archive on stable
+ stage_archive = false
+ stage("System Integration Test") {
+ if ( params.DO_ROBOT ) {
+ run_robot_systest(container_name,container_name,params.TEST_NAME,params.ROBOT_VIM)
+ } //else {
+ run_systest(container_name,container_name,"openstack_stage_4",params.HIVE_VIM_1)
+ //}
+
+ if ( ! currentBuild.result.equals('UNSTABLE') && ! currentBuild.result.equals('FAILURE')) {
+ stage_archive = keep_artifacts
+ } else {
+ println ("Systest test failed, throwing error")
+ error = new Exception("Systest test failed")
+ currentBuild.result = 'FAILURE'
+ throw error
+ }
}
}
- }
-
- // override to save the artifacts
- if ( params.SAVE_ARTIFACTS_OVERRIDE || stage_4_archive ) {
- stage("Archive") {
- sh "echo ${container_name} > build_version.txt"
- archiveArtifacts artifacts: "build_version.txt", fingerprint: true
- // Archive the tested repo
- dir("repo/${RELEASE}") {
- ci_helper.archive(params.ARTIFACTORY_SERVER,RELEASE,GERRIT_BRANCH,'tested')
+ // override to save the artifacts
+ if ( params.SAVE_ARTIFACTS_OVERRIDE || stage_archive ) {
+ stage("Archive") {
+ sh "echo ${container_name} > build_version.txt"
+ archiveArtifacts artifacts: "build_version.txt", fingerprint: true
+
+ // Archive the tested repo
+ dir("${RELEASE_DIR}") {
+ ci_helper.archive(params.ARTIFACTORY_SERVER,RELEASE,GERRIT_BRANCH,'tested')
+ }
+ if ( params.DO_DOCKERPUSH ) {
+ stage("Docker Push") {
+ sh "make -C docker push INPUT_TAG=${container_name} TAG=${params.DOCKER_TAG}"
+ }
+ }
}
}
}
- }
- catch(caughtError) {
- println("Caught error!")
- error = caughtError
- currentBuild.result = 'FAILURE'
- }
- finally {
- sh "docker stop ${http_server_name}"
- sh "docker rm ${http_server_name}"
-
- if ( params.DO_INSTALL ) {
- if (error) {
- if ( !params.SAVE_CONTAINER_ON_FAIL ) {
- uninstall_osm container_name
+ catch(Exception ex) {
+ error = ex
+ currentBuild.result = 'FAILURE'
+ println("Caught error")
+ println(ex.getMessage())
+ }
+ finally {
+ if ( params.DO_INSTALL ) {
+ if (error) {
+ if ( !params.SAVE_CONTAINER_ON_FAIL ) {
+ uninstall_osm container_name
+ sh "docker stop ${http_server_name}"
+ sh "docker rm ${http_server_name}"
+ }
}
- throw error
- }
- else {
- if ( !params.SAVE_CONTAINER_ON_PASS ) {
- uninstall_osm container_name
+ else {
+ if ( !params.SAVE_CONTAINER_ON_PASS ) {
+ uninstall_osm container_name
+ sh "docker stop ${http_server_name}"
+ sh "docker rm ${http_server_name}"
+ }
}
}
}