cffec30027
To interact with the devstack-gate sqlite DB we need the sqlite3 CLI tool on the Jenkins master. Have puppet install this package for us. Change-Id: I53297b854dcf8897ecc932ed6506d1f77f7971ac Reviewed-on: https://review.openstack.org/14998 Reviewed-by: Jeremy Stanley <fungi@yuggoth.org> Approved: Clark Boylan <clark.boylan@gmail.com> Reviewed-by: Clark Boylan <clark.boylan@gmail.com> Tested-by: Jenkins
198 lines
4.7 KiB
Puppet
198 lines
4.7 KiB
Puppet
class jenkins::master(
|
|
$vhost_name=$fqdn,
|
|
$serveradmin="webmaster@$fqdn",
|
|
$logo,
|
|
$ssl_cert_file='',
|
|
$ssl_key_file='',
|
|
$ssl_chain_file='',
|
|
$ssl_cert_file_contents='', # If left empty puppet will not create file.
|
|
$ssl_key_file_contents='', # If left empty puppet will not create file.
|
|
$ssl_chain_file_contents='' # If left empty puppet will not create file.
|
|
) {
|
|
include pip
|
|
include apt
|
|
include apache
|
|
|
|
#This key is at http://pkg.jenkins-ci.org/debian/jenkins-ci.org.key
|
|
apt::key { "jenkins":
|
|
key => "D50582E6",
|
|
key_source => "http://pkg.jenkins-ci.org/debian/jenkins-ci.org.key",
|
|
require => Package["wget"]
|
|
}
|
|
|
|
apt::source { 'jenkins':
|
|
location => "http://pkg.jenkins-ci.org/debian",
|
|
release => "binary/",
|
|
repos => "",
|
|
require => Apt::Key['jenkins'],
|
|
include_src => false,
|
|
}
|
|
|
|
apache::vhost { $vhost_name:
|
|
port => 443,
|
|
docroot => 'MEANINGLESS ARGUMENT',
|
|
priority => '50',
|
|
template => 'jenkins/jenkins.vhost.erb',
|
|
ssl => true,
|
|
}
|
|
a2mod { 'rewrite':
|
|
ensure => present
|
|
}
|
|
a2mod { 'proxy':
|
|
ensure => present
|
|
}
|
|
a2mod { 'proxy_http':
|
|
ensure => present
|
|
}
|
|
|
|
if $ssl_cert_file_contents != '' {
|
|
file { $ssl_cert_file:
|
|
owner => 'root',
|
|
group => 'root',
|
|
mode => '0640',
|
|
content => $ssl_cert_file_contents,
|
|
before => Apache::Vhost[$vhost_name],
|
|
}
|
|
}
|
|
|
|
if $ssl_key_file_contents != '' {
|
|
file { $ssl_key_file:
|
|
owner => 'root',
|
|
group => 'ssl-cert',
|
|
mode => '0640',
|
|
content => $ssl_key_file_contents,
|
|
require => Package['ssl-cert'],
|
|
before => Apache::Vhost[$vhost_name],
|
|
}
|
|
}
|
|
|
|
if $ssl_chain_file_contents != '' {
|
|
file { $ssl_chain_file:
|
|
owner => 'root',
|
|
group => 'root',
|
|
mode => '0640',
|
|
content => $ssl_chain_file_contents,
|
|
before => Apache::Vhost[$vhost_name],
|
|
}
|
|
}
|
|
|
|
$packages = [
|
|
'python-babel',
|
|
'python-sqlalchemy', # devstack-gate
|
|
'ssl-cert',
|
|
'sqlite3', # interact with devstack-gate DB
|
|
]
|
|
|
|
package { $packages:
|
|
ensure => "present",
|
|
}
|
|
|
|
# devstack-gate
|
|
if ! defined(Package['python-jenkins']) {
|
|
package { "python-jenkins":
|
|
ensure => present,
|
|
}
|
|
}
|
|
|
|
package { "jenkins":
|
|
ensure => "present",
|
|
require => Apt::Source['jenkins'],
|
|
}
|
|
|
|
package { "apache-libcloud":
|
|
ensure => present,
|
|
provider => pip,
|
|
require => Class[pip]
|
|
}
|
|
|
|
package { "git-review":
|
|
ensure => latest,
|
|
provider => pip,
|
|
require => Class[pip]
|
|
}
|
|
|
|
package { "tox":
|
|
ensure => latest, # okay to use latest for pip
|
|
provider => pip,
|
|
require => Class[pip],
|
|
}
|
|
|
|
package { "statsd":
|
|
ensure => latest, # okay to use latest for pip
|
|
provider => pip,
|
|
require => Class[pip],
|
|
}
|
|
|
|
exec { "update apt cache":
|
|
subscribe => [ File["/etc/apt/sources.list.d/jenkins.list"]],
|
|
refreshonly => true,
|
|
path => "/bin:/usr/bin",
|
|
command => "apt-get update",
|
|
}
|
|
|
|
file { '/var/lib/jenkins':
|
|
ensure => directory,
|
|
owner => 'jenkins',
|
|
group => 'adm',
|
|
require => Package['jenkins'],
|
|
}
|
|
|
|
file { '/var/lib/jenkins/plugins':
|
|
ensure => directory,
|
|
owner => 'jenkins',
|
|
group => 'nogroup',
|
|
mode => '0750',
|
|
require => File['/var/lib/jenkins'],
|
|
}
|
|
|
|
file { '/var/lib/jenkins/plugins/simple-theme-plugin':
|
|
ensure => directory,
|
|
owner => 'jenkins',
|
|
group => 'nogroup',
|
|
require => File['/var/lib/jenkins/plugins'],
|
|
}
|
|
|
|
file { "/var/lib/jenkins/plugins/simple-theme-plugin/openstack.css":
|
|
ensure => present,
|
|
source => "puppet:///modules/jenkins/openstack.css",
|
|
require => File["/var/lib/jenkins/plugins/simple-theme-plugin"]
|
|
}
|
|
|
|
file { "/var/lib/jenkins/plugins/simple-theme-plugin/openstack.js":
|
|
ensure => present,
|
|
content => template("jenkins/openstack.js.erb"),
|
|
require => File["/var/lib/jenkins/plugins/simple-theme-plugin"]
|
|
}
|
|
|
|
file { "/var/lib/jenkins/plugins/simple-theme-plugin/openstack-page-bkg.jpg":
|
|
ensure => present,
|
|
source => "puppet:///modules/jenkins/openstack-page-bkg.jpg",
|
|
require => File["/var/lib/jenkins/plugins/simple-theme-plugin"]
|
|
}
|
|
|
|
file { "/var/lib/jenkins/plugins/simple-theme-plugin/title.png":
|
|
ensure => present,
|
|
source => "puppet:///modules/jenkins/${logo}",
|
|
require => File["/var/lib/jenkins/plugins/simple-theme-plugin"]
|
|
}
|
|
|
|
file { '/usr/local/jenkins':
|
|
owner => 'root',
|
|
group => 'root',
|
|
mode => 755,
|
|
ensure => 'directory',
|
|
}
|
|
|
|
file { '/usr/local/jenkins/slave_scripts':
|
|
owner => 'root',
|
|
group => 'root',
|
|
mode => 755,
|
|
ensure => 'directory',
|
|
recurse => true,
|
|
require => File['/usr/local/jenkins'],
|
|
source => [
|
|
"puppet:///modules/jenkins/slave_scripts",
|
|
],
|
|
}
|
|
}
|