-
Notifications
You must be signed in to change notification settings - Fork 193
/
Copy pathspec_helper_acceptance.rb
151 lines (134 loc) · 5.03 KB
/
spec_helper_acceptance.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
require 'beaker-puppet'
require 'beaker-rspec/spec_helper'
require 'beaker-rspec/helpers/serverspec'
require 'beaker/ca_cert_helper'
require 'voxpupuli/acceptance/spec_helper_acceptance'
def stop_firewall_on(host)
case host['platform']
when %r{debian}
on host, 'iptables -F'
when %r{fedora|el-7}
on host, puppet('resource', 'service', 'firewalld', 'ensure=stopped')
when %r{el-|centos}
on host, puppet('resource', 'service', 'iptables', 'ensure=stopped')
when %r{ubuntu}
on host, puppet('resource', 'service', 'ufw', 'ensure=stopped')
else
logger.notify("Not sure how to clear firewall on #{host['platform']}")
end
end
# Project root
PROJ_ROOT = File.expand_path(File.join(File.dirname(__FILE__), '..'))
TEST_FILES = File.expand_path(File.join(File.dirname(__FILE__), 'acceptance', 'files'))
PUPPET_COLLECTION = 'puppet7'.freeze
def install_modules_on(host)
install_ca_certs_on(host)
puppet_module_install_on(host, source: PROJ_ROOT, module_name: 'puppet_agent')
on host, puppet('module', 'install', 'puppetlabs-stdlib'), { acceptable_exit_codes: [0] }
on host, puppet('module', 'install', 'puppetlabs-inifile'), { acceptable_exit_codes: [0] }
on host, puppet('module', 'install', 'puppetlabs-apt'), { acceptable_exit_codes: [0] }
end
unless ENV['BEAKER_provision'] == 'no'
# Install puppet-server on master
options['is_puppetserver'] = true
master['puppetservice'] = 'puppetserver'
master['puppetserver-confdir'] = '/etc/puppetlabs/puppetserver/conf.d'
master['type'] = 'aio'
install_puppet_agent_on master, { version: ENV['PUPPET_CLIENT_VERSION'] || '7.23.0', puppet_collection: PUPPET_COLLECTION }
install_modules_on master
stop_firewall_on master
end
def agent_opts(master_fqdn)
{
main: { color: 'ansi' },
agent: { ssldir: '$vardir/ssl', server: master_fqdn },
}
end
def puppet_conf(host)
if %r{windows}i.match?(host['platform'])
'C:/ProgramData/PuppetLabs/puppet/etc/puppet.conf'
else
'/etc/puppetlabs/puppet/puppet.conf'
end
end
def package_name(host)
if %r{windows}i.match?(host['platform'])
'Puppet Agent*'
else
'puppet-agent'
end
end
def setup_puppet_on(host, opts = {})
opts = { agent: false }.merge(opts)
host['type'] = 'aio'
puts "Setup aio puppet on #{host}"
configure_type_defaults_on host
install_puppet_agent_on host, { version: ENV['PUPPET_CLIENT_VERSION'] || '7.23.0', puppet_collection: PUPPET_COLLECTION }
puppet_opts = agent_opts(master.to_s)
if %r{windows}i.match?(host['platform'])
# MODULES-4242: ssldir setting is cleared but files not copied on Windows upgrading from Puppet 3
puppet_opts[:agent].delete(:ssldir)
end
configure_puppet_on(host, puppet_opts)
if opts[:agent]
puts 'Clean SSL on all hosts and disable firewalls'
hosts.each do |h|
stop_firewall_on h
end
else
install_modules_on host
end
end
def configure_agent_on(host, agent_run = false)
configure_type_defaults_on host
install_modules_on host unless agent_run
end
def wait_for_finish_on(host)
return unless %r{windows}i.match?(host['platform'])
tries = 1
# cygpath doesn't expose temp directory as there is no CSIDL for it. Assume it's always `Temp` in the Local Application Data directory
# CSIDL reference - https://msdn.microsoft.com/en-us/library/windows/desktop/bb774096%28v=vs.85%29.aspx?f=255&MSPPError=-2147217396
until on(host, 'cat `cygpath -smF 28`/Temp/puppet_agent_upgrade.pid', acceptable_exit_codes: [0, 1]).exit_code == 1 || tries > 45
puts 'waiting for upgrade to complete ...'
sleep 2
tries += 1
end
end
def teardown_puppet_on(host)
puts "Purge puppet from #{host}"
ensure_type = 'purged'
# Note pc_repo is specific to the module's manifests. This is knowledge we need to clean
# the machine after each run.
case host['platform']
when %r{debian|ubuntu}
on host, '/opt/puppetlabs/bin/puppet module install puppetlabs-apt --version 9.4.0', { acceptable_exit_codes: [0, 1] }
clean_repo = "include apt\napt::source { 'pc_repo': ensure => absent, notify => Package['puppet-agent'] }"
when %r{fedora|el|centos}
clean_repo = "yumrepo { 'pc_repo': ensure => absent, notify => Package['puppet-agent'] }"
when %r{osx}
ensure_type = 'absent'
when %r{sles}
ensure_type = 'absent'
clean_repo = "file { '/etc/zypp/repos.d/pc_repo.repo': ensure => absent, notify => Package['puppet-agent'] }"
else
logger.notify("Not sure how to remove repos on #{host['platform']}")
clean_repo = ''
end
if host['platform'].include?('windows')
install_dir = on(host, 'facter.bat env_windows_installdir').output.tr('\\', '/').chomp
scp_to host, "#{TEST_FILES}/uninstall.ps1", 'uninstall.ps1'
on host, 'rm -rf C:/ProgramData/PuppetLabs'
on host, 'powershell.exe -File uninstall.ps1 < /dev/null'
on host, "rm -rf '#{install_dir}'"
else
pp = <<-EOS
#{clean_repo}
package { ['puppet-agent', 'puppet']: ensure => #{ensure_type} }
EOS
on host, puppet('apply', '-e', "\"#{pp}\"", '--no-report')
end
end
RSpec.configure do |c|
# Readable test descriptions
c.formatter = :documentation
end