# == Class: openstack_project::slave_common # # Common configuration between openstack_project::slave and # openstack_project::single_use_slave class openstack_project::slave_common( $sudo = false, $project_config_repo = '', ){ vcsrepo { '/opt/requirements': ensure => latest, provider => git, revision => 'master', source => 'https://git.openstack.org/openstack/requirements', } class { 'project_config': url => $project_config_repo, } file { '/usr/local/jenkins/common_data': ensure => directory, owner => 'root', group => 'root', mode => '0755', recurse => true, purge => true, force => true, require => [File['/usr/local/jenkins'], $::project_config::config_dir], source => $::project_config::jenkins_data_dir, } file { '/usr/local/jenkins/slave_scripts': ensure => directory, owner => 'root', group => 'root', mode => '0755', recurse => true, purge => true, force => true, require => [File['/usr/local/jenkins'], $::project_config::config_dir], source => $::project_config::jenkins_scripts_dir, } file { '/home/jenkins/.pydistutils.cfg': ensure => present, owner => 'jenkins', group => 'jenkins', mode => '0644', source => 'puppet:///modules/openstack_project/pydistutils.cfg', require => Class['jenkins::slave'], } if ($sudo == true) { file { '/etc/sudoers.d/jenkins-sudo': ensure => present, source => 'puppet:///modules/openstack_project/jenkins-sudo.sudo', owner => 'root', group => 'root', mode => '0440', } } file { '/etc/sudoers.d/jenkins-sudo-grep': ensure => present, source => 'puppet:///modules/openstack_project/jenkins-sudo-grep.sudo', owner => 'root', group => 'root', mode => '0440', } # needed by jenkins/jobs if ! defined(Package['curl']) { package { 'curl': ensure => present, } } # install linux-headers depending on OS version case $::osfamily { 'RedHat': { if ! defined(Package['kernel-devel']) { package { 'kernel-devel': ensure => present, } } if ! defined(Package['kernel-headers']) { package { 'kernel-headers': ensure => present, } } } 'Debian': { if ($::operatingsystem == 'Debian') { # install depending on architecture case $::architecture { 'amd64', 'x86_64': { $headers_package = ['linux-headers-amd64'] } 'x86': { $headers_package = ['linux-headers-686-pae'] } default: { $headers_package = ["linux-headers-${::kernelrelease}"] } } if ! defined(Package[$headers_package]) { package { $headers_package: ensure => present, } } } else { if ($::lsbdistcodename == 'precise') { if ! defined(Package['linux-headers-virtual']) { package { 'linux-headers-virtual': ensure => present, } } if ! defined(Package['linux-headers-generic']) { package { 'linux-headers-generic': ensure => present, } } } else { # In trusty (and later), linux-headers-virtual is a transitional package that # simply depends on linux-headers-generic, so there is no need to specify it # any more. Specifying it when installing on an arm64 host causes an error, # as linux-headers-virtual does not exist for arm64/aarch64. if ! defined(Package['linux-headers-generic']) { package { 'linux-headers-generic': ensure => present, } } } } } default: { fail("Unsupported osfamily: ${::osfamily}.") } } file { '/etc/zuul-env-reqs.txt': ensure => present, owner => 'root', group => 'root', mode => '0444', source => 'puppet:///modules/openstack_project/zuul-env-reqs.txt', } python::virtualenv { '/usr/zuul-env': ensure => present, requirements => '/etc/zuul-env-reqs.txt', owner => 'root', group => 'root', timeout => 0, require => File['/etc/zuul-env-reqs.txt'], } }