This repository has been archived by the owner on Jun 15, 2021. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 92
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
4 changed files
with
51 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -35,7 +35,7 @@ pipeline { | |
script{ | ||
env.EXIT_STATUS = '' | ||
env.LS_RELEASE = sh( | ||
script: '''docker run --rm alexeiled/skopeo sh -c 'skopeo inspect docker://docker.io/'${DOCKERHUB_IMAGE}':latest 2>/dev/null' | jq -r '.Labels.build_version' | awk '{print $3}' | grep '\\-ls' || : ''', | ||
script: '''docker run --rm alexeiled/skopeo sh -c 'skopeo inspect docker://docker.io/'${DOCKERHUB_IMAGE}':xenial 2>/dev/null' | jq -r '.Labels.build_version' | awk '{print $3}' | grep '\\-ls' || : ''', | ||
returnStdout: true).trim() | ||
env.LS_RELEASE_NOTES = sh( | ||
script: '''cat readme-vars.yml | awk -F \\" '/date: "[0-9][0-9].[0-9][0-9].[0-9][0-9]:/ {print $4;exit;}' | sed -E ':a;N;$!ba;s/\\r{0,1}\\n/\\\\n/g' ''', | ||
|
@@ -120,10 +120,10 @@ pipeline { | |
} | ||
} | ||
} | ||
// If this is a master build use live docker endpoints | ||
// If this is a xenial build use live docker endpoints | ||
stage("Set ENV live build"){ | ||
when { | ||
branch "master" | ||
branch "xenial" | ||
environment name: 'CHANGE_ID', value: '' | ||
} | ||
steps { | ||
|
@@ -141,7 +141,7 @@ pipeline { | |
// If this is a dev build use dev docker endpoints | ||
stage("Set ENV dev build"){ | ||
when { | ||
not {branch "master"} | ||
not {branch "xenial"} | ||
environment name: 'CHANGE_ID', value: '' | ||
} | ||
steps { | ||
|
@@ -208,7 +208,7 @@ pipeline { | |
// Use helper containers to render templated files | ||
stage('Update-Templates') { | ||
when { | ||
branch "master" | ||
branch "xenial" | ||
environment name: 'CHANGE_ID', value: '' | ||
expression { | ||
env.CONTAINER_NAME != null | ||
|
@@ -219,15 +219,15 @@ pipeline { | |
set -e | ||
TEMPDIR=$(mktemp -d) | ||
docker pull linuxserver/jenkins-builder:latest | ||
docker run --rm -e CONTAINER_NAME=${CONTAINER_NAME} -e GITHUB_BRANCH=master -v ${TEMPDIR}:/ansible/jenkins linuxserver/jenkins-builder:latest | ||
docker run --rm -e CONTAINER_NAME=${CONTAINER_NAME} -e GITHUB_BRANCH=xenial -v ${TEMPDIR}:/ansible/jenkins linuxserver/jenkins-builder:latest | ||
docker pull linuxserver/doc-builder:latest | ||
docker run --rm -e CONTAINER_NAME=${CONTAINER_NAME} -e GITHUB_BRANCH=master -v ${TEMPDIR}:/ansible/readme linuxserver/doc-builder:latest | ||
docker run --rm -e CONTAINER_NAME=${CONTAINER_NAME} -e GITHUB_BRANCH=xenial -v ${TEMPDIR}:/ansible/readme linuxserver/doc-builder:latest | ||
if [ "$(md5sum ${TEMPDIR}/${LS_REPO}/Jenkinsfile | awk '{ print $1 }')" != "$(md5sum Jenkinsfile | awk '{ print $1 }')" ] || \ | ||
[ "$(md5sum ${TEMPDIR}/${CONTAINER_NAME}/README.md | awk '{ print $1 }')" != "$(md5sum README.md | awk '{ print $1 }')" ] || \ | ||
[ "$(cat ${TEMPDIR}/${LS_REPO}/LICENSE | md5sum | cut -c1-8)" != "${LICENSE_TAG}" ]; then | ||
mkdir -p ${TEMPDIR}/repo | ||
git clone https://github.com/${LS_USER}/${LS_REPO}.git ${TEMPDIR}/repo/${LS_REPO} | ||
git --git-dir ${TEMPDIR}/repo/${LS_REPO}/.git checkout -f master | ||
git --git-dir ${TEMPDIR}/repo/${LS_REPO}/.git checkout -f xenial | ||
cp ${TEMPDIR}/${CONTAINER_NAME}/README.md ${TEMPDIR}/repo/${LS_REPO}/ | ||
cp ${TEMPDIR}/docker-${CONTAINER_NAME}/Jenkinsfile ${TEMPDIR}/repo/${LS_REPO}/ | ||
cp ${TEMPDIR}/docker-${CONTAINER_NAME}/LICENSE ${TEMPDIR}/repo/${LS_REPO}/ | ||
|
@@ -259,7 +259,7 @@ pipeline { | |
// Exit the build if the Templated files were just updated | ||
stage('Template-exit') { | ||
when { | ||
branch "master" | ||
branch "xenial" | ||
environment name: 'CHANGE_ID', value: '' | ||
environment name: 'FILES_UPDATED', value: 'true' | ||
expression { | ||
|
@@ -358,7 +358,7 @@ pipeline { | |
// Take the image we just built and dump package versions for comparison | ||
stage('Update-packages') { | ||
when { | ||
branch "master" | ||
branch "xenial" | ||
environment name: 'CHANGE_ID', value: '' | ||
environment name: 'EXIT_STATUS', value: '' | ||
} | ||
|
@@ -386,7 +386,7 @@ pipeline { | |
echo "Package tag sha from current packages in buit container is ${NEW_PACKAGE_TAG} comparing to old ${PACKAGE_TAG} from github" | ||
if [ "${NEW_PACKAGE_TAG}" != "${PACKAGE_TAG}" ]; then | ||
git clone https://github.com/${LS_USER}/${LS_REPO}.git ${TEMPDIR}/${LS_REPO} | ||
git --git-dir ${TEMPDIR}/${LS_REPO}/.git checkout -f master | ||
git --git-dir ${TEMPDIR}/${LS_REPO}/.git checkout -f xenial | ||
cp ${TEMPDIR}/package_versions.txt ${TEMPDIR}/${LS_REPO}/ | ||
cd ${TEMPDIR}/${LS_REPO}/ | ||
wait | ||
|
@@ -410,7 +410,7 @@ pipeline { | |
// Exit the build if the package file was just updated | ||
stage('PACKAGE-exit') { | ||
when { | ||
branch "master" | ||
branch "xenial" | ||
environment name: 'CHANGE_ID', value: '' | ||
environment name: 'PACKAGE_UPDATED', value: 'true' | ||
environment name: 'EXIT_STATUS', value: '' | ||
|
@@ -424,7 +424,7 @@ pipeline { | |
// Exit the build if this is just a package check and there are no changes to push | ||
stage('PACKAGECHECK-exit') { | ||
when { | ||
branch "master" | ||
branch "xenial" | ||
environment name: 'CHANGE_ID', value: '' | ||
environment name: 'PACKAGE_UPDATED', value: 'false' | ||
environment name: 'EXIT_STATUS', value: '' | ||
|
@@ -509,12 +509,12 @@ pipeline { | |
sh '''#! /bin/bash | ||
echo $DOCKERPASS | docker login -u $DOCKERUSER --password-stdin | ||
''' | ||
sh "docker tag ${IMAGE}:${META_TAG} ${IMAGE}:latest" | ||
sh "docker push ${IMAGE}:latest" | ||
sh "docker tag ${IMAGE}:${META_TAG} ${IMAGE}:xenial" | ||
sh "docker push ${IMAGE}:xenial" | ||
sh "docker push ${IMAGE}:${META_TAG}" | ||
sh '''docker rmi \ | ||
${IMAGE}:${META_TAG} \ | ||
${IMAGE}:latest || :''' | ||
${IMAGE}:xenial || :''' | ||
|
||
} | ||
} | ||
|
@@ -544,32 +544,32 @@ pipeline { | |
docker tag lsiodev/buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER} ${IMAGE}:arm32v7-${META_TAG} | ||
docker tag lsiodev/buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER} ${IMAGE}:arm64v8-${META_TAG} | ||
fi''' | ||
sh "docker tag ${IMAGE}:amd64-${META_TAG} ${IMAGE}:amd64-latest" | ||
sh "docker tag ${IMAGE}:arm32v7-${META_TAG} ${IMAGE}:arm32v7-latest" | ||
sh "docker tag ${IMAGE}:arm64v8-${META_TAG} ${IMAGE}:arm64v8-latest" | ||
sh "docker tag ${IMAGE}:amd64-${META_TAG} ${IMAGE}:amd64-xenial" | ||
sh "docker tag ${IMAGE}:arm32v7-${META_TAG} ${IMAGE}:arm32v7-xenial" | ||
sh "docker tag ${IMAGE}:arm64v8-${META_TAG} ${IMAGE}:arm64v8-xenial" | ||
sh "docker push ${IMAGE}:amd64-${META_TAG}" | ||
sh "docker push ${IMAGE}:arm32v7-${META_TAG}" | ||
sh "docker push ${IMAGE}:arm64v8-${META_TAG}" | ||
sh "docker push ${IMAGE}:amd64-latest" | ||
sh "docker push ${IMAGE}:arm32v7-latest" | ||
sh "docker push ${IMAGE}:arm64v8-latest" | ||
sh "docker manifest push --purge ${IMAGE}:latest || :" | ||
sh "docker manifest create ${IMAGE}:latest ${IMAGE}:amd64-latest ${IMAGE}:arm32v7-latest ${IMAGE}:arm64v8-latest" | ||
sh "docker manifest annotate ${IMAGE}:latest ${IMAGE}:arm32v7-latest --os linux --arch arm" | ||
sh "docker manifest annotate ${IMAGE}:latest ${IMAGE}:arm64v8-latest --os linux --arch arm64 --variant v8" | ||
sh "docker push ${IMAGE}:amd64-xenial" | ||
sh "docker push ${IMAGE}:arm32v7-xenial" | ||
sh "docker push ${IMAGE}:arm64v8-xenial" | ||
sh "docker manifest push --purge ${IMAGE}:xenial || :" | ||
sh "docker manifest create ${IMAGE}:xenial ${IMAGE}:amd64-xenial ${IMAGE}:arm32v7-xenial ${IMAGE}:arm64v8-xenial" | ||
sh "docker manifest annotate ${IMAGE}:xenial ${IMAGE}:arm32v7-xenial --os linux --arch arm" | ||
sh "docker manifest annotate ${IMAGE}:xenial ${IMAGE}:arm64v8-xenial --os linux --arch arm64 --variant v8" | ||
sh "docker manifest push --purge ${IMAGE}:${META_TAG} || :" | ||
sh "docker manifest create ${IMAGE}:${META_TAG} ${IMAGE}:amd64-${META_TAG} ${IMAGE}:arm32v7-${META_TAG} ${IMAGE}:arm64v8-${META_TAG}" | ||
sh "docker manifest annotate ${IMAGE}:${META_TAG} ${IMAGE}:arm32v7-${META_TAG} --os linux --arch arm" | ||
sh "docker manifest annotate ${IMAGE}:${META_TAG} ${IMAGE}:arm64v8-${META_TAG} --os linux --arch arm64 --variant v8" | ||
sh "docker manifest push --purge ${IMAGE}:latest" | ||
sh "docker manifest push --purge ${IMAGE}:xenial" | ||
sh "docker manifest push --purge ${IMAGE}:${META_TAG}" | ||
sh '''docker rmi \ | ||
${IMAGE}:amd64-${META_TAG} \ | ||
${IMAGE}:amd64-latest \ | ||
${IMAGE}:amd64-xenial \ | ||
${IMAGE}:arm32v7-${META_TAG} \ | ||
${IMAGE}:arm32v7-latest \ | ||
${IMAGE}:arm32v7-xenial \ | ||
${IMAGE}:arm64v8-${META_TAG} \ | ||
${IMAGE}:arm64v8-latest \ | ||
${IMAGE}:arm64v8-xenial \ | ||
lsiodev/buildcache:arm32v7-${COMMIT_SHA}-${BUILD_NUMBER} \ | ||
lsiodev/buildcache:arm64v8-${COMMIT_SHA}-${BUILD_NUMBER} || :''' | ||
} | ||
|
@@ -578,7 +578,7 @@ pipeline { | |
// If this is a public release tag it in the LS Github | ||
stage('Github-Tag-Push-Release') { | ||
when { | ||
branch "master" | ||
branch "xenial" | ||
expression { | ||
env.LS_RELEASE != env.EXT_RELEASE_CLEAN + '-ls' + env.LS_TAG_NUMBER | ||
} | ||
|
@@ -590,17 +590,17 @@ pipeline { | |
sh '''curl -H "Authorization: token ${GITHUB_TOKEN}" -X POST https://api.github.com/repos/${LS_USER}/${LS_REPO}/git/tags \ | ||
-d '{"tag":"'${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER}'",\ | ||
"object": "'${COMMIT_SHA}'",\ | ||
"message": "Tagging Release '${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER}' to master",\ | ||
"message": "Tagging Release '${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER}' to xenial",\ | ||
"type": "commit",\ | ||
"tagger": {"name": "LinuxServer Jenkins","email": "[email protected]","date": "'${GITHUB_DATE}'"}}' ''' | ||
echo "Pushing New release for Tag" | ||
sh '''#! /bin/bash | ||
echo "Updating to ${EXT_RELEASE_CLEAN}" > releasebody.json | ||
echo '{"tag_name":"'${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER}'",\ | ||
"target_commitish": "master",\ | ||
"target_commitish": "xenial",\ | ||
"name": "'${EXT_RELEASE_CLEAN}'-ls'${LS_TAG_NUMBER}'",\ | ||
"body": "**LinuxServer Changes:**\\n\\n'${LS_RELEASE_NOTES}'\\n**Remote Changes:**\\n\\n' > start | ||
printf '","draft": false,"prerelease": false}' >> releasebody.json | ||
printf '","draft": false,"prerelease": true}' >> releasebody.json | ||
paste -d'\\0' start releasebody.json > releasebody.json.done | ||
curl -H "Authorization: token ${GITHUB_TOKEN}" -X POST https://api.github.com/repos/${LS_USER}/${LS_REPO}/releases -d @releasebody.json.done''' | ||
} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters