Update specs and fix FM-1361
[puppet_vcsrepo.git] / spec / acceptance / beaker / git / clone / clone_over_different_exiting_repo_with_force.rb
1 test_name 'C3511 - clone over an existing repo with force'
2
3 # Globals
4 repo_name = 'testrepo_already_exists'
5
6 hosts.each do |host|
7   tmpdir = host.tmpdir('vcsrepo')
8   step 'setup - create repo' do
9     install_package(host, 'git')
10     my_root = File.expand_path(File.join(File.dirname(__FILE__), '../../../..'))
11     scp_to(host, "#{my_root}/acceptance/files/create_git_repo.sh", tmpdir)
12     on(host, "cd #{tmpdir} && ./create_git_repo.sh")
13     on(host, "mkdir #{tmpdir}/#{repo_name}")
14     on(host, "cd #{tmpdir}/#{repo_name} && git init")
15     on(host, "cd #{tmpdir}/#{repo_name} && touch a && git add a && git commit -m 'a'")
16   end
17
18   teardown do
19     on(host, "rm -fr #{tmpdir}")
20   end
21
22   step 'clone over existing repo with force using puppet' do
23     on(host, "cd #{tmpdir}/#{repo_name} && git log --pretty=format:\"%h\"") do |res|
24       @existing_sha = res.stdout
25     end
26     pp = <<-EOS
27     vcsrepo { "#{tmpdir}/#{repo_name}":
28       ensure => present,
29       source => "file://#{tmpdir}/testrepo.git",
30       provider => git,
31       force => true,
32     }
33     EOS
34
35     apply_manifest_on(host, pp, :catch_failures => true)
36     apply_manifest_on(host, pp, :catch_changes  => true)
37   end
38
39   step 'verify new repo has replaced old one' do
40     on(host, "cd #{tmpdir}/#{repo_name} && git log --pretty=format:\"%h\"") do |res|
41       fail_test('original repo not replaced by force') if res.stdout.include? "#{@existing_sha}"
42     end
43   end
44
45 end