local executableName = 'newsletter-to-web'; local cross_image = 'img.kie.rs/jjkiers/rust-dind-cross:1.66-full'; local archs = [ { target: 'aarch64-unknown-linux-musl', short: 'arm64-musl' }, { target: 'x86_64-pc-windows-gnu', short: 'windows' }, { target: 'x86_64-unknown-linux-musl', short: 'amd64-musl' }, ]; local getStepName(arch) = 'Build for ' + arch.short; local builtExecutableName(arch) = executableName + if std.length(std.findSubstr(arch.short, 'windows')) > 0 then '.exe' else ''; local targetExecutableName(arch) = executableName + '-' + arch.target + if std.length(std.findSubstr(arch.short, 'windows')) > 0 then '.exe' else ''; local add_build_steps() = [ { name: getStepName(arch), image: cross_image, volumes: [ { name: 'dockersock', path: '/var/run', }, ], commands: [ 'echo Hello World from Jsonnet on ' + arch.target + '!', 'cross build --release --target ' + arch.target, 'cp target/' + arch.target + '/release/' + builtExecutableName(arch) + ' artifacts/' + targetExecutableName(arch), 'rm -rf target/' + arch.target + '/release/*', ], environment: { CROSS_REMOTE: true, }, depends_on: ['Wait for Docker'], } for arch in archs ]; { kind: 'pipeline', type: 'docker', name: 'default', platform: { arch: 'amd64', }, steps: [{ name: 'Wait for Docker', image: cross_image, commands: [ 'mkdir artifacts', 'echo Using image: ' + cross_image, 'while ! docker image ls; do sleep 1; done', 'cargo --version', 'rustc --version', 'docker info', 'docker pull hello-world:latest', ], environment: { CROSS_REMOTE: true, }, volumes: [{ name: 'dockersock', path: '/var/run', }], }] + add_build_steps() + [ { name: 'Show built artifacts', image: cross_image, commands: [ 'ls -lah artifacts', ], depends_on: [getStepName(a) for a in archs], }, { name: 'Create release on gitea', image: 'plugins/gitea-release', settings: { api_key: { from_secret: 'gitea_token', }, base_url: 'https://code.kiers.eu', files: 'artifacts/*', checksum: 'sha256', }, when: { event: ['tag', 'promote'], }, depends_on: ['Show built artifacts'], }, ], services: [{ name: 'docker', image: 'docker:dind', privileged: true, volumes: [ { name: 'dockersock', path: '/var/run', }, { name: 'docker-storage', path: '/var/lib/docker', }, ], }], volumes: [ { name: 'dockersock', temp: {}, }, ], image_pull_secrets: ['docker_private_repo'], }