forked from spritsail/alpine
Compare commits
16 Commits
Author | SHA1 | Date | |
---|---|---|---|
58a253d336
|
|||
f987f60fff
|
|||
ea70eddebd
|
|||
b1b46fb469
|
|||
ed8af085db
|
|||
4b67afe49d
|
|||
735a1de6ca
|
|||
f8c0652bbc
|
|||
bc6f6539b2
|
|||
e50739bb32 | |||
fa09f2867c
|
|||
438819be65
|
|||
f848ecae6f
|
|||
d7d15ca14d
|
|||
a216ae99b9
|
|||
7d52c725e4
|
111
.drone.star
111
.drone.star
@ -1,35 +1,57 @@
|
||||
def main(ctx):
|
||||
return [
|
||||
step("3.8"),
|
||||
step("3.9"),
|
||||
step("3.10"),
|
||||
step("3.11",["latest"]),
|
||||
step("edge"),
|
||||
]
|
||||
repo = "spritsail/alpine"
|
||||
archs = ["amd64", "arm64"]
|
||||
branches = ["master"]
|
||||
versions = {
|
||||
"3.21": [],
|
||||
"3.22": ["latest"],
|
||||
"edge": [],
|
||||
}
|
||||
|
||||
def step(alpinever,tags=[]):
|
||||
def main(ctx):
|
||||
builds = []
|
||||
|
||||
for ver, tags in versions.items():
|
||||
depends_on = []
|
||||
for arch in archs:
|
||||
key = "build-%s-%s" % (ver, arch)
|
||||
builds.append(step(ver, arch, key))
|
||||
depends_on.append(key)
|
||||
|
||||
if ctx.build.branch in branches:
|
||||
builds.extend(publish(ver, depends_on, tags))
|
||||
|
||||
return builds
|
||||
|
||||
def step(ver, arch, key):
|
||||
vertest = "grep -q '%s' /etc/alpine-release && " % ver if ver != "edge" else ""
|
||||
return {
|
||||
"kind": "pipeline",
|
||||
"name": "build-%s" % alpinever,
|
||||
"name": key,
|
||||
"platform": {
|
||||
"os": "linux",
|
||||
"arch": arch,
|
||||
},
|
||||
"environment": {
|
||||
"DOCKER_IMAGE_TOKEN": ver,
|
||||
},
|
||||
"steps": [
|
||||
{
|
||||
"name": "build",
|
||||
"image": "spritsail/docker-build",
|
||||
"pull": "always",
|
||||
"settings": {
|
||||
"repo": "alpine-dev-%s" % alpinever,
|
||||
"build_args": [
|
||||
"ALPINE_TAG=%s" % alpinever,
|
||||
],
|
||||
"ALPINE_TAG=%s" % ver,
|
||||
],
|
||||
},
|
||||
},
|
||||
},
|
||||
{
|
||||
"name": "test",
|
||||
"image": "spritsail/docker-test",
|
||||
"pull": "always",
|
||||
"settings": {
|
||||
"repo": "spritsail/alpine",
|
||||
"run": "su-exec nobody apk --version",
|
||||
"run": vertest + "su-exec nobody apk --version",
|
||||
"verbose": "true",
|
||||
},
|
||||
},
|
||||
{
|
||||
@ -37,23 +59,54 @@ def step(alpinever,tags=[]):
|
||||
"image": "spritsail/docker-publish",
|
||||
"pull": "always",
|
||||
"settings": {
|
||||
"from": "alpine-dev-%s" % alpinever,
|
||||
"repo": "spritsail/alpine",
|
||||
"tags": [alpinever] + tags,
|
||||
},
|
||||
"environment": {
|
||||
"DOCKER_USERNAME": {
|
||||
"from_secret": "docker_username",
|
||||
},
|
||||
"DOCKER_PASSWORD": {
|
||||
"from_secret": "docker_password",
|
||||
},
|
||||
"registry": {"from_secret": "registry_url"},
|
||||
"login": {"from_secret": "registry_login"},
|
||||
},
|
||||
"when": {
|
||||
"branch": ["master"],
|
||||
"event": ["push"],
|
||||
"branch": branches,
|
||||
"event": ["push", "cron"],
|
||||
},
|
||||
},
|
||||
]
|
||||
}
|
||||
|
||||
def publish(ver, depends, tags=[]):
|
||||
return [
|
||||
{
|
||||
"kind": "pipeline",
|
||||
"name": "publish-%s-%s" % (ver, name),
|
||||
"depends_on": depends,
|
||||
"platform": {
|
||||
"os": "linux",
|
||||
},
|
||||
"environment": {
|
||||
"DOCKER_IMAGE_TOKEN": ver,
|
||||
},
|
||||
"steps": [
|
||||
{
|
||||
"name": "publish",
|
||||
"image": "spritsail/docker-multiarch-publish",
|
||||
"pull": "always",
|
||||
"settings": {
|
||||
"src_registry": {"from_secret": "registry_url"},
|
||||
"src_login": {"from_secret": "registry_login"},
|
||||
"dest_registry": registry,
|
||||
"dest_repo": repo,
|
||||
"dest_login": {"from_secret": login_secret},
|
||||
"tags": [ver] + tags,
|
||||
},
|
||||
"when": {
|
||||
"branch": branches,
|
||||
"event": ["push", "cron"],
|
||||
},
|
||||
},
|
||||
],
|
||||
}
|
||||
for name, registry, login_secret in [
|
||||
("dockerhub", "index.docker.io", "docker_login"),
|
||||
("spritsail", "registry.spritsail.io", "spritsail_login"),
|
||||
("ghcr", "ghcr.io", "ghcr_login"),
|
||||
]
|
||||
]
|
||||
|
||||
# vim: ft=python sw=2
|
||||
|
16
Dockerfile
16
Dockerfile
@ -1,15 +1,15 @@
|
||||
ARG ALPINE_TAG=3.11
|
||||
ARG ALPINE_TAG=3.22
|
||||
|
||||
FROM alpine:$ALPINE_TAG
|
||||
|
||||
ARG ALPINE_TAG
|
||||
|
||||
LABEL maintainer="Spritsail <alpine@spritsail.io>" \
|
||||
org.label-schema.vendor="Spritsail" \
|
||||
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}
|
||||
LABEL org.opencontainers.image.authors="Spritsail <alpine@spritsail.io>" \
|
||||
org.opencontainers.image.title="Alpine Linux" \
|
||||
org.opencontainers.image.url="https://github.com/gliderlabs/docker-alpine" \
|
||||
org.opencontainers.image.source="https://github.com/spritsail/alpine" \
|
||||
org.opencontainers.image.description="Alpine Linux base image" \
|
||||
org.opencontainers.image.version=${ALPINE_TAG}
|
||||
|
||||
# Override shell for sh-y debugging goodness
|
||||
SHELL ["/bin/sh", "-exc"]
|
||||
@ -18,7 +18,7 @@ COPY skel/ /
|
||||
ADD https://alpine.spritsail.io/spritsail-alpine.rsa.pub /etc/apk/keys
|
||||
|
||||
ENV ENV="/etc/profile"
|
||||
RUN sed -i '1ihttp://alpine.spritsail.io/spritsail' /etc/apk/repositories \
|
||||
RUN sed -i '1ihttps://alpine.spritsail.io/spritsail' /etc/apk/repositories \
|
||||
&& apk --no-cache add \
|
||||
su-exec \
|
||||
tini
|
||||
|
Reference in New Issue
Block a user