add starlark script [ci skip]
This commit is contained in:
parent
14ed083e1c
commit
3aa6fca781
130
.drone.starlark
Normal file
130
.drone.starlark
Normal file
@ -0,0 +1,130 @@
|
||||
# this starlark script should be used to generate the .drone.yml
|
||||
# configuration file.
|
||||
|
||||
def main(ctx):
|
||||
# TODO consider running unit tests before building and
|
||||
# publishing docker images.
|
||||
before = {}
|
||||
|
||||
stages = [
|
||||
linux('arm'),
|
||||
linux('arm64'),
|
||||
linux('amd64'),
|
||||
windows('1903'),
|
||||
windows('1809'),
|
||||
]
|
||||
|
||||
after = manifest()
|
||||
|
||||
# the after stage should only execute after all previous
|
||||
# stages complete. this builds the dependency graph.
|
||||
for stage in stages:
|
||||
after['depends_on'].append(stage['name'])
|
||||
|
||||
return stages + [ after ]
|
||||
|
||||
# create a pipeline stage responsible for building and
|
||||
# publishing the Docker image on linux.
|
||||
def linux(arch):
|
||||
return {
|
||||
'kind': 'pipeline',
|
||||
'type': 'docker',
|
||||
'name': 'linux-%s' % arch,
|
||||
'platform': {
|
||||
'os': 'linux',
|
||||
'arch': arch,
|
||||
},
|
||||
'steps': [
|
||||
{
|
||||
'name': 'build',
|
||||
'image': 'golang:1.10',
|
||||
'commands': [
|
||||
'cd posix',
|
||||
'tar -xf fixtures.tar -C /',
|
||||
'go test -v',
|
||||
],
|
||||
},
|
||||
{
|
||||
'name': 'publish',
|
||||
'image': 'plugins/docker',
|
||||
'settings': {
|
||||
'auto_tag': 'true',
|
||||
'auto_tag_suffix': 'linux-%s' % arch,
|
||||
'dockerfile': 'docker/Dockerfile.linux.%s' % arch,
|
||||
'password': {
|
||||
'from_secret': 'docker_password',
|
||||
},
|
||||
'repo': 'drone/git',
|
||||
'username': 'drone',
|
||||
},
|
||||
'when': {
|
||||
'event': ['push', 'tag']
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
# create a pipeline stage responsible for building and
|
||||
# publishing the Docker image on windows. The windows stage
|
||||
# uses an ssh runner, as opposed to a docker runner.
|
||||
def windows(version):
|
||||
return {
|
||||
'kind': 'pipeline',
|
||||
'type': 'ssh',
|
||||
'name': 'windows-%s-amd64' % version,
|
||||
'platform': {
|
||||
'os': 'windows'
|
||||
},
|
||||
'server': {
|
||||
'host': { 'from_secret': 'windows_server_%s' % version },
|
||||
'user': { 'from_secret': 'windows_username' },
|
||||
'password': { 'from_secret': 'windows_password' },
|
||||
},
|
||||
'steps': [
|
||||
{
|
||||
'name': 'build',
|
||||
'environment': {
|
||||
'USERNAME': { 'from_secret': 'docker_username' },
|
||||
'PASSWORD': { 'from_secret': 'docker_password' },
|
||||
},
|
||||
# TODO these commands build and publish the latest
|
||||
# docker tag regardless of git tag.
|
||||
'commands': [
|
||||
'docker login -u $env:USERNAME -p $env:PASSWORD',
|
||||
'docker build -f docker/Dockerfile.windows.%s -t drone/git:windows-%s-amd64 .' % (version, version),
|
||||
'docker push drone/git:windows-%s-amd64' % version,
|
||||
],
|
||||
},
|
||||
],
|
||||
'trigger': {
|
||||
'event': ['push']
|
||||
}
|
||||
}
|
||||
|
||||
# create a pipeline stage responsible for creating and
|
||||
# publishing a docker manifest to the registry.
|
||||
def manifest():
|
||||
return {
|
||||
'kind': 'pipeline',
|
||||
'type': 'docker',
|
||||
'name': 'manifest',
|
||||
'steps': [
|
||||
{
|
||||
'name': 'manifest',
|
||||
'image': 'plugins/manifest',
|
||||
'settings': {
|
||||
'auto_tag': 'true',
|
||||
'username': 'drone',
|
||||
'password': {
|
||||
'from_secret': 'docker_password'
|
||||
},
|
||||
'spec': 'docker/manifest.tmpl',
|
||||
'ignore_missing': 'true',
|
||||
},
|
||||
},
|
||||
],
|
||||
'depends_on': [],
|
||||
'trigger': {
|
||||
'event': ['push', 'tag']
|
||||
}
|
||||
}
|
@ -1,74 +0,0 @@
|
||||
local windows_pipe = '\\\\\\\\.\\\\pipe\\\\docker_engine';
|
||||
local windows_pipe_volume = 'docker_pipe';
|
||||
local versions = [
|
||||
//'1803',
|
||||
'1809',
|
||||
];
|
||||
local trigger = {
|
||||
ref: [
|
||||
'refs/heads/master',
|
||||
'refs/tags/**',
|
||||
],
|
||||
};
|
||||
local pipeline_name(version) = 'Windows ' + version;
|
||||
|
||||
local pipeline(version, arch) = {
|
||||
kind: 'pipeline',
|
||||
name: pipeline_name(version),
|
||||
|
||||
platform: {
|
||||
os: 'windows',
|
||||
arch: arch,
|
||||
version: version,
|
||||
},
|
||||
|
||||
steps: [{
|
||||
name: 'git',
|
||||
image: 'plugins/docker:windows-1809', // TODO: This should just use the manifest
|
||||
settings: {
|
||||
repo: 'drone/git',
|
||||
dockerfile: 'docker/Dockerfile.windows.' + version,
|
||||
auto_tag: true,
|
||||
auto_tag_suffix: 'windows-' + version + '-' + arch,
|
||||
|
||||
username: { from_secret: 'docker_username' },
|
||||
password: { from_secret: 'docker_password' },
|
||||
|
||||
// Windows specific options
|
||||
daemon_off: true,
|
||||
purge: 'false', // TODO: Fix bug where setting false won't generate the yaml value
|
||||
},
|
||||
volumes: [{ name: windows_pipe_volume, path: windows_pipe }],
|
||||
}],
|
||||
|
||||
volumes: [{ name: windows_pipe_volume, host: { path: windows_pipe } }],
|
||||
trigger: trigger,
|
||||
};
|
||||
|
||||
[
|
||||
pipeline(version, 'amd64')
|
||||
for version in versions
|
||||
] + [
|
||||
{
|
||||
kind: 'pipeline',
|
||||
name: 'Image Manifest',
|
||||
|
||||
steps: [{
|
||||
name: 'manifest',
|
||||
image: 'plugins/manifest',
|
||||
settings: {
|
||||
spec: 'docker/manifest.tmpl',
|
||||
ignore_missing: true,
|
||||
|
||||
username: { from_secret: 'docker_username' },
|
||||
password: { from_secret: 'docker_password' },
|
||||
},
|
||||
}],
|
||||
|
||||
depends_on: [
|
||||
pipeline_name(version)
|
||||
for version in versions
|
||||
],
|
||||
trigger: trigger,
|
||||
},
|
||||
]
|
@ -1,65 +0,0 @@
|
||||
---
|
||||
kind: pipeline
|
||||
name: Windows 1809
|
||||
|
||||
platform:
|
||||
os: windows
|
||||
arch: amd64
|
||||
version: 1809
|
||||
|
||||
steps:
|
||||
- name: git
|
||||
image: plugins/docker:windows-1809
|
||||
settings:
|
||||
auto_tag: true
|
||||
auto_tag_suffix: windows-1809-amd64
|
||||
daemon_off: true
|
||||
dockerfile: docker/Dockerfile.windows.1809
|
||||
password:
|
||||
from_secret: docker_password
|
||||
purge: false
|
||||
repo: drone/git
|
||||
username:
|
||||
from_secret: docker_username
|
||||
volumes:
|
||||
- name: docker_pipe
|
||||
path: \\\\.\\pipe\\docker_engine
|
||||
|
||||
volumes:
|
||||
- name: docker_pipe
|
||||
host:
|
||||
path: \\\\.\\pipe\\docker_engine
|
||||
|
||||
trigger:
|
||||
ref:
|
||||
- refs/heads/master
|
||||
- "refs/tags/**"
|
||||
|
||||
---
|
||||
kind: pipeline
|
||||
name: Image Manifest
|
||||
|
||||
platform:
|
||||
os: linux
|
||||
arch: amd64
|
||||
|
||||
steps:
|
||||
- name: manifest
|
||||
image: plugins/manifest
|
||||
settings:
|
||||
ignore_missing: true
|
||||
password:
|
||||
from_secret: docker_password
|
||||
spec: docker/manifest.tmpl
|
||||
username:
|
||||
from_secret: docker_username
|
||||
|
||||
trigger:
|
||||
ref:
|
||||
- refs/heads/master
|
||||
- "refs/tags/**"
|
||||
|
||||
depends_on:
|
||||
- Windows 1809
|
||||
|
||||
...
|
2
.gitignore
vendored
2
.gitignore
vendored
@ -1,2 +0,0 @@
|
||||
.drone.jsonnet
|
||||
.drone.jsonnet.yml
|
Loading…
Reference in New Issue
Block a user