Imported puppetlabs-vcsrepo
This commit is contained in:
parent
0938a13fe6
commit
18d9aa4a23
152 changed files with 9191 additions and 0 deletions
|
@ -0,0 +1,43 @@
|
|||
test_name 'C3608 - shallow clone repo depth hostile input'
|
||||
|
||||
# Globals
|
||||
repo_name = 'testrepo_shallow_clone'
|
||||
|
||||
hosts.each do |host|
|
||||
tmpdir = host.tmpdir('vcsrepo')
|
||||
step 'setup - create repo' do
|
||||
git_pkg = 'git'
|
||||
if host['platform'] =~ /ubuntu-10/
|
||||
git_pkg = 'git-core'
|
||||
end
|
||||
install_package(host, git_pkg)
|
||||
my_root = File.expand_path(File.join(File.dirname(__FILE__), '../../../../..'))
|
||||
scp_to(host, "#{my_root}/acceptance/files/create_git_repo.sh", tmpdir)
|
||||
on(host, "cd #{tmpdir} && ./create_git_repo.sh")
|
||||
end
|
||||
|
||||
teardown do
|
||||
on(host, "rm -fr #{tmpdir}")
|
||||
end
|
||||
|
||||
step 'shallow clone repo with puppet (bad input ignored, full clone checkedout)' do
|
||||
pp = <<-EOS
|
||||
vcsrepo { "#{tmpdir}/#{repo_name}":
|
||||
ensure => present,
|
||||
source => "file://#{tmpdir}/testrepo.git",
|
||||
provider => git,
|
||||
depth => "exec 'rm -rf /tmp'",
|
||||
}
|
||||
EOS
|
||||
|
||||
apply_manifest_on(host, pp, :catch_failures => true)
|
||||
apply_manifest_on(host, pp, :catch_changes => true)
|
||||
end
|
||||
|
||||
step 'verify checkout is NOT shallow' do
|
||||
on(host, "ls #{tmpdir}/#{repo_name}/.git/") do |res|
|
||||
fail_test('shallow not found') if res.stdout.include? "shallow"
|
||||
end
|
||||
end
|
||||
|
||||
end
|
|
@ -0,0 +1,44 @@
|
|||
test_name 'C3475 - shallow clone repo minimal depth = 1 (file path protocol)'
|
||||
skip_test 'Not currently supported. See FM-1285'
|
||||
|
||||
# Globals
|
||||
repo_name = 'testrepo_shallow_clone'
|
||||
|
||||
hosts.each do |host|
|
||||
tmpdir = host.tmpdir('vcsrepo')
|
||||
step 'setup - create repo' do
|
||||
git_pkg = 'git'
|
||||
if host['platform'] =~ /ubuntu-10/
|
||||
git_pkg = 'git-core'
|
||||
end
|
||||
install_package(host, git_pkg)
|
||||
my_root = File.expand_path(File.join(File.dirname(__FILE__), '../../../../..'))
|
||||
scp_to(host, "#{my_root}/acceptance/files/create_git_repo.sh", tmpdir)
|
||||
on(host, "cd #{tmpdir} && ./create_git_repo.sh")
|
||||
end
|
||||
|
||||
teardown do
|
||||
on(host, "rm -fr #{tmpdir}")
|
||||
end
|
||||
|
||||
step 'shallow clone repo with puppet' do
|
||||
pp = <<-EOS
|
||||
vcsrepo { "#{tmpdir}/#{repo_name}":
|
||||
ensure => present,
|
||||
source => "#{tmpdir}/testrepo.git",
|
||||
provider => git,
|
||||
depth => 1,
|
||||
}
|
||||
EOS
|
||||
|
||||
apply_manifest_on(host, pp, :catch_failures => true)
|
||||
apply_manifest_on(host, pp, :catch_changes => true)
|
||||
end
|
||||
|
||||
step 'git does not support shallow clone via file path: verify checkout is NOT created' do
|
||||
on(host, "ls #{tmpdir}") do |res|
|
||||
fail_test('checkout found') if res.stdout.include? "#{repo_name}"
|
||||
end
|
||||
end
|
||||
|
||||
end
|
|
@ -0,0 +1,55 @@
|
|||
test_name 'C3479 - shallow clone repo minimal depth = 1 (http protocol)'
|
||||
|
||||
# Globals
|
||||
repo_name = 'testrepo_shallow_clone'
|
||||
|
||||
hosts.each do |host|
|
||||
ruby = (host.is_pe? && '/opt/puppet/bin/ruby') || 'ruby'
|
||||
tmpdir = host.tmpdir('vcsrepo')
|
||||
step 'setup - create repo' do
|
||||
git_pkg = 'git'
|
||||
if host['platform'] =~ /ubuntu-10/
|
||||
git_pkg = 'git-core'
|
||||
end
|
||||
install_package(host, git_pkg)
|
||||
my_root = File.expand_path(File.join(File.dirname(__FILE__), '../../../../..'))
|
||||
scp_to(host, "#{my_root}/acceptance/files/create_git_repo.sh", tmpdir)
|
||||
on(host, "cd #{tmpdir} && ./create_git_repo.sh")
|
||||
end
|
||||
|
||||
step 'setup - start http server' do
|
||||
http_daemon =<<-EOF
|
||||
require 'webrick'
|
||||
server = WEBrick::HTTPServer.new(:Port => 8000, :DocumentRoot => "#{tmpdir}")
|
||||
WEBrick::Daemon.start
|
||||
server.start
|
||||
EOF
|
||||
create_remote_file(host, '/tmp/http_daemon.rb', http_daemon)
|
||||
on(host, "#{ruby} /tmp/http_daemon.rb")
|
||||
end
|
||||
|
||||
teardown do
|
||||
on(host, "rm -fr #{tmpdir}")
|
||||
on(host, 'ps ax | grep "#{ruby} /tmp/http_daemon.rb" | grep -v grep | awk \'{print "kill -9 " $1}\' | sh ; sleep 1')
|
||||
end
|
||||
|
||||
step 'shallow clone repo with puppet' do
|
||||
pp = <<-EOS
|
||||
vcsrepo { "#{tmpdir}/#{repo_name}":
|
||||
ensure => present,
|
||||
source => "http://#{host}:8000/testrepo.git",
|
||||
provider => git,
|
||||
depth => 1,
|
||||
}
|
||||
EOS
|
||||
|
||||
apply_manifest_on(host, pp, :expect_failures => true)
|
||||
end
|
||||
|
||||
step 'git does not support shallow clone via HTTP: verify checkout is NOT created' do
|
||||
on(host, "ls #{tmpdir}") do |res|
|
||||
fail_test('checkout found') if res.stdout.include? "#{repo_name}"
|
||||
end
|
||||
end
|
||||
|
||||
end
|
|
@ -0,0 +1,43 @@
|
|||
test_name 'C3607 - shallow clone repo depth = -1'
|
||||
|
||||
# Globals
|
||||
repo_name = 'testrepo_shallow_clone'
|
||||
|
||||
hosts.each do |host|
|
||||
tmpdir = host.tmpdir('vcsrepo')
|
||||
step 'setup - create repo' do
|
||||
git_pkg = 'git'
|
||||
if host['platform'] =~ /ubuntu-10/
|
||||
git_pkg = 'git-core'
|
||||
end
|
||||
install_package(host, git_pkg)
|
||||
my_root = File.expand_path(File.join(File.dirname(__FILE__), '../../../../..'))
|
||||
scp_to(host, "#{my_root}/acceptance/files/create_git_repo.sh", tmpdir)
|
||||
on(host, "cd #{tmpdir} && ./create_git_repo.sh")
|
||||
end
|
||||
|
||||
teardown do
|
||||
on(host, "rm -fr #{tmpdir}")
|
||||
end
|
||||
|
||||
step 'shallow clone repo with puppet (bad input ignored, full clone checkedout)' do
|
||||
pp = <<-EOS
|
||||
vcsrepo { "#{tmpdir}/#{repo_name}":
|
||||
ensure => present,
|
||||
source => "file://#{tmpdir}/testrepo.git",
|
||||
provider => git,
|
||||
depth => -1,
|
||||
}
|
||||
EOS
|
||||
|
||||
apply_manifest_on(host, pp, :catch_failures => true)
|
||||
apply_manifest_on(host, pp, :catch_changes => true)
|
||||
end
|
||||
|
||||
step 'verify checkout is NOT shallow' do
|
||||
on(host, "ls #{tmpdir}/#{repo_name}/.git/") do |res|
|
||||
fail_test('shallow not found') if res.stdout.include? "shallow"
|
||||
end
|
||||
end
|
||||
|
||||
end
|
|
@ -0,0 +1,45 @@
|
|||
test_name 'C3606 - shallow clone repo depth overflow 64bit integer'
|
||||
|
||||
# Globals
|
||||
repo_name = 'testrepo_shallow_clone'
|
||||
|
||||
pending_test("The overflow can't be handled on some git versions")
|
||||
|
||||
hosts.each do |host|
|
||||
tmpdir = host.tmpdir('vcsrepo')
|
||||
step 'setup - create repo' do
|
||||
git_pkg = 'git'
|
||||
if host['platform'] =~ /ubuntu-10/
|
||||
git_pkg = 'git-core'
|
||||
end
|
||||
install_package(host, git_pkg)
|
||||
my_root = File.expand_path(File.join(File.dirname(__FILE__), '../../../../..'))
|
||||
scp_to(host, "#{my_root}/acceptance/files/create_git_repo.sh", tmpdir)
|
||||
on(host, "cd #{tmpdir} && ./create_git_repo.sh")
|
||||
end
|
||||
|
||||
teardown do
|
||||
on(host, "rm -fr #{tmpdir}")
|
||||
end
|
||||
|
||||
step 'shallow clone repo with puppet (bad input ignored, full clone checkedout)' do
|
||||
pp = <<-EOS
|
||||
vcsrepo { "#{tmpdir}/#{repo_name}":
|
||||
ensure => present,
|
||||
source => "file://#{tmpdir}/testrepo.git",
|
||||
provider => git,
|
||||
depth => 18446744073709551616,
|
||||
}
|
||||
EOS
|
||||
|
||||
apply_manifest_on(host, pp, :catch_failures => true)
|
||||
apply_manifest_on(host, pp, :catch_changes => true)
|
||||
end
|
||||
|
||||
step 'verify checkout is NOT shallow' do
|
||||
on(host, "ls #{tmpdir}/#{repo_name}/.git/") do |res|
|
||||
fail_test('shallow not found') if res.stdout.include? "shallow"
|
||||
end
|
||||
end
|
||||
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue