Sha256: adf915b43faffe926175633e2220ef037ace33817f0d42a5d6652452f03dad32
Contents?: true
Size: 1.95 KB
Versions: 18
Compression:
Stored size: 1.95 KB
Contents
# This test verifies that corrupt facts are refreshed with new values test_name "C100042: ttls configured cached facts that are corrupt are refreshed with new values" do tag 'risk:high' require 'facter/acceptance/user_fact_utils' extend Facter::Acceptance::UserFactUtils # This fact must be resolvable on ALL platforms # Do NOT use the 'kernel' fact as it is used to configure the tests cached_factname = 'uptime' config = <<EOM facts : { ttls : [ { "#{cached_factname}" : 30 days } ] } EOM agents.each do |agent| step "Agent #{agent}: create config file" do config_dir = get_default_fact_dir(agent['platform'], on(agent, facter('kernelmajversion')).stdout.chomp.to_f) config_file = File.join(config_dir, "facter.conf") cached_facts_dir = get_cached_facts_dir(agent['platform'], on(agent, facter('kernelmajversion')).stdout.chomp.to_f) cached_fact_file = File.join(cached_facts_dir, cached_factname) # Setup facter conf on(agent, "mkdir -p '#{config_dir}'") create_remote_file(agent, config_file, config) teardown do on(agent, "rm -rf '#{config_dir}'", :acceptable_exit_codes => [0, 1]) on(agent, "rm -rf '#{cached_facts_dir}'", :acceptable_exit_codes => [0, 1]) end step "should refresh a cached fact if cache file is corrupt" do # Setup a known cached fact on(agent, "rm -rf '#{cached_facts_dir}'", :acceptable_exit_codes => [0, 1]) on(agent, facter("")) # Corrupt the cached fact file create_remote_file(agent, cached_fact_file, 'ThisIsNotvalidJSON') on(agent, facter("#{cached_factname}")) do assert_match(/.+/, stdout, "Expected fact to be resolved") end on(agent, "cat #{cached_fact_file}", :acceptable_exit_codes => [0]) do |cat_output| assert_match(/#{cached_factname}/, cat_output.stdout, "Expected cachced fact to contain the fact name") end end end end end
Version data entries
18 entries across 18 versions & 2 rubygems