diff options
| author | Nick Lewis <nick@puppetlabs.com> | 2011-06-06 15:59:01 -0700 |
|---|---|---|
| committer | Nick Lewis <nick@puppetlabs.com> | 2011-06-06 15:59:01 -0700 |
| commit | 3d09ca82e57d0c8836b77623d876cd5dc9a3a5e6 (patch) | |
| tree | 8a55f2319be5042200b66e6c547f02ad52ac3c0f /acceptance | |
| parent | 8ebec1effc8038b1f59537450f3fe27249d543ee (diff) | |
| parent | 1c70f0ce54022b55119b9e2d6d60cd1ae9bc019e (diff) | |
Merge branch 'ticket/2.6.x/2128' into 2.6.x
Diffstat (limited to 'acceptance')
4 files changed, 122 insertions, 0 deletions
diff --git a/acceptance/tests/allow_arbitrary_node_name_fact_for_agent.rb b/acceptance/tests/allow_arbitrary_node_name_fact_for_agent.rb new file mode 100644 index 000000000..2e89d765f --- /dev/null +++ b/acceptance/tests/allow_arbitrary_node_name_fact_for_agent.rb @@ -0,0 +1,46 @@ +test_name "node_name_fact should be used to determine the node name for puppet agent" + +success_message = "node_name_fact setting was correctly used to determine the node name" + +node_names = [] + +on agents, facter('kernel') do + node_names << stdout.chomp +end + +node_names.uniq! + +authfile = "/tmp/auth.conf-2128-#{$$}" +authconf = node_names.map do |node_name| + %Q[ +path /catalog/#{node_name} +auth yes +allow * +] +end.join("\n") + +manifest_file = "/tmp/node_name_value-test-#{$$}.pp" +manifest = %Q[ + Exec { path => "/usr/bin:/bin" } + node default { + exec { "false": } + } +] +manifest << node_names.map do |node_name| + %Q[ + node "#{node_name}" { + exec { "echo #{success_message}": } + } + ] +end.join("\n") + +create_remote_file master, authfile, authconf +create_remote_file master, manifest_file, manifest + +on master, "chmod 644 #{authfile} #{manifest_file}" + +with_master_running_on(master, "--rest_authconfig #{authfile} --manifest #{manifest_file} --daemonize --autosign true") do + run_agent_on(agents, "--no-daemonize --verbose --onetime --node_name_fact kernel --server #{master}") do + assert_match(success_message, stdout) + end +end diff --git a/acceptance/tests/allow_arbitrary_node_name_fact_for_apply.rb b/acceptance/tests/allow_arbitrary_node_name_fact_for_apply.rb new file mode 100644 index 000000000..d7cf2dcac --- /dev/null +++ b/acceptance/tests/allow_arbitrary_node_name_fact_for_apply.rb @@ -0,0 +1,30 @@ +test_name "node_name_fact should be used to determine the node name for puppet apply" + +success_message = "node_name_fact setting was correctly used to determine the node name" + +node_names = [] + +on agents, facter('kernel') do + node_names << stdout.chomp +end + +node_names.uniq! + +manifest = %Q[ + Exec { path => "/usr/bin:/bin" } + node default { + exec { "false": } + } +] + +node_names.each do |node_name| + manifest << %Q[ + node "#{node_name}" { + exec { "echo #{success_message}": } + } + ] +end + +on agents, puppet_apply("--verbose --node_name_fact kernel"), :stdin => manifest do + assert_match(success_message, stdout) +end diff --git a/acceptance/tests/allow_arbitrary_node_name_for_agent.rb b/acceptance/tests/allow_arbitrary_node_name_for_agent.rb new file mode 100644 index 000000000..f5e027660 --- /dev/null +++ b/acceptance/tests/allow_arbitrary_node_name_for_agent.rb @@ -0,0 +1,29 @@ +test_name "node_name_value should be used as the node name for puppet agent" + +success_message = "node_name_value setting was correctly used as the node name" + +authfile = "/tmp/auth.conf-2128-#{$$}" +create_remote_file master, authfile, <<AUTHCONF +path /catalog/specified_node_name +auth yes +allow * +AUTHCONF + +manifest_file = "/tmp/node_name_value-test-#{$$}.pp" +create_remote_file master, manifest_file, <<MANIFEST + Exec { path => "/usr/bin:/bin" } + node default { + exec { "false": } + } + node specified_node_name { + exec { "echo #{success_message}": } + } +MANIFEST + +on master, "chmod 644 #{authfile} #{manifest_file}" + +with_master_running_on(master, "--rest_authconfig #{authfile} --manifest #{manifest_file} --daemonize --autosign true") do + run_agent_on(agents, "--no-daemonize --verbose --onetime --node_name_value specified_node_name --server #{master}") do + assert_match(success_message, stdout) + end +end diff --git a/acceptance/tests/allow_arbitrary_node_name_for_apply.rb b/acceptance/tests/allow_arbitrary_node_name_for_apply.rb new file mode 100644 index 000000000..4daa8a65b --- /dev/null +++ b/acceptance/tests/allow_arbitrary_node_name_for_apply.rb @@ -0,0 +1,17 @@ +test_name "node_name_value should be used as the node name for puppet apply" + +success_message = "node_name_value setting was correctly used as the node name" + +manifest = %Q[ + Exec { path => "/usr/bin:/bin" } + node default { + exec { "false": } + } + node a_different_node_name { + exec { "echo #{success_message}": } + } +] + +on agents, puppet_apply("--verbose --node_name_value a_different_node_name"), :stdin => manifest do + assert_match(success_message, stdout) +end |
