Abandon travis-ci for jenkins
All checks were successful
moparisthebest/static-curl/pipeline/head This commit looks good

This commit is contained in:
Travis Burtrum 2020-11-24 00:21:25 -05:00
parent 0b1d428cec
commit f8fa26f01d
5 changed files with 53 additions and 59 deletions

43
.ci/Jenkinsfile vendored Normal file
View File

@ -0,0 +1,43 @@
properties(
[
disableConcurrentBuilds()
]
)
node('linux && docker') {
try {
stage('Checkout') {
//branch name from Jenkins environment variables
echo "My branch is: ${env.BRANCH_NAME}"
// this doesn't grab tags pointing to this branch
//checkout scm
// this hack does... https://issues.jenkins.io/browse/JENKINS-45164
checkout([
$class: 'GitSCM',
branches: [[name: 'refs/heads/'+env.BRANCH_NAME]],
extensions: [[$class: 'CloneOption', noTags: false, shallow: false, depth: 0, reference: '']],
userRemoteConfigs: scm.userRemoteConfigs,
])
sh '''
set -euxo pipefail
git checkout "$BRANCH_NAME" --
git reset --hard "origin/$BRANCH_NAME"
'''
}
stage('Build + Deploy') {
sh 'curl --compressed -sL https://code.moparisthebest.com/moparisthebest/self-ci/raw/branch/master/build-ci.sh | bash -s -- -l c -b ./build.sh'
}
currentBuild.result = 'SUCCESS'
} catch (Exception err) {
currentBuild.result = 'FAILURE'
} finally {
stage('Email') {
step([$class: 'Mailer', notifyEveryUnstableBuild: true, recipients: 'admin.jenkins@moparisthebest.com', sendToIndividuals: true])
}
sh './bin/build.sh docker-chown'
deleteDir()
}
}

View File

@ -1,26 +0,0 @@
language: minimal
services: docker
matrix:
include:
- env: ARCH='amd64' DOCKER_IMAGE='alpine'
- env: ARCH='aarch64' DOCKER_IMAGE='alpine'
arch: arm64
- env: ARCH='i386' DOCKER_IMAGE='multiarch/alpine:i386-latest-stable'
# - env: ARCH='x86' DOCKER_IMAGE='multiarch/alpine:x86-latest-stable'
- env: ARCH='ppc64le' DOCKER_IMAGE='multiarch/alpine:ppc64le-latest-stable'
# - env: ARCH='armhf' DOCKER_IMAGE='multiarch/alpine:armhf-latest-stable'
- env: ARCH='armv7' DOCKER_IMAGE='multiarch/alpine:armv7-latest-stable'
arch: arm64
script:
- ./docker_build.sh "$DOCKER_IMAGE" "$ARCH"
deploy:
api_key: $GITHUB_OAUTH
file_glob: true
file: curl*
on:
tags: true
provider: releases
skip_cleanup: true

View File

@ -1,6 +1,6 @@
:mechanical_arm: Static curl :mechanical_arm: :mechanical_arm: Static curl :mechanical_arm:
----------- -----------
[![Travis-CI Build Status](https://api.travis-ci.org/moparisthebest/static-curl.svg?branch=master)](https://travis-ci.org/moparisthebest/static-curl) [![Build Status](https://ci.moparisthe.best/job/moparisthebest/job/static-curl/job/master/badge/icon%3Fstyle=plastic)](https://ci.moparisthe.best/job/moparisthebest/job/static-curl/job/master/)
These are a couple simple scripts to build a fully static curl binary using alpine linux docker containers. Currently it is a featureful build with OpenSSL, libssh2, nghttp2, and zlib, supporting most protocols. Tweak configure options in [build.sh](build.sh#L50) if you need something else (and/or suggest or PR). These are a couple simple scripts to build a fully static curl binary using alpine linux docker containers. Currently it is a featureful build with OpenSSL, libssh2, nghttp2, and zlib, supporting most protocols. Tweak configure options in [build.sh](build.sh#L50) if you need something else (and/or suggest or PR).
@ -18,5 +18,4 @@ Development
File explanation: File explanation:
- [build.sh](build.sh) - runs inside an alpine docker container, downloads curl, verifies it with gpg, and builds it - [build.sh](build.sh) - runs inside an alpine docker container, downloads curl, verifies it with gpg, and builds it
- [docker_build.sh](docker_build.sh) - runs build.sh inside docker
- [mykey.asc](mykey.asc) - Daniel Stenberg's [GPG key](https://daniel.haxx.se/address.html) used for signing/verifying curl releases - [mykey.asc](mykey.asc) - Daniel Stenberg's [GPG key](https://daniel.haxx.se/address.html) used for signing/verifying curl releases

View File

@ -1,10 +1,9 @@
#!/bin/sh #!/bin/sh
# to test locally, run one of: # to test locally, run one of:
# docker run --rm -v $(pwd):/tmp alpine /tmp/build.sh # docker run --rm -v $(pwd):/tmp -w /tmp -e ARCH=amd64 alpine /tmp/build.sh
# docker run --rm -v $(pwd):/tmp multiarch/alpine:armhf-latest-stable /tmp/build.sh # docker run --rm -v $(pwd):/tmp -w /tmp -e ARCH=aarch64 multiarch/alpine:aarch64-latest-stable /tmp/build.sh
# docker run --rm -v $(pwd):/tmp i386/alpine /tmp/build.sh # docker run --rm -v $(pwd):/tmp -w /tmp -e ARCH=ARCH_HERE ALPINE_IMAGE_HERE /tmp/build.sh
# docker run --rm -v $(pwd):/tmp ALPINE_IMAGE_HERE /tmp/build.sh
CURL_VERSION='7.73.0' CURL_VERSION='7.73.0'
@ -12,9 +11,6 @@ CURL_VERSION='7.73.0'
set -exu set -exu
# change to the directory this script is in, we assume mykey.asc is there
cd "$(dirname "$0")"
if [ ! -f curl-${CURL_VERSION}.tar.gz ] if [ ! -f curl-${CURL_VERSION}.tar.gz ]
then then
@ -63,5 +59,8 @@ ldd src/curl || true
#./src/curl -v http://www.moparisthebest.com/; ./src/curl -v https://www.moparisthebest.com/ip #./src/curl -v http://www.moparisthebest.com/; ./src/curl -v https://www.moparisthebest.com/ip
# we only want to save curl here, by moving it to /tmp/ for now # we only want to save curl here
mv src/curl /tmp/ mkdir -p /tmp/release/
mv src/curl "/tmp/release/curl-$ARCH"
cd ..
rm -rf "curl-${CURL_VERSION}/"

View File

@ -1,21 +0,0 @@
#!/bin/sh
DOCKER_IMAGE="$1"
shift
ARCH="$1"
BUILD_DIR=/tmp/static-curl/
rm -rf "$BUILD_DIR"
mkdir -p "$BUILD_DIR"
cp build.sh mykey.asc "$BUILD_DIR"
# if this is a multiarch image, must register binfmt handlers
echo "$DOCKER_IMAGE" | grep multiarch && docker run --rm --privileged multiarch/qemu-user-static:register --reset
docker run --rm -v "$BUILD_DIR":/tmp "$DOCKER_IMAGE" /tmp/build.sh || exit 1
mv "$BUILD_DIR"curl "./curl-$ARCH"
rm -rf "$BUILD_DIR" 2>/dev/null
exit 0