autojen/configure_jenkins.groovy
2020-06-18 18:44:00 +04:00

297 lines
6.1 KiB
Groovy

import java.net.URI
import java.nio.file.Paths
def confrepo = 'http://gogs.smb.basealt.ru/BaseALT/autojen.git'
def infraConfRepo = 'http://gogs.smb.basealt.ru/BaseALT/infra-conf.git'
def infraRepo = 'https://github.com/altlinuxteam/infra.git'
def stackSamba = [
'jenkins-samba-1x3',
'jenkins-samba-3x3',
'jenkins-samba-8sp-1x3-pub',
'jenkins-samba-8sp-3x3-pub',
'jenkins-samba-9-3x3-pub',
'jenkins-samba-sisyphus-1x3',
'jenkins-samba-sisyphus-1x3-pub',
'jenkins-samba-sisyphus-3x3-pub',
'jenkins-samba-sisyphus-3x3',
'samba-9-3x3-pub-kevl'
]
def stackKerberos = [
'jenkins-krb5-sisyphus-1x1'
]
folder('samba') {
displayName('Samba Team')
description('Jobs for Samba AD DC testing and deployment')
views {
listView('Samba stacks') {
description('Samba AD DC tests')
filterBuildQueue()
filterExecutors()
columns {
status()
name()
buildButton()
}
jobs {
stackSamba.each { stack ->
name(stack)
}
}
}
listView('Kerberos stacks') {
description('Kerberos stacks')
filterBuildQueue()
filterExecutors()
columns {
status()
name()
buildButton()
}
jobs {
stackKerberos.each { stack ->
name(stack)
}
}
}
}
}
def mirrorsDest = '/data/mirrors/alt'
def imageMirrorsDest = '/data/shared/iso'
def mirrorsSrc = 'mirror.yandex.ru'
def platforms = [
'c8',
'p8',
'p9'
]
def elbrusBracnhes = [
'c8',
'p8',
'p9',
'sisyphus'
]
def images = [
'http://ftp.altlinux.org/pub/distributions/ALTLinux/p8/images/workstation/alt-workstation-8.2.1-20190906-x86_64-ru-install-dvd5.iso',
'http://ftp.altlinux.org/pub/distributions/ALTLinux/p8/images/server/alt-server-8.2.1-20190906-x86_64-ru-install-dvd5.iso',
'http://ftp.altlinux.org/pub/distributions/ALTLinux/p8/images/kworkstation/alt-kworkstation-8.3-install-x86_64.iso',
'http://ftp.altlinux.org/pub/distributions/ALTLinux/p9/images/server/alt-server-20191009_rc4-x86_64.iso',
'http://ftp.altlinux.org/pub/distributions/ALTLinux/p9/images/server/alt-server-20191009_rc4-aarch64.iso',
'http://ftp.altlinux.org/pub/distributions/ALTLinux/p9/images/workstation/x86_64/alt-workstation-8.991_rc2-x86_64.iso',
'http://ftp.altlinux.org/pub/distributions/ALTLinux/p9/images/workstation/aarch64/alt-workstation-8.991_rc2-aarch64.iso',
'http://ftp.altlinux.org/pub/distributions/ALTLinux/p9/images/workstation/mipsel/tavolga-alt-workstation-8.920_beta2-mipsel.recovery.tar'
]
folder('infra') {
displayName('Infrastructure')
description('Run Jenkins Job DSL to reconfigure master')
views {
sectionedView('File synchronization') {
description('File synchronization')
filterBuildQueue()
filterExecutors()
sections {
listView {
name('Images')
columns {
status()
name()
buildButton()
}
jobs {
regex('sync-image-.*')
}
}
listView {
name('Repos')
columns {
status()
name()
buildButton()
}
jobs {
regex("sync-pub-.*")
}
}
listView {
name('Elbrus repos')
columns {
status()
name()
buildButton()
}
jobs {
regex("sync-e2k-.*")
}
}
}
}
listView('Backups') {
description('Jobs to backup various artifacts')
filterBuildQueue()
filterExecutors()
columns {
status()
name()
buildButton()
}
jobs {
name('switch-backup')
}
}
listView('etc') {
description('Uncategorized jobs')
filterBuildQueue()
filterExecutors()
columns {
status()
name()
buildButton()
}
jobs {
name('configure-jenkins')
}
}
}
}
/*
* Job to configure Jenkins
job('infra/configure-jenkins') {
displayName('Configure Jenkins')
description('Apply Jenkins configuration')
scm {
git {
remote {
name('origin')
url(confrepo)
}
branch('master')
extensions {
cleanAfterCheckout()
}
}
}
}
*/
for (i = 0; i < images.size(); i++) {
filename = Paths.get(new URI(images[i]).getPath()).getFileName().toString()
job("infra/sync-image-${i}") {
displayName("${filename}")
description("Synchronize image: ${images[i]}")
label('pve')
logRotator {
numToKeep(10)
}
parameters {
stringParam('IMAGES_DEST',
imageMirrorsDest,
'Directory to save images to')
}
scm {
git {
remote {
name('origin')
url(confrepo)
}
branch('master')
extensions {
cleanAfterCheckout()
}
}
}
triggers {
// Make a pause for sync during working hours
//cron('H 3,7,9,20,23 * * *')
}
steps {
shell("/usr/bin/env IMAGES_DEST=" + '${IMAGES_DEST}' + " IMAGE=${images[i]} FILE=${filename} /bin/sh ./scripts/sync_image")
}
}
}
/*
* Generate jobs to syncrinize various repos. The process looks like
* this:
* 1) Checkout this repo;
* 2) Run synchronization script with paths set via environment
* variables;
* 3) Cleanup workspace;
*/
platforms.each { platform ->
job("infra/sync-pub-${platform}") {
displayName("Synchronize ALT Linux repos for ${platform}")
description('Runs synchronization script on PVE')
// The job must be run on pve node
label('pve')
logRotator {
numToKeep(10)
}
parameters {
stringParam('MIRRORS_DEST',
mirrorsDest,
'Directory to save repository to')
stringParam('MIRRORS_SRC',
mirrorsSrc,
'Host to download files from')
}
scm {
git {
remote {
name('origin')
url(confrepo)
}
branch('master')
extensions {
cleanAfterCheckout()
}
}
}
triggers {
// Make a pause for sync during working hours
cron('H 3,7,9,20,23 * * *')
}
steps {
shell('/usr/bin/env MIRRORS_DEST=${MIRRORS_DEST} MIRRORS_SRC=${MIRRORS_SRC} PLATFORM=' + platform + ' /bin/sh ./scripts/sync_alt_repo')
}
}
}
job('infra/switch-backup') {
displayName('Backup switch configuration')
description('Signals switches to dump active configuration to central storage')
label('pve')
logRotator {
numToKeep(20)
}
scm {
git {
remote {
name('origin')
url(confrepo)
}
branch('master')
extensions {
cleanAfterCheckout()
}
}
}
triggers {
// Synchronize every 5 hours
cron('H 5,10,15,20 * * *')
}
steps {
shell('echo test')
}
}