More pipeline development
This commit is contained in:
parent
c8e5ac7750
commit
adf2ceaaf4
@ -1,14 +1,33 @@
|
|||||||
|
def ImageRepository = "registry.test-chamber-13.lan:5000"
|
||||||
|
def ImageName = "factorio"
|
||||||
|
def ImageTag = "latest"
|
||||||
|
|
||||||
|
def AlpineGlibcBaseURL = "https://github.com/sgerrand/alpine-pkg-glibc/releases/download"
|
||||||
|
def AlpineGlibcPackageVersion = "2.30-r0"
|
||||||
|
def AlpineGlibcBasePackageFilename = "glibc-${AlpineGlibcPackageVersion}.apk"
|
||||||
|
def AlpineGlibcBinPackageFilename = "glibc-${AlpineGlibcPackageVersion}.apk"
|
||||||
|
def AlpineGlibcI18nPackageFilename = "glibc-${AlpineGlibcPackageVersion}.apk"
|
||||||
|
|
||||||
|
def FactorioDownloadURL = "https://www.factorio.com/get-download/stable/headless/linux64"
|
||||||
|
def FactorioFileName = "/tmp/factorio.tar"
|
||||||
|
|
||||||
|
def dockerFile = """
|
||||||
FROM alpine:3.10
|
FROM alpine:3.10
|
||||||
|
|
||||||
|
MAINTAINER The_Spider <spider@smoothnet.org>
|
||||||
|
|
||||||
RUN \
|
RUN \
|
||||||
ALPINE_GLIBC_BASE_URL="https://github.com/sgerrand/alpine-pkg-glibc/releases/download" && \
|
apk add --update --no-cache \
|
||||||
ALPINE_GLIBC_PACKAGE_VERSION="2.30-r0" && \
|
pwgen \
|
||||||
ALPINE_GLIBC_BASE_PACKAGE_FILENAME="glibc-$ALPINE_GLIBC_PACKAGE_VERSION.apk" && \
|
su-exec \
|
||||||
ALPINE_GLIBC_BIN_PACKAGE_FILENAME="glibc-bin-$ALPINE_GLIBC_PACKAGE_VERSION.apk" && \
|
binutils \
|
||||||
ALPINE_GLIBC_I18N_PACKAGE_FILENAME="glibc-i18n-$ALPINE_GLIBC_PACKAGE_VERSION.apk" && \
|
gettext \
|
||||||
apk add --no-cache --virtual=.build-dependencies wget ca-certificates && \
|
libintl \
|
||||||
printf '%s\n' \
|
shadow && \
|
||||||
"-----BEGIN PUBLIC KEY-----" \
|
apk add --update --no-cache --virtual=.build-dependencies \
|
||||||
|
curl \
|
||||||
|
ca-certificates && \
|
||||||
|
printf '%s\n' "-----BEGIN PUBLIC KEY-----" \
|
||||||
"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEApZ2u1KJKUu/fW4A25y9m" \
|
"MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEApZ2u1KJKUu/fW4A25y9m" \
|
||||||
"y70AGEa/J3Wi5ibNVGNn1gT1r0VfgeWd0pUybS4UmcHdiNzxJPgoWQhV2SSW1JYu" \
|
"y70AGEa/J3Wi5ibNVGNn1gT1r0VfgeWd0pUybS4UmcHdiNzxJPgoWQhV2SSW1JYu" \
|
||||||
"tOqKZF5QSN6X937PTUpNBjUvLtTQ1ve1fp39uf/lEXPpFpOPL88LKnDBgbh7wkCp" \
|
"tOqKZF5QSN6X937PTUpNBjUvLtTQ1ve1fp39uf/lEXPpFpOPL88LKnDBgbh7wkCp" \
|
||||||
@ -17,22 +36,80 @@ RUN \
|
|||||||
"Zvo9GI2e2MaZyo9/lvb+LbLEJZKEQckqRj4P26gmASrZEPStwc+yqy1ShHLA0j6m" \
|
"Zvo9GI2e2MaZyo9/lvb+LbLEJZKEQckqRj4P26gmASrZEPStwc+yqy1ShHLA0j6m" \
|
||||||
"1QIDAQAB" \
|
"1QIDAQAB" \
|
||||||
"-----END PUBLIC KEY-----" > "/etc/apk/keys/sgerrand.rsa.pub" && \
|
"-----END PUBLIC KEY-----" > "/etc/apk/keys/sgerrand.rsa.pub" && \
|
||||||
wget \
|
curl -sSLO "${AlpineGlibcBaseURL}/${AlpineGlibcPackageVersion}/${AlpineGlibcBasePackageFilename}" && \
|
||||||
"$ALPINE_GLIBC_BASE_URL/$ALPINE_GLIBC_PACKAGE_VERSION/$ALPINE_GLIBC_BASE_PACKAGE_FILENAME" \
|
curl -sSLO "${AlpineGlibcBaseURL}/${AlpineGlibcPackageVersion}/${AlpineGlibcBinPackageFilename}" && \
|
||||||
"$ALPINE_GLIBC_BASE_URL/$ALPINE_GLIBC_PACKAGE_VERSION/$ALPINE_GLIBC_BIN_PACKAGE_FILENAME" \
|
curl -sSLO "${AlpineGlibcBaseURL}/${AlpineGlibcPackageVersion}/${AlpineGlibcI18nPackageFilename}" && \
|
||||||
"$ALPINE_GLIBC_BASE_URL/$ALPINE_GLIBC_PACKAGE_VERSION/$ALPINE_GLIBC_I18N_PACKAGE_FILENAME" && \
|
|
||||||
apk add --no-cache \
|
apk add --no-cache \
|
||||||
"$ALPINE_GLIBC_BASE_PACKAGE_FILENAME" \
|
"${AlpineGlibcBasePackageFilename}" \
|
||||||
"$ALPINE_GLIBC_BIN_PACKAGE_FILENAME" \
|
"${AlpineGlibcBinPackageFilename}" \
|
||||||
"$ALPINE_GLIBC_I18N_PACKAGE_FILENAME" && \
|
"${AlpineGlibcI18nPackageFilename}" && \
|
||||||
rm -v "/etc/apk/keys/sgerrand.rsa.pub" && \
|
rm -v "/etc/apk/keys/sgerrand.rsa.pub" && \
|
||||||
/usr/glibc-compat/bin/localedef --force --inputfile POSIX --charmap UTF-8 "$LANG" || true && \
|
/usr/glibc-compat/bin/localedef --force --inputfile POSIX --charmap UTF-8 "$LANG" || true && \
|
||||||
echo "export LANG=$LANG" > /etc/profile.d/locale.sh && \
|
mkdir -p /opt /factorio && \
|
||||||
|
curl -sSL "${FactorioDownloadURL}" -o ${FactorioFileName} && \
|
||||||
|
tar -x -f ${FactorioFileName} --directory /opt && \
|
||||||
apk del glibc-i18n && \
|
apk del glibc-i18n && \
|
||||||
rm -v "/root/.wget-hsts" && \
|
|
||||||
apk del .build-dependencies && \
|
apk del .build-dependencies && \
|
||||||
rm -v \
|
rm -v \
|
||||||
"$ALPINE_GLIBC_BASE_PACKAGE_FILENAME" \
|
"${AlpineGlibcBasePackageFilename}" \
|
||||||
"$ALPINE_GLIBC_BIN_PACKAGE_FILENAME" \
|
"${AlpineGlibcBinPackageFilename}" \
|
||||||
"$ALPINE_GLIBC_I18N_PACKAGE_FILENAME"
|
"${AlpineGlibcI18nPackageFilename}" \
|
||||||
|
${FactorioFileName} && \
|
||||||
|
rm -v "/root/.wget-hsts" || true && \
|
||||||
|
addgroup -g 1000 -S factorio && \
|
||||||
|
adduser -u 1000 -G factorio -s /bin/sh -SDH factorio && \
|
||||||
|
chown -R factorio:factorio /opt/factorio /factorio
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
podTemplate(
|
||||||
|
containers: [
|
||||||
|
containerTemplate(
|
||||||
|
name: "docker",
|
||||||
|
image: "docker:19.03",
|
||||||
|
command: "sleep",
|
||||||
|
args: "99d",
|
||||||
|
envVars: [
|
||||||
|
envVar(
|
||||||
|
key: "DOCKER_HOST",
|
||||||
|
value: "tcp://localhost:2375"
|
||||||
|
)
|
||||||
|
]
|
||||||
|
),
|
||||||
|
containerTemplate(
|
||||||
|
name: "docker-daemon",
|
||||||
|
image: "docker:19.03-dind",
|
||||||
|
command: "dockerd-entrypoint.sh",
|
||||||
|
args: "--insecure-registry registry.test-chamber-13.lan:5000",
|
||||||
|
privileged: true,
|
||||||
|
envVars: [
|
||||||
|
envVar(
|
||||||
|
key: "DOCKER_TLS_CERTDIR",
|
||||||
|
value: ""
|
||||||
|
)
|
||||||
|
],
|
||||||
|
)
|
||||||
|
]
|
||||||
|
) {
|
||||||
|
node(POD_LABEL) {
|
||||||
|
container("docker") {
|
||||||
|
stage("Test DinD Daemon") {
|
||||||
|
sh """
|
||||||
|
docker version
|
||||||
|
"""
|
||||||
|
}
|
||||||
|
stage("Write Dockerfile"){
|
||||||
|
writeFile(file: "Dockerfile", text: dockerFile)
|
||||||
|
}
|
||||||
|
stage("Build Container"){
|
||||||
|
sh """
|
||||||
|
docker build --tag ${ImageRepository}/${ImageName}:${ImageTag} ./
|
||||||
|
"""
|
||||||
|
}
|
||||||
|
stage("Push Container"){
|
||||||
|
sh """
|
||||||
|
docker push ${ImageRepository}/${ImageName}:${ImageTag}
|
||||||
|
"""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user