(FM-8223) converted to use litmus
This commit is contained in:
@@ -1,37 +1,59 @@
|
||||
require 'beaker-pe'
|
||||
require 'beaker-puppet'
|
||||
require 'beaker-rspec'
|
||||
require 'beaker/puppet_install_helper'
|
||||
require 'beaker/module_install_helper'
|
||||
# frozen_string_literal: true
|
||||
|
||||
run_puppet_install_helper
|
||||
configure_type_defaults_on(hosts)
|
||||
install_module_on(hosts)
|
||||
install_module_dependencies_on(hosts)
|
||||
require 'serverspec'
|
||||
require 'puppet_litmus'
|
||||
require 'spec_helper_acceptance_local' if File.file?(File.join(File.dirname(__FILE__), 'spec_helper_acceptance_local.rb'))
|
||||
include PuppetLitmus
|
||||
|
||||
UNSUPPORTED_PLATFORMS = ['Darwin', 'windows'].freeze
|
||||
if ENV['TARGET_HOST'].nil? || ENV['TARGET_HOST'] == 'localhost'
|
||||
puts 'Running tests against this machine !'
|
||||
if Gem.win_platform?
|
||||
set :backend, :cmd
|
||||
else
|
||||
set :backend, :exec
|
||||
end
|
||||
else
|
||||
# load inventory
|
||||
inventory_hash = inventory_hash_from_inventory_file
|
||||
node_config = config_from_node(inventory_hash, ENV['TARGET_HOST'])
|
||||
|
||||
unless ENV['RS_PROVISION'] == 'no' || ENV['BEAKER_provision'] == 'no'
|
||||
hosts.each do |host|
|
||||
install_puppet_module_via_pmt_on(host, module_name: 'puppetlabs-apt')
|
||||
end
|
||||
end
|
||||
|
||||
RSpec.configure do |c|
|
||||
# Readable test descriptions
|
||||
c.formatter = :documentation
|
||||
end
|
||||
|
||||
def idempotent_apply(hosts, manifest, opts = {}, &block)
|
||||
block_on hosts, opts do |host|
|
||||
file_path = host.tmpfile('apply_manifest.pp')
|
||||
create_remote_file(host, file_path, manifest + "\n")
|
||||
|
||||
puppet_apply_opts = { :verbose => nil, 'detailed-exitcodes' => nil }
|
||||
on_options = { acceptable_exit_codes: [0, 2] }
|
||||
on host, puppet('apply', file_path, puppet_apply_opts), on_options, &block
|
||||
puppet_apply_opts2 = { :verbose => nil, 'detailed-exitcodes' => nil }
|
||||
on_options2 = { acceptable_exit_codes: [0] }
|
||||
on host, puppet('apply', file_path, puppet_apply_opts2), on_options2, &block
|
||||
if target_in_group(inventory_hash, ENV['TARGET_HOST'], 'docker_nodes')
|
||||
host = ENV['TARGET_HOST']
|
||||
set :backend, :docker
|
||||
set :docker_container, host
|
||||
elsif target_in_group(inventory_hash, ENV['TARGET_HOST'], 'ssh_nodes')
|
||||
set :backend, :ssh
|
||||
options = Net::SSH::Config.for(host)
|
||||
options[:user] = node_config.dig('ssh', 'user') unless node_config.dig('ssh', 'user').nil?
|
||||
options[:port] = node_config.dig('ssh', 'port') unless node_config.dig('ssh', 'port').nil?
|
||||
options[:keys] = node_config.dig('ssh', 'private-key') unless node_config.dig('ssh', 'private-key').nil?
|
||||
options[:password] = node_config.dig('ssh', 'password') unless node_config.dig('ssh', 'password').nil?
|
||||
options[:verify_host_key] = Net::SSH::Verifiers::Null.new unless node_config.dig('ssh', 'host-key-check').nil?
|
||||
host = if ENV['TARGET_HOST'].include?(':')
|
||||
ENV['TARGET_HOST'].split(':').first
|
||||
else
|
||||
ENV['TARGET_HOST']
|
||||
end
|
||||
set :host, options[:host_name] || host
|
||||
set :ssh_options, options
|
||||
set :request_pty, true
|
||||
elsif target_in_group(inventory_hash, ENV['TARGET_HOST'], 'winrm_nodes')
|
||||
require 'winrm'
|
||||
|
||||
set :backend, :winrm
|
||||
set :os, family: 'windows'
|
||||
user = node_config.dig('winrm', 'user') unless node_config.dig('winrm', 'user').nil?
|
||||
pass = node_config.dig('winrm', 'password') unless node_config.dig('winrm', 'password').nil?
|
||||
endpoint = "http://#{ENV['TARGET_HOST']}:5985/wsman"
|
||||
|
||||
opts = {
|
||||
user: user,
|
||||
password: pass,
|
||||
endpoint: endpoint,
|
||||
operation_timeout: 300,
|
||||
}
|
||||
|
||||
winrm = WinRM::Connection.new opts
|
||||
Specinfra.configuration.winrm = winrm
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user