Sha256: 96389eb81c11de3b4b5078e6387f36a6c763f799482b80cda3b51fcc53da7d58

Contents?: true

Size: 1.33 KB

Versions: 18

Compression:

Stored size: 1.33 KB

Contents

# This test is intended to ensure that the --trace command-line option works
# properly. This option provides backtraces for erroring custom Ruby facts.
# To test, we try to resolve an erroneous custom fact and catch the backtrace.
test_name "C99982: --trace command-line option enables backtraces for custom facts" do

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

  content = <<EOM
Facter.add('custom_fact') do
  setcode do
    non_existent_value
  end
end
EOM

  agents.each do |agent|
    step "Agent #{agent}: create custom fact directory and executable custom fact" do
      custom_dir = get_user_fact_dir(agent['platform'], on(agent, facter('kernelmajversion')).stdout.chomp.to_f)
      on(agent, "mkdir -p '#{custom_dir}'")
      custom_fact = File.join(custom_dir, 'custom_fact.rb')
      create_remote_file(agent, custom_fact, content)
      on(agent, "chmod +x '#{custom_fact}'")

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

      step "--trace option should provide a backtrace for a custom fact with errors" do
        on(agent, facter("--custom-dir '#{custom_dir}' --trace custom_fact"), :acceptable_exit_codes => [1]) do
          assert_match(/backtrace:\s+#{custom_fact}/, stderr, "Expected a backtrace for erroneous custom fact")
        end
      end
    end
  end
end

Version data entries

18 entries across 18 versions & 2 rubygems

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