]> git.donarmstrong.com Git - dsa-puppet.git/blobdiff - modules/buildd/manifests/init.pp
Kill broken aptitudes on wheezy buildds
[dsa-puppet.git] / modules / buildd / manifests / init.pp
index d00197b7345852ad723db7595602cde6a670a51c..6b6e7162d6900704b327fd585fd5152364dc9538 100644 (file)
@@ -1,27 +1,31 @@
-class buildd {
+class buildd ($ensure=present) {
 
-       package { [
-                       'schroot',
-                       'sbuild'
-               ]:
-               ensure  => installed,
-               require => [
-                       Exec['apt-get update']
-               ]
-       }
+       include schroot
 
-       package { 'apt-transport-https':
+       package { 'sbuild':
                ensure => installed,
+               tag    => extra_repo,
        }
-       package { [
-                       'debootstrap',
-                       'dupload'
-               ]:
+       package { 'libsbuild-perl':
                ensure => installed,
+               tag    => extra_repo,
+               before => Package['sbuild']
        }
 
-       site::linux_module { 'dm_snapshot': }
-       ferm::module { 'nf_conntrack_ftp': }
+       package { 'apt-transport-https':
+               ensure => installed,
+       }
+       if $ensure == present {
+               package { 'dupload':
+                       ensure => installed,
+               }
+               file { '/etc/dupload.conf':
+                       source  => 'puppet:///modules/buildd/dupload.conf',
+                       require => Package['dupload'],
+               }
+               site::linux_module { 'dm_snapshot': }
+               ferm::module { 'nf_conntrack_ftp': }
+       }
 
        site::aptrepo { 'buildd':
                ensure => absent,
@@ -40,7 +44,6 @@ class buildd {
                suite      => $suite,
                components => 'main',
                require    => Package['apt-transport-https'],
-               before     => Package[schroot,sbuild]
        }
 
        if $::hostname in [alkman,porpora,zandonai] {
@@ -67,23 +70,23 @@ class buildd {
        }
        file { '/etc/apt/preferences.d/buildd':
                content => template('buildd/etc/apt/preferences.d/buildd'),
-               before  => File['/etc/apt/sources.list.d/buildd.debian.org.list']
-       }
-       file { '/etc/schroot/mount-defaults':
-               content => template('buildd/etc/schroot/mount-defaults.erb'),
-               require => Package['sbuild'],
+               before  => Site::Aptrepo['buildd.debian.org']
        }
        file { '/etc/cron.d/dsa-buildd':
                source  => 'puppet:///modules/buildd/cron.d-dsa-buildd',
                require => Package['debian.org']
        }
-       file { '/etc/dupload.conf':
-               source  => 'puppet:///modules/buildd/dupload.conf',
-               require => Package['dupload'],
-       }
-       file { '/etc/default/schroot':
-               source  => 'puppet:///modules/buildd/default-schroot',
-               require => Package['schroot']
-       }
 
+       if $::lsbmajdistrelease >= 7 {
+               package { 'python-psutil':
+                       ensure => installed,
+               }
+               file { '/usr/local/sbin/buildd-schroot-aptitude-kill':
+                       source  => 'puppet:///modules/buildd/dupload.conf',
+                       mode    => '0555',
+               }
+               file { '/etc/cron.d/puppet-buildd-aptitude':
+                       content => "*/5 * * * * root /usr/local/sbin/buildd-schroot-aptitude-kill\n",
+               }
+       }
 }