forked from spritsail/alpine
Compare commits
7 Commits
Author | SHA1 | Date | |
---|---|---|---|
80cdda202e
|
|||
fa09f2867c
|
|||
438819be65
|
|||
f848ecae6f
|
|||
d7d15ca14d
|
|||
a216ae99b9
|
|||
7d52c725e4
|
99
.drone.star
99
.drone.star
@ -1,26 +1,47 @@
|
||||
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"]
|
||||
versions = ["edge", "3.14", "3.15", "3.16"]
|
||||
branches = ["master"]
|
||||
|
||||
def step(alpinever,tags=[]):
|
||||
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": "build-%s" % alpinever,
|
||||
"name": key,
|
||||
"platform": {
|
||||
"os": "linux",
|
||||
"arch": arch,
|
||||
},
|
||||
"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,
|
||||
],
|
||||
"repo": tmprepo,
|
||||
},
|
||||
},
|
||||
{
|
||||
@ -28,8 +49,8 @@ def step(alpinever,tags=[]):
|
||||
"image": "spritsail/docker-test",
|
||||
"pull": "always",
|
||||
"settings": {
|
||||
"repo": "spritsail/alpine",
|
||||
"run": "su-exec nobody apk --version",
|
||||
"run": vertest + "su-exec nobody apk --version",
|
||||
"repo": tmprepo,
|
||||
},
|
||||
},
|
||||
{
|
||||
@ -37,23 +58,49 @@ 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",
|
||||
},
|
||||
"from": tmprepo,
|
||||
"repo": tmprepo,
|
||||
"registry": {"from_secret": "registry_url"},
|
||||
"username": {"from_secret": "registry_username"},
|
||||
"password": {"from_secret": "registry_password"},
|
||||
},
|
||||
"when": {
|
||||
"branch": ["master"],
|
||||
"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
|
||||
|
@ -1,4 +1,4 @@
|
||||
ARG ALPINE_TAG=3.11
|
||||
ARG ALPINE_TAG=3.16
|
||||
|
||||
FROM alpine:$ALPINE_TAG
|
||||
|
||||
@ -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