Merge pull request #174 from justinstoller/update-helpers
[puppet_vcsrepo.git] / spec / acceptance / beaker_helper.rb
1 test_name "Installing Puppet and vcsrepo module" do
2   step 'install puppet' do
3     if @options[:provision]
4       # This will fail if puppet is already installed, ie --no-provision
5       if hosts.first.is_pe?
6         install_pe
7       else
8         install_puppet
9         on hosts, "mkdir -p #{hosts.first['distmoduledir']}"
10       end
11     end
12   end
13
14   step 'Ensure we can install our module' do
15     # We ask the host to interpolate it's distmoduledir because we don't
16     # actually know it on Windows until we've let it redirect us (depending
17     # on whether we're running as a 32/64 bit process on 32/64 bit Windows
18     moduledir = on(host, "echo #{host['distmoduledir']}").stdout.chomp
19     on host, "mkdir -p #{moduledir}"
20   end
21
22   step 'install module' do
23     hosts.each do |host|
24       proj_root = File.expand_path(File.join(File.dirname(__FILE__),'..','..'))
25
26       # This require beaker 1.12.2 I believe
27       puppet_module_install(:source => proj_root, :module_name => 'vcsrepo')
28
29       case fact_on(host, 'osfamily')
30       when 'RedHat'
31         install_package(host, 'git')
32       when 'Debian'
33         install_package(host, 'git-core')
34       else
35         if !check_for_package(host, 'git')
36           puts "Git package is required for this module"
37           exit
38         end
39       end
40
41       gitconfig = <<-EOS
42 [user]
43         email = root@localhost
44         name = root
45 EOS
46       create_remote_file(host, "/root/.gitconfig", gitconfig)
47     end
48   end
49 end