Sha256: 9aab1a298b42c209a990ad69ce8f210fc269f08fd460e8ba6391b6be82e8d194

Contents?: true

Size: 1.6 KB

Versions: 16

Compression:

Stored size: 1.6 KB

Contents

test_name "C64315: external facts that print messages to stderr should be seen on stderr" do
  tag 'risk:high'

  require 'facter/acceptance/user_fact_utils'
  extend Facter::Acceptance::UserFactUtils

  agents.each do |agent|
    factsd = get_factsd_dir(agent['platform'], on(agent, facter('kernelmajversion')).stdout.chomp.to_f)
    ext = get_external_fact_script_extension(agent['platform'])
    ext_fact = File.join(factsd, "external_fact#{ext}")

    if agent['platform'] =~ /windows/
      content = <<EOM
echo "SCRIPT STDERR" >&2
echo "test=value"
EOM
    else
      content = <<EOM
#!/bin/sh
echo "SCRIPT STDERR" >&2
echo "test=value"
EOM
    end

    teardown do
      on(agent, "rm -f '#{ext_fact}'")
    end

    step "Agent #{agent}: create facts.d directory and fact" do
      on(agent, "mkdir -p '#{factsd}'")
      create_remote_file(agent, ext_fact, content)
      on(agent, "chmod +x '#{ext_fact}'")
    end

    step "Agent #{agent}: external fact stderr messages should appear on stderr from facter" do
      on(agent, facter) do |facter_output|
        assert_match(/WARN.*SCRIPT STDERR/, facter_output.stderr,
                     "Expected facter to output a warning message with the stderr string from the external fact")
      end
    end

    step "Agent #{agent}: external fact stderr messages should appear on stderr from puppet facts" do
      on(agent, puppet("facts")) do |puppet_output|
        assert_match(/Warning.*SCRIPT STDERR/, puppet_output.stderr,
                     "Expected puppet facts to output a warning message with the stderr string from the external fact")
      end
    end
  end
end

Version data entries

16 entries across 16 versions & 2 rubygems

Version Path
facter-3.12.2.cfacter.20181217 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.12.1.cfacter.20181031 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.11.6.cfacter.20181031 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.12.1.cfacter.20181023 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.11.5.cfacter.20181022 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.12.0.cfacter.20181004 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.12.0.cfacter.20181001 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.12.0.cfacter.20180918 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.11.4.cfacter.20180821 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.11.3.cfacter.20180716 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.11.2.cfacter.20180612 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.9.6.cfacter.20180612 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.11.2.cfacter.20180606 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.9.6.cfacter.20180606 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
facter-3.11.0.cfacter.20180319 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb
cfacter-3.11.0.rc.20180314 ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb