Left: | ||
Right: |
OLD | NEW |
---|---|
(Empty) | |
1 # == Type: buildbot::slave | |
2 # | |
3 # Manage Buildbot (http://buildbot.net/) slave instances. | |
4 # | |
5 # === Parameters: | |
6 # | |
7 # [*basedir*] | |
8 # The base directory of the slave, which can be configured elsewhere or, | |
9 # if it's ancestors are present, relied upon the builtin defaults. | |
Felix Dahlke
2015/11/19 19:50:01
Typo: "its"
mathias
2016/01/20 16:13:52
Acknowledged.
| |
10 # | |
11 # [*ensure*] | |
12 # Whether to setup the slave (anything but 'absent' or 'purged') or | |
Felix Dahlke
2015/11/19 19:50:02
Typo: "set up"
mathias
2016/01/20 16:13:52
Acknowledged.
| |
13 # remove the associated resources. Note that only 'purged' implies the | |
14 # removal of $basedir. | |
15 # | |
16 # [*master*] | |
17 # The "$hostname:$port" combination of the build master. | |
18 # | |
19 # [*name*] | |
20 # The build slave's name. | |
21 # | |
22 # [*password*] | |
23 # The build slave's password with the master. | |
24 # | |
25 # [*system*] | |
26 # Any value beside 'false' will cause the slave operations to also | |
27 # affect the buildbot::buildslave service. Use this option to include | |
28 # the slave instance with the system daemon. | |
29 # | |
30 # [*user*] | |
31 # The user to whom the slave instance belongs to. Note that the user | |
32 # is not created implicitly by this setup, except if the creation is | |
33 # implied with any of the $buildbot::slave_packages. | |
34 # | |
35 # === Examples: | |
36 # | |
37 # buildbot::slave {'alpha': | |
38 # basedir => '/var/buildslave-alpha', | |
39 # } | |
40 # | |
41 # buildbot::slave {'beta': | |
42 # ensure => absent, | |
43 # } | |
44 # | |
45 define buildbot::slave ( | |
46 $admin = 'buildbot@localhost', | |
47 $basedir = "$::buildbot::slave_directory/$name", | |
48 $ensure = 'present', | |
49 $master = 'localhost:9989', | |
50 $password = 'changeme', | |
51 $system = false, | |
52 $user = $::buildbot::slave_user, | |
53 ) { | |
54 | |
55 if $ensure !~ /^(absent|purged)$/ { | |
56 ensure_packages($::buildbot::slave_packages) | |
57 realize(File[$::buildbot::slave_directory]) | |
58 | |
59 exec {"buildslave#$title": | |
60 command => shellquote([ | |
61 $::buildbot::slave_runner, | |
62 'create-slave', | |
63 $basedir, | |
64 $master, | |
65 $name, | |
66 $password, | |
67 ]), | |
68 creates => "$basedir/buildbot.tac", | |
69 require => [ | |
70 File[$::buildbot::master_directory], | |
71 Package[$::buildbot::master_packages], | |
72 ], | |
73 user => $user, | |
74 } | |
75 | |
76 Exec["buildslave#$title"] <- Exec <|creates == $basedir|> | |
77 Exec["buildslave#$title"] <- File <|path == $basedir|> | |
78 | |
79 file {"$basedir/info/admin": | |
80 content => $admin, | |
81 owner => $user, | |
82 require => Exec["buildslave#$title"], | |
83 } | |
84 } | |
85 | |
86 if $system != false { | |
87 ensure_packages($::buildbot::slave_packages) | |
88 realize(Concat['buildslave']) | |
89 realize(Concat::Fragment['buildslave']) | |
90 realize(Service['buildslave']) | |
91 | |
92 concat::fragment {"buildslave#$title": | |
93 content => template('buildbot/buildslave_fragment.erb'), | |
94 ensure => $ensure ? {'present' => $ensure, default => 'absent'}, | |
95 notify => Service['buildslave'], | |
96 order => 1, | |
97 target => 'buildslave', | |
98 } | |
99 | |
100 Service['buildslave'] <~ Exec <|creates == "$basedir"|> | |
101 Service['buildslave'] <~ Exec <|creates == "$basedir/buildbot.tac"|> | |
102 | |
103 Service['buildslave'] <~ File <|path == "$basedir"|> | |
104 Service['buildslave'] <~ File <|path == "$basedir/info/admin"|> | |
105 } | |
106 | |
107 if $ensure == 'purged' { | |
108 file {$basedir: ensure => 'absent'} | |
109 } | |
110 } | |
OLD | NEW |