2
0
mirror of https://github.com/spritsail/alpine.git synced 2025-06-14 15:11:12 +00:00

3 Commits

Author SHA1 Message Date
37c7781c2d Push to 3.8 tag, not latest 2018-07-03 20:49:52 +01:00
1ddb92853c Temporary 3.8 fix.
Waiting on https://github.com/docker-library/official-images/pull/4501
2018-07-03 20:49:51 +01:00
7853193403 Update to alpine:3.8 2018-07-03 20:49:51 +01:00
4 changed files with 50 additions and 117 deletions

View File

@ -1,106 +0,0 @@
repo = "spritsail/alpine"
archs = ["amd64", "arm64"]
versions = ["edge", "3.14", "3.15", "3.16"]
branches = ["master"]
def main(ctx):
builds = []
for ver in versions:
depends_on = []
srctpl = "drone/%s/${DRONE_BUILD_NUMBER}:%s-ARCH" % (ctx.repo.slug, ver)
for arch in archs:
key = "build-%s-%s" % (ver, arch)
tmprepo = "drone/%s/${DRONE_BUILD_NUMBER}:%s-%s" % (ctx.repo.slug, ver, arch)
builds.append(step(ver, arch, key, tmprepo))
depends_on.append(key)
if ctx.build.branch in branches:
tags = []
if ver == versions[-1]:
tags.append("latest")
builds.append(publish(ver, srctpl, depends_on, tags))
return builds
def step(ver, arch, key, tmprepo):
vertest = "grep -q '%s' /etc/alpine-release && " % ver if ver != "edge" else ""
return {
"kind": "pipeline",
"name": key,
"platform": {
"os": "linux",
"arch": arch,
},
"steps": [
{
"name": "build",
"image": "spritsail/docker-build",
"pull": "always",
"settings": {
"build_args": [
"ALPINE_TAG=%s" % ver,
],
"repo": tmprepo,
},
},
{
"name": "test",
"image": "spritsail/docker-test",
"pull": "always",
"settings": {
"run": vertest + "su-exec nobody apk --version",
"repo": tmprepo,
},
},
{
"name": "publish",
"image": "spritsail/docker-publish",
"pull": "always",
"settings": {
"from": tmprepo,
"repo": tmprepo,
"registry": {"from_secret": "registry_url"},
"username": {"from_secret": "registry_username"},
"password": {"from_secret": "registry_password"},
},
"when": {
"branch": branches,
"event": ["push"],
},
},
]
}
def publish(ver, srctpl, depends, tags=[]):
return {
"kind": "pipeline",
"name": "publish-%s" % ver,
"depends_on": depends,
"platform": {
"os": "linux",
},
"steps": [
{
"name": "publish",
"image": "spritsail/docker-multiarch-publish",
"pull": "always",
"settings": {
"src_template": srctpl,
"src_registry": {"from_secret": "registry_url"},
"src_username": {"from_secret": "registry_username"},
"src_password": {"from_secret": "registry_password"},
"dest_repo": repo,
"dest_username": {"from_secret": "docker_username"},
"dest_password": {"from_secret": "docker_password"},
"tags": [ver] + tags,
},
"when": {
"branch": branches,
"event": ["push"],
},
},
]
}
# vim: ft=python sw=2

26
.drone.yml Normal file
View File

@ -0,0 +1,26 @@
pipeline:
build:
image: spritsail/docker-build
volumes: [ '/var/run/docker.sock:/var/run/docker.sock' ]
repo: alpine-dev
build_args:
- ALPINE_TAG=3.8
test:
image: docker
volumes: [ '/var/run/docker.sock:/var/run/docker.sock' ]
commands:
- docker run --rm alpine-dev /bin/sh -xec 'apk --version'
publish:
image: spritsail/docker-publish
when: { branch: [ 3.8 ], event: [ push, tag, deployment ] }
volumes: [ '/var/run/docker.sock:/var/run/docker.sock' ]
secrets: [ docker_username, docker_password, microbadger_token ]
from: alpine-dev
repo: 'spritsail/alpine:3.8'
notify:
image: spritsail/notify
when: { status: [ success, failure ] }
secrets: [ webhook_url, notify_token ]

View File

@ -1,7 +1,19 @@
ARG ALPINE_TAG=3.16
ARG SU_EXEC_VER=v0.3
ARG ALPINE_TAG=3.8
FROM alpine:$ALPINE_TAG
FROM alpine:3.7 AS upgrade
ARG ALPINE_TAG
RUN sed -i "s/3\.7/${ALPINE_TAG}/g" /etc/apk/repositories \
&& apk --no-cache upgrade
# ~~~~~~~~~~~~~~~~~~~~~~
FROM scratch
COPY --from=upgrade / /
ARG SU_EXEC_VER
ARG ALPINE_TAG
LABEL maintainer="Spritsail <alpine@spritsail.io>" \
@ -9,18 +21,19 @@ LABEL maintainer="Spritsail <alpine@spritsail.io>" \
org.label-schema.name="Alpine Linux" \
org.label-schema.url="https://github.com/gliderlabs/docker-alpine" \
org.label-schema.description="Alpine Linux base image" \
org.label-schema.version=${ALPINE_TAG}
org.label-schema.version=${ALPINE_TAG} \
io.spritsail.version.su-exec=${SU_EXEC_VER}
# Override shell for sh-y debugging goodness
SHELL ["/bin/sh", "-exc"]
COPY skel/ /
ADD https://alpine.spritsail.io/spritsail-alpine.rsa.pub /etc/apk/keys
ENV ENV="/etc/profile"
RUN sed -i '1ihttps://alpine.spritsail.io/spritsail' /etc/apk/repositories \
&& apk --no-cache add \
su-exec \
tini
RUN apk --no-cache add \
tini \
openssl \
&& wget -qO /sbin/su-exec https://github.com/frebib/su-exec/releases/download/${SU_EXEC_VER}/su-exec-alpine-$(uname -m) \
&& chmod +x /sbin/su-exec \
&& apk --no-cache del openssl
ENTRYPOINT ["/sbin/tini" , "--"]

View File

@ -1,6 +1,6 @@
export PAGER='/usr/bin/less'
export PAGER='/usr/bin/less -R'
export EDITOR='/usr/bin/vi'
export PS1='\e[1;36m\u@\h\e[0m \e[0;32m$(pwd | sed -E '"'s@^'\$HOME'@~@;s@(.*)/@\\1%#@;s@((^|/)\\.?[^/%]{1})[^/%]*@\\1@g;s@(.*)%#@\\1/@')"'\e[0m> '
export PS1='\e[1;36m\u@\h\e[0m \e[0;32m$(pwd | sed -E '"'s|^'\$HOME'|~|;s|(.*)/|\\1%#|;s|((^\\|/)\\.?[^/%]{1})[^/%]*|\\1|g;s|(.*)%#|\\1/|')"'\e[0m> '
# Source configuration files from /etc/profile.d
for i in /etc/profile.d/*.sh ; do