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):
|
repo = "spritsail/alpine"
|
||||||
return [
|
archs = ["amd64", "arm64"]
|
||||||
step("3.8"),
|
branches = ["master"]
|
||||||
step("3.9"),
|
versions = {
|
||||||
step("3.10"),
|
"3.21": [],
|
||||||
step("3.11",["latest"]),
|
"3.22": ["latest"],
|
||||||
step("edge"),
|
"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 {
|
return {
|
||||||
"kind": "pipeline",
|
"kind": "pipeline",
|
||||||
"name": "build-%s" % alpinever,
|
"name": key,
|
||||||
|
"platform": {
|
||||||
|
"os": "linux",
|
||||||
|
"arch": arch,
|
||||||
|
},
|
||||||
|
"environment": {
|
||||||
|
"DOCKER_IMAGE_TOKEN": ver,
|
||||||
|
},
|
||||||
"steps": [
|
"steps": [
|
||||||
{
|
{
|
||||||
"name": "build",
|
"name": "build",
|
||||||
"image": "spritsail/docker-build",
|
"image": "spritsail/docker-build",
|
||||||
"pull": "always",
|
"pull": "always",
|
||||||
"settings": {
|
"settings": {
|
||||||
"repo": "alpine-dev-%s" % alpinever,
|
|
||||||
"build_args": [
|
"build_args": [
|
||||||
"ALPINE_TAG=%s" % alpinever,
|
"ALPINE_TAG=%s" % ver,
|
||||||
],
|
],
|
||||||
|
},
|
||||||
},
|
},
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "test",
|
"name": "test",
|
||||||
"image": "spritsail/docker-test",
|
"image": "spritsail/docker-test",
|
||||||
"pull": "always",
|
"pull": "always",
|
||||||
"settings": {
|
"settings": {
|
||||||
"repo": "spritsail/alpine",
|
"run": vertest + "su-exec nobody apk --version",
|
||||||
"run": "su-exec nobody apk --version",
|
"verbose": "true",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -37,23 +59,54 @@ def step(alpinever,tags=[]):
|
|||||||
"image": "spritsail/docker-publish",
|
"image": "spritsail/docker-publish",
|
||||||
"pull": "always",
|
"pull": "always",
|
||||||
"settings": {
|
"settings": {
|
||||||
"from": "alpine-dev-%s" % alpinever,
|
"registry": {"from_secret": "registry_url"},
|
||||||
"repo": "spritsail/alpine",
|
"login": {"from_secret": "registry_login"},
|
||||||
"tags": [alpinever] + tags,
|
|
||||||
},
|
|
||||||
"environment": {
|
|
||||||
"DOCKER_USERNAME": {
|
|
||||||
"from_secret": "docker_username",
|
|
||||||
},
|
|
||||||
"DOCKER_PASSWORD": {
|
|
||||||
"from_secret": "docker_password",
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
"when": {
|
"when": {
|
||||||
"branch": ["master"],
|
"branch": branches,
|
||||||
"event": ["push"],
|
"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
|
FROM alpine:$ALPINE_TAG
|
||||||
|
|
||||||
ARG ALPINE_TAG
|
ARG ALPINE_TAG
|
||||||
|
|
||||||
LABEL maintainer="Spritsail <alpine@spritsail.io>" \
|
LABEL org.opencontainers.image.authors="Spritsail <alpine@spritsail.io>" \
|
||||||
org.label-schema.vendor="Spritsail" \
|
org.opencontainers.image.title="Alpine Linux" \
|
||||||
org.label-schema.name="Alpine Linux" \
|
org.opencontainers.image.url="https://github.com/gliderlabs/docker-alpine" \
|
||||||
org.label-schema.url="https://github.com/gliderlabs/docker-alpine" \
|
org.opencontainers.image.source="https://github.com/spritsail/alpine" \
|
||||||
org.label-schema.description="Alpine Linux base image" \
|
org.opencontainers.image.description="Alpine Linux base image" \
|
||||||
org.label-schema.version=${ALPINE_TAG}
|
org.opencontainers.image.version=${ALPINE_TAG}
|
||||||
|
|
||||||
# Override shell for sh-y debugging goodness
|
# Override shell for sh-y debugging goodness
|
||||||
SHELL ["/bin/sh", "-exc"]
|
SHELL ["/bin/sh", "-exc"]
|
||||||
@ -18,7 +18,7 @@ COPY skel/ /
|
|||||||
ADD https://alpine.spritsail.io/spritsail-alpine.rsa.pub /etc/apk/keys
|
ADD https://alpine.spritsail.io/spritsail-alpine.rsa.pub /etc/apk/keys
|
||||||
|
|
||||||
ENV ENV="/etc/profile"
|
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 \
|
&& apk --no-cache add \
|
||||||
su-exec \
|
su-exec \
|
||||||
tini
|
tini
|
||||||
|
Reference in New Issue
Block a user