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):
|
repo = "spritsail/alpine"
|
||||||
return [
|
archs = ["amd64", "arm64"]
|
||||||
step("3.8"),
|
versions = ["edge", "3.14", "3.15", "3.16"]
|
||||||
step("3.9"),
|
branches = ["master"]
|
||||||
step("3.10"),
|
|
||||||
step("3.11",["latest"]),
|
|
||||||
step("edge"),
|
|
||||||
]
|
|
||||||
|
|
||||||
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 {
|
return {
|
||||||
"kind": "pipeline",
|
"kind": "pipeline",
|
||||||
"name": "build-%s" % alpinever,
|
"name": key,
|
||||||
|
"platform": {
|
||||||
|
"os": "linux",
|
||||||
|
"arch": arch,
|
||||||
|
},
|
||||||
"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,
|
||||||
],
|
],
|
||||||
|
"repo": tmprepo,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -28,8 +49,8 @@ def step(alpinever,tags=[]):
|
|||||||
"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",
|
"repo": tmprepo,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -37,23 +58,49 @@ def step(alpinever,tags=[]):
|
|||||||
"image": "spritsail/docker-publish",
|
"image": "spritsail/docker-publish",
|
||||||
"pull": "always",
|
"pull": "always",
|
||||||
"settings": {
|
"settings": {
|
||||||
"from": "alpine-dev-%s" % alpinever,
|
"from": tmprepo,
|
||||||
"repo": "spritsail/alpine",
|
"repo": tmprepo,
|
||||||
"tags": [alpinever] + tags,
|
"registry": {"from_secret": "registry_url"},
|
||||||
},
|
"username": {"from_secret": "registry_username"},
|
||||||
"environment": {
|
"password": {"from_secret": "registry_password"},
|
||||||
"DOCKER_USERNAME": {
|
|
||||||
"from_secret": "docker_username",
|
|
||||||
},
|
|
||||||
"DOCKER_PASSWORD": {
|
|
||||||
"from_secret": "docker_password",
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
"when": {
|
"when": {
|
||||||
"branch": ["master"],
|
"branch": branches,
|
||||||
"event": ["push"],
|
"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
|
FROM alpine:$ALPINE_TAG
|
||||||
|
|
||||||
@ -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