facter 2.5.7 → 3.9.6.cfacter.20180606
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/ext/facter/Makefile.erb +31 -0
- data/ext/facter/cpp-hocon/CMakeLists.txt +67 -0
- data/ext/facter/cpp-hocon/CONTRIBUTING.md +9 -0
- data/ext/facter/cpp-hocon/LICENSE +17 -0
- data/ext/facter/cpp-hocon/MAINTAINERS +33 -0
- data/ext/facter/cpp-hocon/README.md +74 -0
- data/ext/facter/cpp-hocon/acceptance/Gemfile +18 -0
- data/ext/facter/cpp-hocon/acceptance/Rakefile +7 -0
- data/ext/{debian/lintian-overrides → facter/cpp-hocon/acceptance/tests/fake.rb} +0 -0
- data/ext/facter/cpp-hocon/appveyor.yml +41 -0
- data/ext/facter/cpp-hocon/lib/CMakeLists.txt +94 -0
- data/ext/facter/cpp-hocon/lib/Doxyfile.in +2312 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config.hpp +734 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_exception.hpp +184 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_include_context.hpp +51 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_includer.hpp +53 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_includer_file.hpp +30 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_list.hpp +51 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_mergeable.hpp +72 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_object.hpp +81 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_origin.hpp +98 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_parse_options.hpp +139 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_parseable.hpp +47 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_render_options.hpp +128 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_resolve_options.hpp +83 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_syntax.hpp +24 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_value.hpp +267 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/config_value_factory.hpp +48 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/functional_list.hpp +318 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/parser/config_document.hpp +95 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/parser/config_document_factory.hpp +39 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/parser/config_node.hpp +32 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/path.hpp +60 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/program_options.hpp +84 -0
- data/ext/facter/cpp-hocon/lib/inc/hocon/types.hpp +57 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/config_document_parser.hpp +83 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/config_parser.hpp +55 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/config_util.hpp +17 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/container.hpp +28 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/default_transformer.hpp +12 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/full_includer.hpp +13 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/abstract_config_node.hpp +16 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/abstract_config_node_value.hpp +12 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_array.hpp +17 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_comment.hpp +14 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_complex_value.hpp +25 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_concatenation.hpp +16 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_field.hpp +29 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_include.hpp +26 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_object.hpp +45 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_path.hpp +25 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_root.hpp +24 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_simple_value.hpp +21 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/nodes/config_node_single_token.hpp +20 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/parseable.hpp +128 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/path_builder.hpp +20 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/path_parser.hpp +55 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/replaceable_merge_stack.hpp +14 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/resolve_context.hpp +53 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/resolve_result.hpp +21 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/resolve_source.hpp +55 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/simple_config_document.hpp +28 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/simple_config_origin.hpp +67 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/simple_include_context.hpp +22 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/simple_includer.hpp +79 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/substitution_expression.hpp +28 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/token.hpp +45 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/tokenizer.hpp +143 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/tokens.hpp +135 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/unmergeable.hpp +20 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_boolean.hpp +26 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_concatenation.hpp +59 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_delayed_merge.hpp +53 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_delayed_merge_object.hpp +57 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_double.hpp +28 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_int.hpp +25 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_long.hpp +28 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_null.hpp +33 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_number.hpp +38 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_reference.hpp +38 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/config_string.hpp +32 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/simple_config_list.hpp +75 -0
- data/ext/facter/cpp-hocon/lib/inc/internal/values/simple_config_object.hpp +107 -0
- data/ext/facter/cpp-hocon/lib/namespaces.dox.in +6 -0
- data/ext/facter/cpp-hocon/lib/src/config.cc +573 -0
- data/ext/facter/cpp-hocon/lib/src/config_document_factory.cc +24 -0
- data/ext/facter/cpp-hocon/lib/src/config_document_parser.cc +620 -0
- data/ext/facter/cpp-hocon/lib/src/config_parse_options.cc +101 -0
- data/ext/facter/cpp-hocon/lib/src/config_parser.cc +399 -0
- data/ext/facter/cpp-hocon/lib/src/config_render_options.cc +44 -0
- data/ext/facter/cpp-hocon/lib/src/config_resolve_options.cc +24 -0
- data/ext/facter/cpp-hocon/lib/src/config_util.cc +95 -0
- data/ext/facter/cpp-hocon/lib/src/config_value_factory.cc +68 -0
- data/ext/facter/cpp-hocon/lib/src/default_transformer.cc +94 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/abstract_config_node.cc +19 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_array.cc +13 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_comment.cc +15 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_complex_value.cc +50 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_concatenation.cc +14 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_field.cc +80 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_include.cc +38 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_object.cc +318 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_path.cc +47 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_root.cc +70 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_simple_value.cc +50 -0
- data/ext/facter/cpp-hocon/lib/src/nodes/config_node_single_token.cc +18 -0
- data/ext/facter/cpp-hocon/lib/src/parseable.cc +325 -0
- data/ext/facter/cpp-hocon/lib/src/path.cc +219 -0
- data/ext/facter/cpp-hocon/lib/src/path_builder.cc +38 -0
- data/ext/facter/cpp-hocon/lib/src/path_parser.cc +253 -0
- data/ext/facter/cpp-hocon/lib/src/resolve_context.cc +139 -0
- data/ext/facter/cpp-hocon/lib/src/resolve_source.cc +216 -0
- data/ext/facter/cpp-hocon/lib/src/simple_config_document.cc +69 -0
- data/ext/facter/cpp-hocon/lib/src/simple_config_origin.cc +246 -0
- data/ext/facter/cpp-hocon/lib/src/simple_include_context.cc +18 -0
- data/ext/facter/cpp-hocon/lib/src/simple_includer.cc +186 -0
- data/ext/facter/cpp-hocon/lib/src/substitution_expression.cc +35 -0
- data/ext/facter/cpp-hocon/lib/src/token.cc +52 -0
- data/ext/facter/cpp-hocon/lib/src/tokenizer.cc +568 -0
- data/ext/facter/cpp-hocon/lib/src/tokens.cc +257 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_boolean.cc +34 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_concatenation.cc +260 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_delayed_merge.cc +223 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_delayed_merge_object.cc +180 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_double.cc +35 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_int.cc +35 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_long.cc +35 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_null.cc +35 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_number.cc +78 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_object.cc +97 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_reference.cc +85 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_string.cc +47 -0
- data/ext/facter/cpp-hocon/lib/src/values/config_value.cc +289 -0
- data/ext/facter/cpp-hocon/lib/src/values/simple_config_list.cc +219 -0
- data/ext/facter/cpp-hocon/lib/src/values/simple_config_object.cc +515 -0
- data/ext/facter/cpp-hocon/lib/tests/CMakeLists.txt +42 -0
- data/ext/facter/cpp-hocon/lib/tests/concatenation_test.cc +401 -0
- data/ext/facter/cpp-hocon/lib/tests/conf_parser_test.cc +715 -0
- data/ext/facter/cpp-hocon/lib/tests/config_document_parser_test.cc +208 -0
- data/ext/facter/cpp-hocon/lib/tests/config_document_tests.cc +110 -0
- data/ext/facter/cpp-hocon/lib/tests/config_node_test.cc +338 -0
- data/ext/facter/cpp-hocon/lib/tests/config_substitution_test.cc +897 -0
- data/ext/facter/cpp-hocon/lib/tests/config_test.cc +151 -0
- data/ext/facter/cpp-hocon/lib/tests/config_value_factory_test.cc +60 -0
- data/ext/facter/cpp-hocon/lib/tests/config_value_test.cc +111 -0
- data/ext/facter/cpp-hocon/lib/tests/fixtures.hpp.in +3 -0
- data/ext/facter/cpp-hocon/lib/tests/fixtures/test01.conf +91 -0
- data/ext/facter/cpp-hocon/lib/tests/fixtures/test01.json +4 -0
- data/ext/facter/cpp-hocon/lib/tests/main.cc +8 -0
- data/ext/facter/cpp-hocon/lib/tests/path_test.cc +129 -0
- data/ext/facter/cpp-hocon/lib/tests/program_options.cc +63 -0
- data/ext/facter/cpp-hocon/lib/tests/test.conf +1 -0
- data/ext/facter/cpp-hocon/lib/tests/test_utils.cc +452 -0
- data/ext/facter/cpp-hocon/lib/tests/test_utils.hpp +139 -0
- data/ext/facter/cpp-hocon/lib/tests/token_test.cc +108 -0
- data/ext/facter/cpp-hocon/lib/tests/tokenizer_test.cc +694 -0
- data/ext/facter/cpp-hocon/lib/version.h.in +28 -0
- data/ext/facter/cpp-hocon/locales/CMakeLists.txt +4 -0
- data/ext/facter/cpp-hocon/locales/cpp-hocon.pot +767 -0
- data/ext/facter/extconf.rb +22 -0
- data/ext/facter/facter/CMakeLists.txt +183 -0
- data/ext/facter/facter/CONTRIBUTING.md +99 -0
- data/ext/facter/facter/Extensibility.md +133 -0
- data/ext/facter/facter/LICENSE +17 -0
- data/ext/facter/facter/MAINTAINERS +28 -0
- data/ext/facter/facter/README.md +295 -0
- data/ext/facter/facter/Rakefile +42 -0
- data/ext/facter/facter/acceptance/Gemfile +22 -0
- data/ext/facter/facter/acceptance/Rakefile +2 -0
- data/ext/facter/facter/acceptance/bin/ci-bootstrap-from-artifacts.sh +55 -0
- data/ext/facter/facter/acceptance/config/aio/options.rb +3 -0
- data/ext/facter/facter/acceptance/config/git/options.rb +3 -0
- data/ext/facter/facter/acceptance/config/nodes/aix-53-power.yaml +7 -0
- data/ext/facter/facter/acceptance/config/nodes/aix-61-power.yaml +7 -0
- data/ext/facter/facter/acceptance/config/nodes/aix-71-power.yaml +7 -0
- data/ext/facter/facter/acceptance/config/nodes/huaweios-6-powerpc.yaml +7 -0
- data/ext/facter/facter/acceptance/config/nodes/solaris-10-sparc.yaml +9 -0
- data/ext/facter/facter/acceptance/config/nodes/solaris-11-sparc.yaml +9 -0
- data/ext/facter/facter/acceptance/lib/facter/acceptance/base_fact_utils.rb +563 -0
- data/ext/facter/facter/acceptance/lib/facter/acceptance/user_fact_utils.rb +132 -0
- data/ext/facter/facter/acceptance/lib/helper.rb +1 -0
- data/ext/facter/facter/acceptance/lib/puppet/acceptance/common_utils.rb +10 -0
- data/ext/facter/facter/acceptance/lib/puppet/acceptance/git_utils.rb +19 -0
- data/ext/facter/facter/acceptance/lib/puppet/acceptance/install_utils.rb +58 -0
- data/ext/facter/facter/acceptance/tests/custom_facts/custom_fact_with_10001_weight_overrides_external_fact.rb +30 -0
- data/ext/facter/facter/acceptance/tests/custom_facts/having_multiple_facts_in_one_file.rb +40 -0
- data/ext/facter/facter/acceptance/tests/custom_facts/using_win32ole_should_not_hang.rb +33 -0
- data/ext/facter/facter/acceptance/tests/external_facts/env_var_overrides_external_fact.rb +46 -0
- data/ext/facter/facter/acceptance/tests/external_facts/external_dir_overrides_default_external_fact.rb +34 -0
- data/ext/facter/facter/acceptance/tests/external_facts/external_fact_overrides_custom_fact.rb +29 -0
- data/ext/facter/facter/acceptance/tests/external_facts/external_fact_overrides_custom_fact_with_10000_weight_or_less.rb +30 -0
- data/ext/facter/facter/acceptance/tests/external_facts/external_fact_overrides_custom_fact_with_confine.rb +35 -0
- data/ext/facter/facter/acceptance/tests/external_facts/external_fact_stderr_messages_output_to_stderr.rb +49 -0
- data/ext/facter/facter/acceptance/tests/external_facts/external_facts_only_run_once.rb +43 -0
- data/ext/facter/facter/acceptance/tests/external_facts/fact_directory_precedence.rb +109 -0
- data/ext/facter/facter/acceptance/tests/external_facts/non_root_users_default_external_fact_directory.rb +142 -0
- data/ext/facter/facter/acceptance/tests/external_facts/root_uses_default_external_fact_dir.rb +34 -0
- data/ext/facter/facter/acceptance/tests/external_facts/structured_executable_facts.rb +139 -0
- data/ext/facter/facter/acceptance/tests/facter_returns_success_on_non_existent_fact.rb +9 -0
- data/ext/facter/facter/acceptance/tests/facts/dmi.rb +51 -0
- data/ext/facter/facter/acceptance/tests/facts/facterversion.rb +11 -0
- data/ext/facter/facter/acceptance/tests/facts/identity.rb +52 -0
- data/ext/facter/facter/acceptance/tests/facts/networking_facts.rb +76 -0
- data/ext/facter/facter/acceptance/tests/facts/non_root_users_without_errors.rb +32 -0
- data/ext/facter/facter/acceptance/tests/facts/operatingsystem_detection_after_clear_on_ubuntu.rb +26 -0
- data/ext/facter/facter/acceptance/tests/facts/os_processors_and_kernel.rb +20 -0
- data/ext/facter/facter/acceptance/tests/facts/partitions.rb +37 -0
- data/ext/facter/facter/acceptance/tests/facts/productname.rb +15 -0
- data/ext/facter/facter/acceptance/tests/facts/ruby.rb +59 -0
- data/ext/facter/facter/acceptance/tests/facts/validate_file_system_size_bytes.rb +37 -0
- data/ext/facter/facter/acceptance/tests/facts/verify_tmpfs_file_system.rb +54 -0
- data/ext/facter/facter/acceptance/tests/load_libfacter.rb +66 -0
- data/ext/facter/facter/acceptance/tests/no_errors_on_stderr.rb +10 -0
- data/ext/facter/facter/acceptance/tests/options/color.rb +16 -0
- data/ext/facter/facter/acceptance/tests/options/config.rb +27 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/blocklist.rb +35 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/blocklist_from_puppet_facts.rb +40 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/custom_dir_overridden_by_cli_custom_dir.rb +56 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/custom_facts.rb +42 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/custom_facts_list.rb +56 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/debug.rb +34 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/debug_override_config_file.rb +34 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/default_file_location.rb +37 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/external_dir_conflicts_with_cli_no_external_facts.rb +37 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/external_dir_overridden_by_cli_external_dir.rb +40 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/external_facts.rb +37 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/external_facts_list.rb +43 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/load_from_ruby.rb +73 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/log_level.rb +35 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/no_custom_facts_and_custom_dir.rb +43 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/no_custom_facts_and_facterlib.rb +43 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/no_custom_facts_and_load_path.rb +49 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/no_external_facts.rb +38 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/no_external_facts_and_external_dir.rb +34 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/no_ruby_disables_custom_facts.rb +52 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/no_ruby_disables_ruby_facts.rb +34 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/trace.rb +48 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/ttls_cached_facts_clear_by_empty_ttls_cache_list.rb +71 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/ttls_cached_facts_creates_json_cache_file.rb +48 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/ttls_cached_facts_expire_facts_do_not_read_the_old_cached_value.rb +58 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/ttls_cached_facts_expire_facts_refresh_the_cached_value.rb +61 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/ttls_cached_facts_read_from_the_cached_value.rb +57 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/ttls_cached_facts_that_are_corrupt_are_refreshed.rb +53 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/ttls_cached_facts_that_are_empty_return_an_empty_value.rb +53 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/ttls_puppet_facts_creates_json_for_cached_facts.rb +45 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/ttls_puppet_facts_honors_cached_facts.rb +54 -0
- data/ext/facter/facter/acceptance/tests/options/config_file/verbose.rb +34 -0
- data/ext/facter/facter/acceptance/tests/options/custom_facts.rb +34 -0
- data/ext/facter/facter/acceptance/tests/options/custom_facts_facterlib.rb +33 -0
- data/ext/facter/facter/acceptance/tests/options/custom_facts_list.rb +48 -0
- data/ext/facter/facter/acceptance/tests/options/custom_facts_load_path.rb +42 -0
- data/ext/facter/facter/acceptance/tests/options/debug.rb +12 -0
- data/ext/facter/facter/acceptance/tests/options/external_facts.rb +28 -0
- data/ext/facter/facter/acceptance/tests/options/external_facts_list.rb +35 -0
- data/ext/facter/facter/acceptance/tests/options/help.rb +13 -0
- data/ext/facter/facter/acceptance/tests/options/json.rb +43 -0
- data/ext/facter/facter/acceptance/tests/options/list_block_groups.rb +16 -0
- data/ext/facter/facter/acceptance/tests/options/list_cache_groups.rb +16 -0
- data/ext/facter/facter/acceptance/tests/options/log_level.rb +13 -0
- data/ext/facter/facter/acceptance/tests/options/no_block.rb +34 -0
- data/ext/facter/facter/acceptance/tests/options/no_cache_should_not_cache_facts.rb +43 -0
- data/ext/facter/facter/acceptance/tests/options/no_cache_should_not_load_cached_facts.rb +58 -0
- data/ext/facter/facter/acceptance/tests/options/no_cache_should_not_refresh_cached_facts.rb +63 -0
- data/ext/facter/facter/acceptance/tests/options/no_color.rb +16 -0
- data/ext/facter/facter/acceptance/tests/options/no_custom_facts.rb +34 -0
- data/ext/facter/facter/acceptance/tests/options/no_custom_facts_and_custom_dir.rb +19 -0
- data/ext/facter/facter/acceptance/tests/options/no_custom_facts_and_facterlib.rb +34 -0
- data/ext/facter/facter/acceptance/tests/options/no_custom_facts_and_load_path.rb +43 -0
- data/ext/facter/facter/acceptance/tests/options/no_external_facts.rb +28 -0
- data/ext/facter/facter/acceptance/tests/options/no_external_facts_and_external_dir.rb +19 -0
- data/ext/facter/facter/acceptance/tests/options/no_ruby.rb +44 -0
- data/ext/facter/facter/acceptance/tests/options/puppet_facts.rb +35 -0
- data/ext/facter/facter/acceptance/tests/options/show_legacy.rb +18 -0
- data/ext/facter/facter/acceptance/tests/options/strict.rb +11 -0
- data/ext/facter/facter/acceptance/tests/options/trace.rb +36 -0
- data/ext/facter/facter/acceptance/tests/options/verbose.rb +12 -0
- data/ext/facter/facter/acceptance/tests/options/version.rb +12 -0
- data/ext/facter/facter/acceptance/tests/options/yaml.rb +43 -0
- data/ext/facter/facter/acceptance/tests/ticket_1123_facter_with_invalid_locale.rb +22 -0
- data/ext/facter/facter/acceptance/tests/ticket_1238_hostname_fqdn.rb +37 -0
- data/ext/facter/facter/appveyor.yml +43 -0
- data/ext/facter/facter/cmake/FindBLKID.cmake +6 -0
- data/ext/facter/facter/cmake/FindCPPHOCON.cmake +6 -0
- data/ext/facter/facter/cmake/FindDependency.cmake +54 -0
- data/ext/facter/facter/cmake/FindOPENSSL.cmake +10 -0
- data/ext/facter/facter/cmake/FindRuby.cmake +286 -0
- data/ext/facter/facter/cmake/FindWHEREAMI.cmake +6 -0
- data/ext/facter/facter/cmake/FindYAMLCPP.cmake +17 -0
- data/ext/facter/facter/contrib/dockerfiles/travis-cpp-builder/Dockerfile +56 -0
- data/ext/facter/facter/contrib/dockerfiles/travis-facter-builder/Dockerfile +23 -0
- data/ext/facter/facter/contrib/dockerfiles/travis-facter-coverity/Dockerfile +40 -0
- data/ext/facter/facter/contrib/dockerfiles/travis-facter-coverity/_coverity-submit.erb +12 -0
- data/ext/facter/facter/contrib/dockerfiles/travis-facter-coverity/fix_curl_command.patch +32 -0
- data/ext/facter/facter/exe/CMakeLists.txt +39 -0
- data/ext/facter/facter/exe/facter.cc +377 -0
- data/ext/facter/facter/ext/build_defaults.yaml +16 -0
- data/ext/facter/facter/ext/debian/changelog.erb +11 -0
- data/ext/{debian → facter/facter/ext/debian}/compat +0 -0
- data/ext/facter/facter/ext/debian/control +14 -0
- data/ext/facter/facter/ext/debian/copyright +19 -0
- data/ext/facter/facter/ext/debian/docs +2 -0
- data/ext/facter/facter/ext/debian/facter.install +4 -0
- data/ext/facter/facter/ext/debian/lintian-overrides +0 -0
- data/ext/facter/facter/ext/debian/rules +39 -0
- data/ext/{debian → facter/facter/ext/debian}/source/format +0 -0
- data/ext/facter/facter/ext/project_data.yaml +30 -0
- data/ext/facter/facter/ext/redhat/facter.spec.erb +113 -0
- data/ext/facter/facter/ext/windows/facter.bat +8 -0
- data/ext/facter/facter/ext/windows/facter_interactive.bat +6 -0
- data/ext/facter/facter/ext/windows/run_facter_interactive.bat +9 -0
- data/ext/facter/facter/factergo/example/main.go +17 -0
- data/ext/facter/facter/factergo/facter.go +42 -0
- data/ext/facter/facter/factergo/facter_test.go +25 -0
- data/ext/facter/facter/lib/CMakeLists.txt +408 -0
- data/ext/facter/facter/lib/Doxyfile +2313 -0
- data/ext/facter/facter/lib/Facter.java.in +110 -0
- data/ext/facter/facter/lib/Gemfile +11 -0
- data/ext/facter/facter/lib/Rakefile +8 -0
- data/ext/facter/facter/lib/docs/generate.rb +25 -0
- data/ext/facter/facter/lib/docs/namespaces.dox +129 -0
- data/ext/facter/facter/lib/docs/template.erb +43 -0
- data/ext/facter/facter/lib/facter.rb.in +45 -0
- data/ext/facter/facter/lib/gemspec.in +21 -0
- data/ext/facter/facter/lib/inc/facter/cwrapper.hpp +18 -0
- data/ext/facter/facter/lib/inc/facter/facts/array_value.hpp +125 -0
- data/ext/facter/facter/lib/inc/facter/facts/collection.hpp +339 -0
- data/ext/facter/facter/lib/inc/facter/facts/external/resolver.hpp +49 -0
- data/ext/facter/facter/lib/inc/facter/facts/fact.hpp +664 -0
- data/ext/facter/facter/lib/inc/facter/facts/map_value.hpp +127 -0
- data/ext/facter/facter/lib/inc/facter/facts/os.hpp +202 -0
- data/ext/facter/facter/lib/inc/facter/facts/os_family.hpp +58 -0
- data/ext/facter/facter/lib/inc/facter/facts/resolver.hpp +126 -0
- data/ext/facter/facter/lib/inc/facter/facts/scalar_value.hpp +152 -0
- data/ext/facter/facter/lib/inc/facter/facts/value.hpp +164 -0
- data/ext/facter/facter/lib/inc/facter/facts/vm.hpp +157 -0
- data/ext/facter/facter/lib/inc/facter/logging/logging.hpp +192 -0
- data/ext/facter/facter/lib/inc/facter/ruby/ruby.hpp +62 -0
- data/ext/facter/facter/lib/inc/facter/util/config.hpp +84 -0
- data/ext/facter/facter/lib/inc/facter/util/string.hpp +72 -0
- data/ext/facter/facter/lib/inc/internal/facts/aix/disk_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/aix/filesystem_resolver.hpp +41 -0
- data/ext/facter/facter/lib/inc/internal/facts/aix/kernel_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/aix/memory_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/aix/networking_resolver.hpp +56 -0
- data/ext/facter/facter/lib/inc/internal/facts/aix/operating_system_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/aix/processor_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/aix/serial_number_resolver.hpp +27 -0
- data/ext/facter/facter/lib/inc/internal/facts/bsd/filesystem_resolver.hpp +30 -0
- data/ext/facter/facter/lib/inc/internal/facts/bsd/networking_resolver.hpp +59 -0
- data/ext/facter/facter/lib/inc/internal/facts/bsd/uptime_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/cache.hpp +71 -0
- data/ext/facter/facter/lib/inc/internal/facts/external/execution_resolver.hpp +31 -0
- data/ext/facter/facter/lib/inc/internal/facts/external/json_resolver.hpp +31 -0
- data/ext/facter/facter/lib/inc/internal/facts/external/text_resolver.hpp +31 -0
- data/ext/facter/facter/lib/inc/internal/facts/external/windows/powershell_resolver.hpp +34 -0
- data/ext/facter/facter/lib/inc/internal/facts/external/yaml_resolver.hpp +31 -0
- data/ext/facter/facter/lib/inc/internal/facts/freebsd/dmi_resolver.hpp +28 -0
- data/ext/facter/facter/lib/inc/internal/facts/freebsd/memory_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/freebsd/networking_resolver.hpp +49 -0
- data/ext/facter/facter/lib/inc/internal/facts/freebsd/operating_system_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/freebsd/processor_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/freebsd/virtualization_resolver.hpp +27 -0
- data/ext/facter/facter/lib/inc/internal/facts/freebsd/zfs_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/freebsd/zpool_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/glib/load_average_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/disk_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/dmi_resolver.hpp +37 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/filesystem_resolver.hpp +40 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/kernel_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/memory_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/networking_resolver.hpp +85 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/operating_system_resolver.hpp +28 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/os_cisco.hpp +114 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/os_coreos.hpp +56 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/os_cumulus.hpp +56 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/os_linux.hpp +72 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/processor_resolver.hpp +60 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/release_file.hpp +124 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/uptime_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/linux/virtualization_resolver.hpp +50 -0
- data/ext/facter/facter/lib/inc/internal/facts/openbsd/dmi_resolver.hpp +28 -0
- data/ext/facter/facter/lib/inc/internal/facts/openbsd/memory_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/openbsd/networking_resolver.hpp +49 -0
- data/ext/facter/facter/lib/inc/internal/facts/openbsd/processor_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/openbsd/virtualization_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/osx/dmi_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/osx/memory_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/osx/networking_resolver.hpp +67 -0
- data/ext/facter/facter/lib/inc/internal/facts/osx/operating_system_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/osx/processor_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/osx/system_profiler_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/osx/virtualization_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/posix/identity_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/posix/kernel_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/posix/networking_resolver.hpp +55 -0
- data/ext/facter/facter/lib/inc/internal/facts/posix/operating_system_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/posix/processor_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/posix/ssh_resolver.hpp +28 -0
- data/ext/facter/facter/lib/inc/internal/facts/posix/timezone_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/posix/uptime_resolver.hpp +32 -0
- data/ext/facter/facter/lib/inc/internal/facts/posix/xen_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/augeas_resolver.hpp +35 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/disk_resolver.hpp +81 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/dmi_resolver.hpp +115 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/ec2_resolver.hpp +30 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/filesystem_resolver.hpp +166 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/gce_resolver.hpp +28 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/hypervisors_resolver.hpp +69 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/identity_resolver.hpp +73 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/kernel_resolver.hpp +66 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/ldom_resolver.hpp +64 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/load_average_resolver.hpp +37 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/memory_resolver.hpp +99 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/networking_resolver.hpp +156 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/operating_system_resolver.hpp +235 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/path_resolver.hpp +28 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/processor_resolver.hpp +80 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/ruby_resolver.hpp +56 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/ssh_resolver.hpp +99 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/system_profiler_resolver.hpp +127 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/timezone_resolver.hpp +36 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/uptime_resolver.hpp +36 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/virtualization_resolver.hpp +95 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/xen_resolver.hpp +55 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/zfs_resolver.hpp +59 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/zone_resolver.hpp +95 -0
- data/ext/facter/facter/lib/inc/internal/facts/resolvers/zpool_resolver.hpp +63 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/disk_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/dmi_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/filesystem_resolver.hpp +29 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/kernel_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/ldom_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/memory_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/networking_resolver.hpp +55 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/operating_system_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/processor_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/virtualization_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/zfs_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/zone_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/solaris/zpool_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/windows/dmi_resolver.hpp +38 -0
- data/ext/facter/facter/lib/inc/internal/facts/windows/identity_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/windows/kernel_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/windows/memory_resolver.hpp +25 -0
- data/ext/facter/facter/lib/inc/internal/facts/windows/networking_resolver.hpp +74 -0
- data/ext/facter/facter/lib/inc/internal/facts/windows/operating_system_resolver.hpp +36 -0
- data/ext/facter/facter/lib/inc/internal/facts/windows/processor_resolver.hpp +36 -0
- data/ext/facter/facter/lib/inc/internal/facts/windows/timezone_resolver.hpp +24 -0
- data/ext/facter/facter/lib/inc/internal/facts/windows/uptime_resolver.hpp +32 -0
- data/ext/facter/facter/lib/inc/internal/facts/windows/virtualization_resolver.hpp +37 -0
- data/ext/facter/facter/lib/inc/internal/ruby/aggregate_resolution.hpp +77 -0
- data/ext/facter/facter/lib/inc/internal/ruby/chunk.hpp +83 -0
- data/ext/facter/facter/lib/inc/internal/ruby/confine.hpp +60 -0
- data/ext/facter/facter/lib/inc/internal/ruby/fact.hpp +108 -0
- data/ext/facter/facter/lib/inc/internal/ruby/module.hpp +165 -0
- data/ext/facter/facter/lib/inc/internal/ruby/resolution.hpp +126 -0
- data/ext/facter/facter/lib/inc/internal/ruby/ruby_value.hpp +119 -0
- data/ext/facter/facter/lib/inc/internal/ruby/simple_resolution.hpp +56 -0
- data/ext/facter/facter/lib/inc/internal/util/agent.hpp +29 -0
- data/ext/facter/facter/lib/inc/internal/util/aix/odm.hpp +373 -0
- data/ext/facter/facter/lib/inc/internal/util/aix/vmount.hpp +139 -0
- data/ext/facter/facter/lib/inc/internal/util/bsd/scoped_ifaddrs.hpp +33 -0
- data/ext/facter/facter/lib/inc/internal/util/posix/scoped_addrinfo.hpp +45 -0
- data/ext/facter/facter/lib/inc/internal/util/posix/scoped_bio.hpp +34 -0
- data/ext/facter/facter/lib/inc/internal/util/posix/scoped_descriptor.hpp +27 -0
- data/ext/facter/facter/lib/inc/internal/util/scoped_file.hpp +36 -0
- data/ext/facter/facter/lib/inc/internal/util/solaris/k_stat.hpp +176 -0
- data/ext/facter/facter/lib/inc/internal/util/solaris/scoped_kstat.hpp +45 -0
- data/ext/facter/facter/lib/inc/internal/util/versions.hpp +34 -0
- data/ext/facter/facter/lib/inc/internal/util/windows/wsa.hpp +92 -0
- data/ext/facter/facter/lib/inc/internal/util/yaml.hpp +25 -0
- data/ext/facter/facter/lib/schema/core_facts.pot +2017 -0
- data/ext/facter/facter/lib/schema/facter.yaml +1927 -0
- data/ext/facter/facter/lib/schema/translation_tooling.rb +67 -0
- data/ext/facter/facter/lib/spec/unit/facter_spec.rb +136 -0
- data/ext/facter/facter/lib/spec_helper.rb.in +27 -0
- data/ext/facter/facter/lib/src/cwrapper.cc +40 -0
- data/ext/facter/facter/lib/src/facts/aix/collection.cc +32 -0
- data/ext/facter/facter/lib/src/facts/aix/disk_resolver.cc +75 -0
- data/ext/facter/facter/lib/src/facts/aix/filesystem_resolver.cc +132 -0
- data/ext/facter/facter/lib/src/facts/aix/kernel_resolver.cc +27 -0
- data/ext/facter/facter/lib/src/facts/aix/memory_resolver.cc +48 -0
- data/ext/facter/facter/lib/src/facts/aix/networking_resolver.cc +250 -0
- data/ext/facter/facter/lib/src/facts/aix/operating_system_resolver.cc +61 -0
- data/ext/facter/facter/lib/src/facts/aix/processor_resolver.cc +106 -0
- data/ext/facter/facter/lib/src/facts/aix/serial_number_resolver.cc +43 -0
- data/ext/facter/facter/lib/src/facts/array_value.cc +111 -0
- data/ext/facter/facter/lib/src/facts/bsd/collection.cc +27 -0
- data/ext/facter/facter/lib/src/facts/bsd/filesystem_resolver.cc +92 -0
- data/ext/facter/facter/lib/src/facts/bsd/networking_resolver.cc +175 -0
- data/ext/facter/facter/lib/src/facts/bsd/uptime_resolver.cc +23 -0
- data/ext/facter/facter/lib/src/facts/cache.cc +117 -0
- data/ext/facter/facter/lib/src/facts/collection.cc +661 -0
- data/ext/facter/facter/lib/src/facts/external/execution_resolver.cc +89 -0
- data/ext/facter/facter/lib/src/facts/external/json_resolver.cc +219 -0
- data/ext/facter/facter/lib/src/facts/external/resolver.cc +12 -0
- data/ext/facter/facter/lib/src/facts/external/text_resolver.cc +45 -0
- data/ext/facter/facter/lib/src/facts/external/windows/powershell_resolver.cc +117 -0
- data/ext/facter/facter/lib/src/facts/external/yaml_resolver.cc +45 -0
- data/ext/facter/facter/lib/src/facts/freebsd/collection.cc +41 -0
- data/ext/facter/facter/lib/src/facts/freebsd/dmi_resolver.cc +39 -0
- data/ext/facter/facter/lib/src/facts/freebsd/memory_resolver.cc +76 -0
- data/ext/facter/facter/lib/src/facts/freebsd/networking_resolver.cc +64 -0
- data/ext/facter/facter/lib/src/facts/freebsd/operating_system_resolver.cc +17 -0
- data/ext/facter/facter/lib/src/facts/freebsd/processor_resolver.cc +63 -0
- data/ext/facter/facter/lib/src/facts/freebsd/virtualization_resolver.cc +44 -0
- data/ext/facter/facter/lib/src/facts/freebsd/zfs_resolver.cc +12 -0
- data/ext/facter/facter/lib/src/facts/freebsd/zpool_resolver.cc +12 -0
- data/ext/facter/facter/lib/src/facts/glib/load_average_resolver.cc +22 -0
- data/ext/facter/facter/lib/src/facts/linux/collection.cc +42 -0
- data/ext/facter/facter/lib/src/facts/linux/disk_resolver.cc +80 -0
- data/ext/facter/facter/lib/src/facts/linux/dmi_resolver.cc +208 -0
- data/ext/facter/facter/lib/src/facts/linux/filesystem_resolver.cc +282 -0
- data/ext/facter/facter/lib/src/facts/linux/kernel_resolver.cc +20 -0
- data/ext/facter/facter/lib/src/facts/linux/memory_resolver.cc +50 -0
- data/ext/facter/facter/lib/src/facts/linux/networking_resolver.cc +284 -0
- data/ext/facter/facter/lib/src/facts/linux/operating_system_resolver.cc +175 -0
- data/ext/facter/facter/lib/src/facts/linux/os_linux.cc +393 -0
- data/ext/facter/facter/lib/src/facts/linux/processor_resolver.cc +200 -0
- data/ext/facter/facter/lib/src/facts/linux/uptime_resolver.cc +15 -0
- data/ext/facter/facter/lib/src/facts/linux/virtualization_resolver.cc +282 -0
- data/ext/facter/facter/lib/src/facts/map_value.cc +119 -0
- data/ext/facter/facter/lib/src/facts/openbsd/collection.cc +37 -0
- data/ext/facter/facter/lib/src/facts/openbsd/dmi_resolver.cc +47 -0
- data/ext/facter/facter/lib/src/facts/openbsd/memory_resolver.cc +76 -0
- data/ext/facter/facter/lib/src/facts/openbsd/networking_resolver.cc +64 -0
- data/ext/facter/facter/lib/src/facts/openbsd/processor_resolver.cc +59 -0
- data/ext/facter/facter/lib/src/facts/openbsd/virtualization_resolver.cc +20 -0
- data/ext/facter/facter/lib/src/facts/osx/collection.cc +39 -0
- data/ext/facter/facter/lib/src/facts/osx/dmi_resolver.cc +32 -0
- data/ext/facter/facter/lib/src/facts/osx/memory_resolver.cc +60 -0
- data/ext/facter/facter/lib/src/facts/osx/networking_resolver.cc +80 -0
- data/ext/facter/facter/lib/src/facts/osx/operating_system_resolver.cc +49 -0
- data/ext/facter/facter/lib/src/facts/osx/processor_resolver.cc +55 -0
- data/ext/facter/facter/lib/src/facts/osx/system_profiler_resolver.cc +66 -0
- data/ext/facter/facter/lib/src/facts/osx/virtualization_resolver.cc +46 -0
- data/ext/facter/facter/lib/src/facts/posix/cache.cc +9 -0
- data/ext/facter/facter/lib/src/facts/posix/collection.cc +48 -0
- data/ext/facter/facter/lib/src/facts/posix/identity_resolver.cc +79 -0
- data/ext/facter/facter/lib/src/facts/posix/kernel_resolver.cc +25 -0
- data/ext/facter/facter/lib/src/facts/posix/networking_resolver.cc +137 -0
- data/ext/facter/facter/lib/src/facts/posix/operatingsystem_resolver.cc +29 -0
- data/ext/facter/facter/lib/src/facts/posix/processor_resolver.cc +22 -0
- data/ext/facter/facter/lib/src/facts/posix/ssh_resolver.cc +115 -0
- data/ext/facter/facter/lib/src/facts/posix/timezone_resolver.cc +26 -0
- data/ext/facter/facter/lib/src/facts/posix/uptime_resolver.cc +53 -0
- data/ext/facter/facter/lib/src/facts/posix/xen_resolver.cc +43 -0
- data/ext/facter/facter/lib/src/facts/resolver.cc +105 -0
- data/ext/facter/facter/lib/src/facts/resolvers/augeas_resolver.cc +56 -0
- data/ext/facter/facter/lib/src/facts/resolvers/disk_resolver.cc +69 -0
- data/ext/facter/facter/lib/src/facts/resolvers/dmi_resolver.cc +160 -0
- data/ext/facter/facter/lib/src/facts/resolvers/ec2_resolver.cc +174 -0
- data/ext/facter/facter/lib/src/facts/resolvers/filesystem_resolver.cc +118 -0
- data/ext/facter/facter/lib/src/facts/resolvers/gce_resolver.cc +276 -0
- data/ext/facter/facter/lib/src/facts/resolvers/hypervisors_resolver.cc +76 -0
- data/ext/facter/facter/lib/src/facts/resolvers/identity_resolver.cc +50 -0
- data/ext/facter/facter/lib/src/facts/resolvers/kernel_resolver.cc +62 -0
- data/ext/facter/facter/lib/src/facts/resolvers/ldom_resolver.cc +60 -0
- data/ext/facter/facter/lib/src/facts/resolvers/load_average_resolver.cc +36 -0
- data/ext/facter/facter/lib/src/facts/resolvers/memory_resolver.cc +88 -0
- data/ext/facter/facter/lib/src/facts/resolvers/networking_resolver.cc +296 -0
- data/ext/facter/facter/lib/src/facts/resolvers/operating_system_resolver.cc +276 -0
- data/ext/facter/facter/lib/src/facts/resolvers/path_resolver.cc +25 -0
- data/ext/facter/facter/lib/src/facts/resolvers/processor_resolver.cc +70 -0
- data/ext/facter/facter/lib/src/facts/resolvers/ruby_resolver.cc +109 -0
- data/ext/facter/facter/lib/src/facts/resolvers/ssh_resolver.cc +76 -0
- data/ext/facter/facter/lib/src/facts/resolvers/system_profiler_resolver.cc +137 -0
- data/ext/facter/facter/lib/src/facts/resolvers/timezone_resolver.cc +27 -0
- data/ext/facter/facter/lib/src/facts/resolvers/uptime_resolver.cc +63 -0
- data/ext/facter/facter/lib/src/facts/resolvers/virtualization_resolver.cc +119 -0
- data/ext/facter/facter/lib/src/facts/resolvers/xen_resolver.cc +80 -0
- data/ext/facter/facter/lib/src/facts/resolvers/zfs_resolver.cc +63 -0
- data/ext/facter/facter/lib/src/facts/resolvers/zone_resolver.cc +91 -0
- data/ext/facter/facter/lib/src/facts/resolvers/zpool_resolver.cc +93 -0
- data/ext/facter/facter/lib/src/facts/scalar_value.cc +73 -0
- data/ext/facter/facter/lib/src/facts/solaris/collection.cc +51 -0
- data/ext/facter/facter/lib/src/facts/solaris/disk_resolver.cc +35 -0
- data/ext/facter/facter/lib/src/facts/solaris/dmi_resolver.cc +86 -0
- data/ext/facter/facter/lib/src/facts/solaris/filesystem_resolver.cc +92 -0
- data/ext/facter/facter/lib/src/facts/solaris/kernel_resolver.cc +24 -0
- data/ext/facter/facter/lib/src/facts/solaris/ldom_resolver.cc +87 -0
- data/ext/facter/facter/lib/src/facts/solaris/memory_resolver.cc +91 -0
- data/ext/facter/facter/lib/src/facts/solaris/networking_resolver.cc +188 -0
- data/ext/facter/facter/lib/src/facts/solaris/operating_system_resolver.cc +83 -0
- data/ext/facter/facter/lib/src/facts/solaris/processor_resolver.cc +105 -0
- data/ext/facter/facter/lib/src/facts/solaris/virtualization_resolver.cc +38 -0
- data/ext/facter/facter/lib/src/facts/solaris/zfs_resolver.cc +12 -0
- data/ext/facter/facter/lib/src/facts/solaris/zone_resolver.cc +33 -0
- data/ext/facter/facter/lib/src/facts/solaris/zpool_resolver.cc +12 -0
- data/ext/facter/facter/lib/src/facts/windows/cache.cc +11 -0
- data/ext/facter/facter/lib/src/facts/windows/collection.cc +91 -0
- data/ext/facter/facter/lib/src/facts/windows/dmi_resolver.cc +38 -0
- data/ext/facter/facter/lib/src/facts/windows/identity_resolver.cc +46 -0
- data/ext/facter/facter/lib/src/facts/windows/kernel_resolver.cc +78 -0
- data/ext/facter/facter/lib/src/facts/windows/memory_resolver.cc +25 -0
- data/ext/facter/facter/lib/src/facts/windows/networking_resolver.cc +227 -0
- data/ext/facter/facter/lib/src/facts/windows/operating_system_resolver.cc +125 -0
- data/ext/facter/facter/lib/src/facts/windows/processor_resolver.cc +99 -0
- data/ext/facter/facter/lib/src/facts/windows/timezone_resolver.cc +28 -0
- data/ext/facter/facter/lib/src/facts/windows/uptime_resolver.cc +26 -0
- data/ext/facter/facter/lib/src/facts/windows/virtualization_resolver.cc +63 -0
- data/ext/facter/facter/lib/src/java/facter.cc +185 -0
- data/ext/facter/facter/lib/src/logging/logging.cc +151 -0
- data/ext/facter/facter/lib/src/ruby/aggregate_resolution.cc +249 -0
- data/ext/facter/facter/lib/src/ruby/chunk.cc +136 -0
- data/ext/facter/facter/lib/src/ruby/confine.cc +84 -0
- data/ext/facter/facter/lib/src/ruby/fact.cc +382 -0
- data/ext/facter/facter/lib/src/ruby/module.cc +1130 -0
- data/ext/facter/facter/lib/src/ruby/resolution.cc +230 -0
- data/ext/facter/facter/lib/src/ruby/ruby.cc +150 -0
- data/ext/facter/facter/lib/src/ruby/ruby_value.cc +288 -0
- data/ext/facter/facter/lib/src/ruby/simple_resolution.cc +156 -0
- data/ext/facter/facter/lib/src/util/bsd/scoped_ifaddrs.cc +29 -0
- data/ext/facter/facter/lib/src/util/config/config.cc +83 -0
- data/ext/facter/facter/lib/src/util/config/posix/config.cc +12 -0
- data/ext/facter/facter/lib/src/util/config/windows/config.cc +14 -0
- data/ext/facter/facter/lib/src/util/posix/scoped_addrinfo.cc +41 -0
- data/ext/facter/facter/lib/src/util/posix/scoped_bio.cc +29 -0
- data/ext/facter/facter/lib/src/util/posix/scoped_descriptor.cc +20 -0
- data/ext/facter/facter/lib/src/util/scoped_file.cc +26 -0
- data/ext/facter/facter/lib/src/util/solaris/k_stat.cc +165 -0
- data/ext/facter/facter/lib/src/util/solaris/scoped_kstat.cc +31 -0
- data/ext/facter/facter/lib/src/util/string.cc +170 -0
- data/ext/facter/facter/lib/src/util/windows/wsa.cc +69 -0
- data/ext/facter/facter/lib/src/util/yaml.cc +72 -0
- data/ext/facter/facter/lib/tasks/spec.rake +26 -0
- data/ext/facter/facter/lib/tests/CMakeLists.txt +172 -0
- data/ext/facter/facter/lib/tests/collection_fixture.cc +15 -0
- data/ext/facter/facter/lib/tests/collection_fixture.hpp +19 -0
- data/ext/facter/facter/lib/tests/cwrapper.cc +22 -0
- data/ext/facter/facter/lib/tests/facts/array_value.cc +140 -0
- data/ext/facter/facter/lib/tests/facts/boolean_value.cc +67 -0
- data/ext/facter/facter/lib/tests/facts/cache.cc +100 -0
- data/ext/facter/facter/lib/tests/facts/collection.cc +576 -0
- data/ext/facter/facter/lib/tests/facts/double_value.cc +40 -0
- data/ext/facter/facter/lib/tests/facts/external/json_resolver.cc +62 -0
- data/ext/facter/facter/lib/tests/facts/external/posix/execution_resolver.cc +69 -0
- data/ext/facter/facter/lib/tests/facts/external/text_resolver.cc +46 -0
- data/ext/facter/facter/lib/tests/facts/external/windows/execution_resolver.cc +69 -0
- data/ext/facter/facter/lib/tests/facts/external/windows/powershell_resolver.cc +122 -0
- data/ext/facter/facter/lib/tests/facts/external/yaml_resolver.cc +70 -0
- data/ext/facter/facter/lib/tests/facts/integer_value.cc +69 -0
- data/ext/facter/facter/lib/tests/facts/linux/dmi_resolver.cc +116 -0
- data/ext/facter/facter/lib/tests/facts/linux/filesystem_resolver.cc +13 -0
- data/ext/facter/facter/lib/tests/facts/linux/processor_fixture.cc +259 -0
- data/ext/facter/facter/lib/tests/facts/linux/processor_fixture.hpp +77 -0
- data/ext/facter/facter/lib/tests/facts/linux/processor_resolver.cc +312 -0
- data/ext/facter/facter/lib/tests/facts/linux/virtualization_resolver.cc +48 -0
- data/ext/facter/facter/lib/tests/facts/map_value.cc +116 -0
- data/ext/facter/facter/lib/tests/facts/posix/collection.cc +39 -0
- data/ext/facter/facter/lib/tests/facts/posix/uptime_resolver.cc +52 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/augeas_resolver.cc +58 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/disk_resolver.cc +114 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/dmi_resolver.cc +152 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/filesystem_resolver.cc +206 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/identity_resolver.cc +83 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/kernel_resolver.cc +61 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/ldom_resolver.cc +86 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/memory_resolver.cc +135 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/networking_resolver.cc +507 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/operating_system_resolver.cc +247 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/processor_resolver.cc +157 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/ruby_resolver.cc +74 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/ssh_resolver.cc +96 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/system_profiler_resolver.cc +135 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/timezone_resolver.cc +49 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/uptime_resolver.cc +151 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/virtualization_resolver.cc +175 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/xen_resolver.cc +100 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/zfs_resolver.cc +65 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/zone_resolver.cc +122 -0
- data/ext/facter/facter/lib/tests/facts/resolvers/zpool_resolver.cc +69 -0
- data/ext/facter/facter/lib/tests/facts/schema.cc +779 -0
- data/ext/facter/facter/lib/tests/facts/string_value.cc +270 -0
- data/ext/facter/facter/lib/tests/facts/windows/collection.cc +60 -0
- data/ext/facter/facter/lib/tests/facts/windows/networking_resolver.cc +217 -0
- data/ext/facter/facter/lib/tests/fixtures.cc +62 -0
- data/ext/facter/facter/lib/tests/fixtures.hpp.in +27 -0
- data/ext/facter/facter/lib/tests/fixtures/execution/with space/command_with_space.bat +2 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/json/facts.json +12 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/json/invalid.json +1 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/ordering/bar/foo.yaml +1 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/ordering/foo/foo.yaml +1 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/posix/execution/error_message +4 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/posix/execution/facts +5 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/posix/execution/failed +3 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/posix/execution/not_executable +1 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/text/facts.txt +4 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/execution/error_message.bat +4 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/execution/facts.bat +4 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/execution/failed.cmd +2 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/execution/not_executable +1 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/execution/ruby_script.rb +1 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/powershell/error_message.ps1 +3 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/powershell/facts.ps1 +4 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/powershell/failed.ps1 +2 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/powershell/json.ps1 +21 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/powershell/not_executable +1 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/windows/powershell/yaml.ps1 +18 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/yaml/facts.yaml +15 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/yaml/invalid.yaml +1 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/z/303/266/facts.rb +3 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/external/z/303/266/facts.txt +1 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/linux/cloud/azure +3 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/linux/cloud/azure-unknown +3 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/linux/cloud/not-azure +0 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/linux/dmidecode/full.txt +83 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/linux/dmidecode/full_alternative.txt +83 -0
- data/ext/facter/facter/lib/tests/fixtures/facts/linux/dmidecode/none.txt +2 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/100_resolutions.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/101_resolutions.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/aggregate.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/aggregate_invalid_require.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/aggregate_with_block.rb +30 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/aggregate_with_cycle.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/aggregate_with_invalid_merge.rb +13 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/aggregate_with_merge.rb +23 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/aggregate_with_require.rb +16 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/array_confine.rb +6 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/array_fact.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/bad_command.rb +19 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/bad_syntax.rb +2 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/bignum_fact_value.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/block_confine.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/block_false_confine.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/block_nil_confine.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/block_true_confine.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/boolean_false_confine.rb +6 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/boolean_false_fact.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/boolean_true_confine.rb +6 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/boolean_true_fact.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/command_with_space.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/confine_missing_fact.rb +22 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/confine_weight.rb +20 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/custom_dir/expect_network_init.rb +15 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/cycle.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/debug.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/debugging.rb +14 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/debugonce.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/define_aggregate_fact.rb +13 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/define_fact.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/double_fact.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/empty_command.rb +3 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/empty_fact.rb +1 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/empty_fact_with_value.rb +1 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/empty_setcode_command.rb +3 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/exec.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/execute_on_fail_raise.rb +17 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/execute_on_fail_value.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/execute_timeout.rb +1 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/execution_failure.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/existing_aggregate_resolution.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/existing_simple_resolution.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/fact.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/facter.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/facterversion.rb +17 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/hash_fact.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/hash_with_non_string_key.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/integer_fact.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/log_exception.rb +21 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/lookup.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/multi_confine.rb +6 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/named_resolution.rb +13 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/negative_number.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/nil_fact.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/nonexistent_command.rb +21 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/on_message.rb +16 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/range_confine.rb +6 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/regexp_confine.rb +6 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/ruby.rb +6 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/simple.rb +11 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/simple_command.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/simple_confine.rb +6 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/simple_resolution.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/single_allocation.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/stderr_output.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/string_fact.rb +5 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/timeout.rb +10 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/trace.rb +22 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/uni/341/220/201dir/customfacts/342/204/242.rb +6 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/uses_exit_code.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/value.rb +6 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/version.rb +2 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/warn.rb +7 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/warnonce.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/weight.rb +20 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/weight_option.rb +17 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/which.rb +9 -0
- data/ext/facter/facter/lib/tests/fixtures/ruby/windows/ole.rb +7 -0
- data/ext/facter/facter/lib/tests/java/facter.cc +69 -0
- data/ext/facter/facter/lib/tests/log_capture.cc +29 -0
- data/ext/facter/facter/lib/tests/log_capture.hpp +35 -0
- data/ext/facter/facter/lib/tests/logging/logging.cc +69 -0
- data/ext/facter/facter/lib/tests/main.cc +20 -0
- data/ext/facter/facter/lib/tests/mock_server.cc +44 -0
- data/ext/facter/facter/lib/tests/mock_server.hpp +25 -0
- data/ext/facter/facter/lib/tests/ruby/ruby.cc +634 -0
- data/ext/facter/facter/lib/tests/ruby/ruby_dirfacts.cc +35 -0
- data/ext/facter/facter/lib/tests/ruby/ruby_helper.cc +41 -0
- data/ext/facter/facter/lib/tests/ruby/ruby_helper.hpp +8 -0
- data/ext/facter/facter/lib/tests/ruby/windows/ruby.cc +53 -0
- data/ext/facter/facter/lib/tests/util/bsd/scoped_ifaddrs.cc +10 -0
- data/ext/facter/facter/lib/tests/util/posix/scoped_addrinfo.cc +11 -0
- data/ext/facter/facter/lib/tests/util/posix/scoped_bio.cc +12 -0
- data/ext/facter/facter/lib/tests/util/posix/scoped_descriptor.cc +22 -0
- data/ext/facter/facter/lib/tests/util/string.cc +291 -0
- data/ext/facter/facter/lib/version.h.in +28 -0
- data/ext/facter/facter/locales/CMakeLists.txt +7 -0
- data/ext/facter/facter/locales/FACTER.pot +1529 -0
- data/ext/facter/facter/man/man8/facter.8 +205 -0
- data/ext/facter/facter/scripts/cpplint.py +4754 -0
- data/ext/facter/facter/scripts/travis_target.sh +83 -0
- data/ext/facter/facter/tasks/ci.rake +22 -0
- data/ext/facter/leatherman/CHANGELOG.md +423 -0
- data/ext/facter/leatherman/CMakeLists.txt +143 -0
- data/ext/facter/leatherman/CONTRIBUTING.md +98 -0
- data/ext/facter/leatherman/LICENSE +17 -0
- data/ext/facter/leatherman/LeathermanConfig.cmake.in +57 -0
- data/ext/facter/leatherman/LeathermanConfigVersion.cmake.in +11 -0
- data/ext/facter/leatherman/MAINTAINERS +28 -0
- data/ext/facter/leatherman/README.md +416 -0
- data/ext/facter/leatherman/appveyor.yml +40 -0
- data/ext/facter/leatherman/catch/CMakeLists.txt +1 -0
- data/ext/facter/leatherman/cmake/FindICU.cmake +690 -0
- data/ext/facter/leatherman/cmake/GetGitRevisionDescription.cmake +130 -0
- data/ext/facter/leatherman/cmake/GetGitRevisionDescription.cmake.in +38 -0
- data/ext/facter/leatherman/cmake/cflags.cmake +110 -0
- data/ext/facter/leatherman/cmake/generate_translations.cmake +17 -0
- data/ext/facter/leatherman/cmake/internal.cmake +241 -0
- data/ext/facter/leatherman/cmake/leatherman.cmake.in +369 -0
- data/ext/facter/leatherman/cmake/leatherman_config.cmake +80 -0
- data/ext/facter/leatherman/cmake/normalize_pot.cmake +17 -0
- data/ext/facter/leatherman/cmake/options.cmake +21 -0
- data/ext/facter/leatherman/cmake/pod2man.cmake +36 -0
- data/ext/facter/leatherman/curl/CMakeLists.txt +42 -0
- data/ext/facter/leatherman/curl/inc/leatherman/curl/client.hpp +441 -0
- data/ext/facter/leatherman/curl/inc/leatherman/curl/request.hpp +130 -0
- data/ext/facter/leatherman/curl/inc/leatherman/curl/response.hpp +80 -0
- data/ext/facter/leatherman/curl/src/client.cc +575 -0
- data/ext/facter/leatherman/curl/src/request.cc +112 -0
- data/ext/facter/leatherman/curl/src/response.cc +62 -0
- data/ext/facter/leatherman/curl/tests/CMakeLists.txt +22 -0
- data/ext/facter/leatherman/curl/tests/client_test.cc +615 -0
- data/ext/facter/leatherman/curl/tests/fixtures.cc +27 -0
- data/ext/facter/leatherman/curl/tests/fixtures.hpp +31 -0
- data/ext/facter/leatherman/curl/tests/mock_curl.cc +421 -0
- data/ext/facter/leatherman/curl/tests/mock_curl.hpp +85 -0
- data/ext/facter/leatherman/curl/tests/request_test.cc +87 -0
- data/ext/facter/leatherman/curl/tests/response_test.cc +60 -0
- data/ext/facter/leatherman/dynamic_library/CMakeLists.txt +43 -0
- data/ext/facter/leatherman/dynamic_library/inc/leatherman/dynamic_library/dynamic_library.hpp +122 -0
- data/ext/facter/leatherman/dynamic_library/src/dynamic_library.cc +57 -0
- data/ext/facter/leatherman/dynamic_library/src/posix/dynamic_library.cc +91 -0
- data/ext/facter/leatherman/dynamic_library/src/windows/dynamic_library.cc +128 -0
- data/ext/facter/leatherman/dynamic_library/tests/dynamic_library_tests.cc +98 -0
- data/ext/facter/leatherman/dynamic_library/tests/fixtures.hpp.in +3 -0
- data/ext/facter/leatherman/dynamic_library/tests/test-lib/goodbye.cc +5 -0
- data/ext/facter/leatherman/dynamic_library/tests/test-lib/hello.cc +7 -0
- data/ext/facter/leatherman/execution/CMakeLists.txt +65 -0
- data/ext/facter/leatherman/execution/inc/leatherman/execution/execution.hpp +488 -0
- data/ext/facter/leatherman/execution/src/execution.cc +507 -0
- data/ext/facter/leatherman/execution/src/posix/execution.cc +575 -0
- data/ext/facter/leatherman/execution/src/posix/generic/platform.cc +30 -0
- data/ext/facter/leatherman/execution/src/posix/platform.hpp +15 -0
- data/ext/facter/leatherman/execution/src/posix/solaris/platform.cc +197 -0
- data/ext/facter/leatherman/execution/src/windows/execution.cc +696 -0
- data/ext/facter/leatherman/execution/tests/fixtures.hpp.in +2 -0
- data/ext/facter/leatherman/execution/tests/fixtures/echo_pid +2 -0
- data/ext/facter/leatherman/execution/tests/fixtures/error_message +5 -0
- data/ext/facter/leatherman/execution/tests/fixtures/execution/selfkill.sh +3 -0
- data/ext/facter/leatherman/execution/tests/fixtures/execution/sleep.sh +3 -0
- data/ext/facter/leatherman/execution/tests/fixtures/facts +5 -0
- data/ext/facter/leatherman/execution/tests/fixtures/failed +3 -0
- data/ext/facter/leatherman/execution/tests/fixtures/ls/crlf.txt +3 -0
- data/ext/facter/leatherman/execution/tests/fixtures/ls/file1.txt +1 -0
- data/ext/facter/leatherman/execution/tests/fixtures/ls/file2.txt +1 -0
- data/ext/facter/leatherman/execution/tests/fixtures/ls/file3.txt +1 -0
- data/ext/facter/leatherman/execution/tests/fixtures/ls/file4.txt +7 -0
- data/ext/facter/leatherman/execution/tests/fixtures/not_executable +1 -0
- data/ext/facter/leatherman/execution/tests/fixtures/windows/error_message.bat +6 -0
- data/ext/facter/leatherman/execution/tests/fixtures/windows/facts.bat +4 -0
- data/ext/facter/leatherman/execution/tests/fixtures/windows/failed.cmd +2 -0
- data/ext/facter/leatherman/execution/tests/fixtures/windows/not_executable +1 -0
- data/ext/facter/leatherman/execution/tests/fixtures/windows/ruby_script.rb +1 -0
- data/ext/facter/leatherman/execution/tests/log_capture.cc +29 -0
- data/ext/facter/leatherman/execution/tests/log_capture.hpp +35 -0
- data/ext/facter/leatherman/execution/tests/lth_cat.cc +38 -0
- data/ext/facter/leatherman/execution/tests/lth_cat.hpp +9 -0
- data/ext/facter/leatherman/execution/tests/posix/execution.cc +728 -0
- data/ext/facter/leatherman/execution/tests/posix/solaris/execution.cc +54 -0
- data/ext/facter/leatherman/execution/tests/windows/execution.cc +787 -0
- data/ext/facter/leatherman/file_util/CMakeLists.txt +18 -0
- data/ext/facter/leatherman/file_util/inc/leatherman/file_util/directory.hpp +28 -0
- data/ext/facter/leatherman/file_util/inc/leatherman/file_util/file.hpp +95 -0
- data/ext/facter/leatherman/file_util/src/directory.cc +51 -0
- data/ext/facter/leatherman/file_util/src/file.cc +131 -0
- data/ext/facter/leatherman/file_util/tests/directory_utils_test.cc +89 -0
- data/ext/facter/leatherman/file_util/tests/file_utils_test.cc +197 -0
- data/ext/facter/leatherman/file_util/tests/fixtures.cc +37 -0
- data/ext/facter/leatherman/file_util/tests/fixtures.hpp +39 -0
- data/ext/facter/leatherman/json_container/CMakeLists.txt +11 -0
- data/ext/facter/leatherman/json_container/README.md +108 -0
- data/ext/facter/leatherman/json_container/inc/leatherman/json_container/json_container.hpp +436 -0
- data/ext/facter/leatherman/json_container/src/json_container.cc +646 -0
- data/ext/facter/leatherman/json_container/tests/json_container_test.cc +985 -0
- data/ext/facter/leatherman/locale/CMakeLists.txt +46 -0
- data/ext/facter/leatherman/locale/disabled/locale.cc +38 -0
- data/ext/facter/leatherman/locale/inc/leatherman/locale/locale.hpp +263 -0
- data/ext/facter/leatherman/locale/locales/CMakeLists.txt +6 -0
- data/ext/facter/leatherman/locale/locales/fr.po +40 -0
- data/ext/facter/leatherman/locale/locales/leatherman_locale.pot +41 -0
- data/ext/facter/leatherman/locale/src/locale.cc +95 -0
- data/ext/facter/leatherman/locale/tests/format.cc +117 -0
- data/ext/facter/leatherman/locale/tests/locale.cc +190 -0
- data/ext/facter/leatherman/locales/CMakeLists.txt +7 -0
- data/ext/facter/leatherman/locales/leatherman.pot +722 -0
- data/ext/facter/leatherman/logging/CMakeLists.txt +43 -0
- data/ext/facter/leatherman/logging/inc/leatherman/logging/logging.hpp +264 -0
- data/ext/facter/leatherman/logging/locales/CMakeLists.txt +6 -0
- data/ext/facter/leatherman/logging/locales/fr.po +72 -0
- data/ext/facter/leatherman/logging/locales/leatherman_logging.pot +72 -0
- data/ext/facter/leatherman/logging/src/logging.cc +227 -0
- data/ext/facter/leatherman/logging/src/posix/logging.cc +39 -0
- data/ext/facter/leatherman/logging/src/windows/logging.cc +52 -0
- data/ext/facter/leatherman/logging/tests/logging.cc +118 -0
- data/ext/facter/leatherman/logging/tests/logging.hpp +88 -0
- data/ext/facter/leatherman/logging/tests/logging_i18n.cc +103 -0
- data/ext/facter/leatherman/logging/tests/logging_on_message.cc +61 -0
- data/ext/facter/leatherman/logging/tests/logging_stream.cc +159 -0
- data/ext/facter/leatherman/logging/tests/logging_stream_lines.cc +172 -0
- data/ext/facter/leatherman/logging/tests/posix/logging.cc +23 -0
- data/ext/facter/leatherman/logging/tests/windows/logging.cc +13 -0
- data/ext/facter/leatherman/nowide/CMakeLists.txt +7 -0
- data/ext/facter/leatherman/rapidjson/CMakeLists.txt +1 -0
- data/ext/facter/leatherman/ruby/CMakeLists.txt +26 -0
- data/ext/facter/leatherman/ruby/inc/leatherman/ruby/api.hpp +744 -0
- data/ext/facter/leatherman/ruby/src/api.cc +527 -0
- data/ext/facter/leatherman/ruby/src/posix/api.cc +14 -0
- data/ext/facter/leatherman/ruby/src/windows/api.cc +20 -0
- data/ext/facter/leatherman/ruby/tests/api-test.cc +206 -0
- data/ext/facter/leatherman/scripts/cpplint.py +6323 -0
- data/ext/facter/leatherman/scripts/travis_target.sh +79 -0
- data/ext/facter/leatherman/tests/CMakeLists.txt +22 -0
- data/ext/facter/leatherman/tests/main.cc +17 -0
- data/ext/facter/leatherman/util/CMakeLists.txt +36 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/environment.hpp +69 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/option_set.hpp +228 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/posix/scoped_descriptor.hpp +32 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/regex.hpp +80 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/scope_exit.hpp +62 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/scoped_env.hpp +35 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/scoped_resource.hpp +130 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/strings.hpp +54 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/time.hpp +36 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/timer.hpp +43 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/uri.hpp +23 -0
- data/ext/facter/leatherman/util/inc/leatherman/util/windows/scoped_handle.hpp +32 -0
- data/ext/facter/leatherman/util/src/environment.cc +29 -0
- data/ext/facter/leatherman/util/src/posix/environment.cc +75 -0
- data/ext/facter/leatherman/util/src/posix/scoped_descriptor.cc +23 -0
- data/ext/facter/leatherman/util/src/posix/time.cc +9 -0
- data/ext/facter/leatherman/util/src/scope_exit.cc +43 -0
- data/ext/facter/leatherman/util/src/scoped_env.cc +37 -0
- data/ext/facter/leatherman/util/src/strings.cc +41 -0
- data/ext/facter/leatherman/util/src/time.cc +49 -0
- data/ext/facter/leatherman/util/src/uri.cc +75 -0
- data/ext/facter/leatherman/util/src/windows/environment.cc +75 -0
- data/ext/facter/leatherman/util/src/windows/scoped_handle.cc +24 -0
- data/ext/facter/leatherman/util/src/windows/time.cc +10 -0
- data/ext/facter/leatherman/util/tests/environment.cc +90 -0
- data/ext/facter/leatherman/util/tests/option_set.cc +234 -0
- data/ext/facter/leatherman/util/tests/posix/environment.cc +36 -0
- data/ext/facter/leatherman/util/tests/scoped_env.cc +52 -0
- data/ext/facter/leatherman/util/tests/strings_test.cc +71 -0
- data/ext/facter/leatherman/util/tests/timer.cc +41 -0
- data/ext/facter/leatherman/util/tests/uri.cc +104 -0
- data/ext/facter/leatherman/util/tests/windows/environment.cc +30 -0
- data/ext/facter/leatherman/vendor/catch-1.4.0.zip +0 -0
- data/ext/facter/leatherman/vendor/nowide/build/Jamfile.v2 +26 -0
- data/ext/facter/leatherman/vendor/nowide/doc/Doxyfile +1632 -0
- data/ext/facter/leatherman/vendor/nowide/doc/gendoc.sh +11 -0
- data/ext/facter/leatherman/vendor/nowide/doc/main.txt +346 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/args.hpp +167 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/cenv.hpp +126 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/config.hpp +54 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/convert.hpp +154 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/cstdio.hpp +101 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/cstdlib.hpp +16 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/filebuf.hpp +415 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/fstream.hpp +283 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/integration/filesystem.hpp +28 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/iostream.hpp +99 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/stackstring.hpp +154 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/system.hpp +46 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/utf8_codecvt.hpp +499 -0
- data/ext/facter/leatherman/vendor/nowide/include/boost/nowide/windows.hpp +39 -0
- data/ext/facter/leatherman/vendor/nowide/index.html +16 -0
- data/ext/facter/leatherman/vendor/nowide/src/iostream.cpp +261 -0
- data/ext/facter/leatherman/vendor/nowide/standalone/CMakeLists.txt +104 -0
- data/ext/facter/leatherman/vendor/nowide/standalone/MinGW.cmake +9 -0
- data/ext/facter/leatherman/vendor/nowide/standalone/config.hpp +37 -0
- data/ext/facter/leatherman/vendor/nowide/standalone/convert +34 -0
- data/ext/facter/leatherman/vendor/nowide/standalone/encoding_errors.hpp +58 -0
- data/ext/facter/leatherman/vendor/nowide/standalone/encoding_utf.hpp +84 -0
- data/ext/facter/leatherman/vendor/nowide/standalone/run_convert_and_build.sh +19 -0
- data/ext/facter/leatherman/vendor/nowide/standalone/scoped_ptr.hpp +93 -0
- data/ext/facter/leatherman/vendor/nowide/standalone/utf.hpp +469 -0
- data/ext/facter/leatherman/vendor/nowide/template.hpp +19 -0
- data/ext/facter/leatherman/vendor/nowide/test/Jamfile.v2 +43 -0
- data/ext/facter/leatherman/vendor/nowide/test/test.hpp +25 -0
- data/ext/facter/leatherman/vendor/nowide/test/test_codecvt.cpp +254 -0
- data/ext/facter/leatherman/vendor/nowide/test/test_convert.cpp +101 -0
- data/ext/facter/leatherman/vendor/nowide/test/test_env.cpp +49 -0
- data/ext/facter/leatherman/vendor/nowide/test/test_fs.cpp +48 -0
- data/ext/facter/leatherman/vendor/nowide/test/test_fstream.cpp +184 -0
- data/ext/facter/leatherman/vendor/nowide/test/test_iostream.cpp +52 -0
- data/ext/facter/leatherman/vendor/nowide/test/test_stdio.cpp +60 -0
- data/ext/facter/leatherman/vendor/nowide/test/test_system.cpp +91 -0
- data/ext/facter/leatherman/vendor/rapidjson-1.0.2.zip +0 -0
- data/ext/facter/leatherman/windows/CMakeLists.txt +27 -0
- data/ext/facter/leatherman/windows/inc/leatherman/windows/file_util.hpp +23 -0
- data/ext/facter/leatherman/windows/inc/leatherman/windows/process.hpp +22 -0
- data/ext/facter/leatherman/windows/inc/leatherman/windows/registry.hpp +56 -0
- data/ext/facter/leatherman/windows/inc/leatherman/windows/system_error.hpp +23 -0
- data/ext/facter/leatherman/windows/inc/leatherman/windows/user.hpp +30 -0
- data/ext/facter/leatherman/windows/inc/leatherman/windows/windows.hpp +10 -0
- data/ext/facter/leatherman/windows/inc/leatherman/windows/wmi.hpp +188 -0
- data/ext/facter/leatherman/windows/src/file_util.cc +28 -0
- data/ext/facter/leatherman/windows/src/process.cc +42 -0
- data/ext/facter/leatherman/windows/src/registry.cc +96 -0
- data/ext/facter/leatherman/windows/src/system_error.cc +33 -0
- data/ext/facter/leatherman/windows/src/user.cc +76 -0
- data/ext/facter/leatherman/windows/src/wmi.cc +208 -0
- data/ext/facter/leatherman/windows/tests/file_utils_test.cc +13 -0
- metadata +1052 -841
- data/COMMITTERS.md +0 -185
- data/CONTRIBUTING.md +0 -91
- data/Gemfile +0 -69
- data/LICENSE +0 -15
- data/README.md +0 -65
- data/Rakefile +0 -46
- data/bin/facter +0 -20
- data/etc/facter.conf +0 -5
- data/ext/build_defaults.yaml +0 -9
- data/ext/debian/changelog.erb +0 -59
- data/ext/debian/control +0 -15
- data/ext/debian/copyright +0 -19
- data/ext/debian/docs +0 -1
- data/ext/debian/rules +0 -10
- data/ext/facter-diff +0 -74
- data/ext/ips/facter.p5m.erb +0 -10
- data/ext/ips/rules +0 -7
- data/ext/ips/transforms +0 -18
- data/ext/osx/file_mapping.yaml +0 -32
- data/ext/osx/preflight.erb +0 -33
- data/ext/osx/prototype.plist.erb +0 -38
- data/ext/project_data.yaml +0 -31
- data/ext/redhat/facter.spec.erb +0 -223
- data/ext/solaris/pkginfo +0 -7
- data/install.rb +0 -380
- data/lib/facter.rb +0 -261
- data/lib/facter/Cfkey.rb +0 -42
- data/lib/facter/application.rb +0 -206
- data/lib/facter/architecture.rb +0 -50
- data/lib/facter/augeasversion.rb +0 -28
- data/lib/facter/blockdevices.rb +0 -105
- data/lib/facter/core/aggregate.rb +0 -220
- data/lib/facter/core/directed_graph.rb +0 -46
- data/lib/facter/core/execution.rb +0 -123
- data/lib/facter/core/execution/base.rb +0 -81
- data/lib/facter/core/execution/posix.rb +0 -50
- data/lib/facter/core/execution/windows.rb +0 -57
- data/lib/facter/core/logging.rb +0 -197
- data/lib/facter/core/resolvable.rb +0 -94
- data/lib/facter/core/suitable.rb +0 -113
- data/lib/facter/dhcp_servers.rb +0 -45
- data/lib/facter/domain.rb +0 -99
- data/lib/facter/ec2.rb +0 -68
- data/lib/facter/ec2/rest.rb +0 -137
- data/lib/facter/facterversion.rb +0 -15
- data/lib/facter/filesystems.rb +0 -45
- data/lib/facter/fqdn.rb +0 -24
- data/lib/facter/gce.rb +0 -16
- data/lib/facter/gce/metadata.rb +0 -87
- data/lib/facter/gid.rb +0 -25
- data/lib/facter/hardwareisa.rb +0 -20
- data/lib/facter/hardwaremodel.rb +0 -67
- data/lib/facter/hostname.rb +0 -31
- data/lib/facter/id.rb +0 -21
- data/lib/facter/interfaces.rb +0 -58
- data/lib/facter/ipaddress.rb +0 -169
- data/lib/facter/ipaddress6.rb +0 -82
- data/lib/facter/iphostnumber.rb +0 -29
- data/lib/facter/kernel.rb +0 -22
- data/lib/facter/kernelmajversion.rb +0 -23
- data/lib/facter/kernelrelease.rb +0 -45
- data/lib/facter/kernelversion.rb +0 -22
- data/lib/facter/ldom.rb +0 -51
- data/lib/facter/lsbdistcodename.rb +0 -20
- data/lib/facter/lsbdistdescription.rb +0 -21
- data/lib/facter/lsbdistid.rb +0 -20
- data/lib/facter/lsbdistrelease.rb +0 -20
- data/lib/facter/lsbmajdistrelease.rb +0 -22
- data/lib/facter/lsbminordistrelease.rb +0 -22
- data/lib/facter/lsbrelease.rb +0 -20
- data/lib/facter/macaddress.rb +0 -99
- data/lib/facter/macosx.rb +0 -56
- data/lib/facter/manufacturer.rb +0 -68
- data/lib/facter/memory.rb +0 -168
- data/lib/facter/netmask.rb +0 -43
- data/lib/facter/network.rb +0 -20
- data/lib/facter/operatingsystem.rb +0 -24
- data/lib/facter/operatingsystem/base.rb +0 -61
- data/lib/facter/operatingsystem/cumuluslinux.rb +0 -27
- data/lib/facter/operatingsystem/implementation.rb +0 -33
- data/lib/facter/operatingsystem/linux.rb +0 -511
- data/lib/facter/operatingsystem/osreleaselinux.rb +0 -28
- data/lib/facter/operatingsystem/sunos.rb +0 -54
- data/lib/facter/operatingsystem/vmkernel.rb +0 -11
- data/lib/facter/operatingsystem/windows.rb +0 -43
- data/lib/facter/operatingsystemmajrelease.rb +0 -31
- data/lib/facter/operatingsystemrelease.rb +0 -29
- data/lib/facter/os.rb +0 -98
- data/lib/facter/osfamily.rb +0 -18
- data/lib/facter/partitions.rb +0 -39
- data/lib/facter/path.rb +0 -14
- data/lib/facter/physicalprocessorcount.rb +0 -27
- data/lib/facter/processor.rb +0 -52
- data/lib/facter/processors.rb +0 -66
- data/lib/facter/processors/os.rb +0 -244
- data/lib/facter/ps.rb +0 -31
- data/lib/facter/puppetversion.rb +0 -20
- data/lib/facter/rackspace.rb +0 -37
- data/lib/facter/rubyplatform.rb +0 -12
- data/lib/facter/rubysitedir.rb +0 -15
- data/lib/facter/rubyversion.rb +0 -12
- data/lib/facter/selinux.rb +0 -154
- data/lib/facter/ssh.rb +0 -73
- data/lib/facter/system32.rb +0 -21
- data/lib/facter/system_uptime.rb +0 -44
- data/lib/facter/timezone.rb +0 -14
- data/lib/facter/uniqueid.rb +0 -4
- data/lib/facter/uptime.rb +0 -16
- data/lib/facter/uptime_days.rb +0 -13
- data/lib/facter/uptime_hours.rb +0 -13
- data/lib/facter/uptime_seconds.rb +0 -20
- data/lib/facter/util/architecture.rb +0 -19
- data/lib/facter/util/collection.rb +0 -161
- data/lib/facter/util/composite_loader.rb +0 -12
- data/lib/facter/util/config.rb +0 -88
- data/lib/facter/util/confine.rb +0 -66
- data/lib/facter/util/dhcp_servers.rb +0 -58
- data/lib/facter/util/directory_loader.rb +0 -88
- data/lib/facter/util/ec2.rb +0 -106
- data/lib/facter/util/fact.rb +0 -204
- data/lib/facter/util/file_read.rb +0 -37
- data/lib/facter/util/formatter.rb +0 -39
- data/lib/facter/util/ip.rb +0 -340
- data/lib/facter/util/ip/windows.rb +0 -215
- data/lib/facter/util/loader.rb +0 -155
- data/lib/facter/util/macaddress.rb +0 -43
- data/lib/facter/util/macosx.rb +0 -73
- data/lib/facter/util/manufacturer.rb +0 -99
- data/lib/facter/util/memory.rb +0 -228
- data/lib/facter/util/netmask.rb +0 -40
- data/lib/facter/util/normalization.rb +0 -94
- data/lib/facter/util/nothing_loader.rb +0 -12
- data/lib/facter/util/operatingsystem.rb +0 -21
- data/lib/facter/util/parser.rb +0 -168
- data/lib/facter/util/partitions.rb +0 -47
- data/lib/facter/util/partitions/linux.rb +0 -71
- data/lib/facter/util/partitions/openbsd.rb +0 -40
- data/lib/facter/util/plist.rb +0 -24
- data/lib/facter/util/plist/generator.rb +0 -228
- data/lib/facter/util/plist/parser.rb +0 -226
- data/lib/facter/util/posix.rb +0 -16
- data/lib/facter/util/processor.rb +0 -289
- data/lib/facter/util/registry.rb +0 -11
- data/lib/facter/util/resolution.rb +0 -160
- data/lib/facter/util/solaris_zones.rb +0 -158
- data/lib/facter/util/unix_root.rb +0 -5
- data/lib/facter/util/uptime.rb +0 -83
- data/lib/facter/util/values.rb +0 -109
- data/lib/facter/util/virtual.rb +0 -220
- data/lib/facter/util/vlans.rb +0 -21
- data/lib/facter/util/windows.rb +0 -10
- data/lib/facter/util/windows/api_types.rb +0 -135
- data/lib/facter/util/windows/dir.rb +0 -43
- data/lib/facter/util/windows/error.rb +0 -87
- data/lib/facter/util/windows/process.rb +0 -294
- data/lib/facter/util/windows/user.rb +0 -186
- data/lib/facter/util/windows_root.rb +0 -7
- data/lib/facter/util/wmi.rb +0 -49
- data/lib/facter/util/xendomains.rb +0 -28
- data/lib/facter/version.rb +0 -86
- data/lib/facter/virtual.rb +0 -339
- data/lib/facter/vlans.rb +0 -17
- data/lib/facter/xendomains.rb +0 -20
- data/lib/facter/zfs_version.rb +0 -14
- data/lib/facter/zonename.rb +0 -6
- data/lib/facter/zones.rb +0 -18
- data/lib/facter/zpool_version.rb +0 -10
- data/spec/fixtures/cpuinfo/amd64dual +0 -57
- data/spec/fixtures/cpuinfo/amd64dual-grep +0 -2
- data/spec/fixtures/cpuinfo/amd64quad +0 -79
- data/spec/fixtures/cpuinfo/amd64solo +0 -23
- data/spec/fixtures/cpuinfo/amd64tri +0 -86
- data/spec/fixtures/cpuinfo/amd64twentyfour +0 -600
- data/spec/fixtures/cpuinfo/amd64twentyfour-grep +0 -24
- data/spec/fixtures/cpuinfo/bbg3-armel +0 -12
- data/spec/fixtures/cpuinfo/beaglexm-armel +0 -12
- data/spec/fixtures/cpuinfo/panda-armel +0 -17
- data/spec/fixtures/cpuinfo/ppc64 +0 -19
- data/spec/fixtures/cpuinfo/ppc64le +0 -15
- data/spec/fixtures/cpuinfo/sparc +0 -10
- data/spec/fixtures/cpuinfo/two_multicore-grep +0 -4
- data/spec/fixtures/cpuinfo/two_singlecore-grep +0 -2
- data/spec/fixtures/hpux/machinfo/hppa-rp4440 +0 -26
- data/spec/fixtures/hpux/machinfo/ia64-rx2620 +0 -49
- data/spec/fixtures/hpux/machinfo/ia64-rx6600 +0 -26
- data/spec/fixtures/hpux/machinfo/ia64-rx8640 +0 -53
- data/spec/fixtures/hpux/machinfo/superdome-server-SD32B +0 -53
- data/spec/fixtures/hpux/machinfo/superdome2-16s +0 -31
- data/spec/fixtures/hpux/sched.models +0 -174
- data/spec/fixtures/hpux/unistd.h +0 -1534
- data/spec/fixtures/ifconfig/bsd_ifconfig_all_with_multiple_interfaces +0 -18
- data/spec/fixtures/ifconfig/centos_5_5 +0 -17
- data/spec/fixtures/ifconfig/centos_5_5_eth0 +0 -8
- data/spec/fixtures/ifconfig/darwin_10_3_0 +0 -26
- data/spec/fixtures/ifconfig/darwin_10_3_0_en0 +0 -6
- data/spec/fixtures/ifconfig/darwin_10_6_4 +0 -28
- data/spec/fixtures/ifconfig/darwin_10_6_4_en1 +0 -6
- data/spec/fixtures/ifconfig/darwin_10_6_6_dualstack +0 -8
- data/spec/fixtures/ifconfig/darwin_10_6_6_dualstack_en1 +0 -7
- data/spec/fixtures/ifconfig/darwin_9_8_0 +0 -26
- data/spec/fixtures/ifconfig/darwin_9_8_0_en0 +0 -6
- data/spec/fixtures/ifconfig/darwin_ifconfig_all_with_multiple_interfaces +0 -23
- data/spec/fixtures/ifconfig/fedora_10 +0 -36
- data/spec/fixtures/ifconfig/fedora_10_eth0 +0 -9
- data/spec/fixtures/ifconfig/fedora_13 +0 -18
- data/spec/fixtures/ifconfig/fedora_13_eth0 +0 -9
- data/spec/fixtures/ifconfig/fedora_8 +0 -38
- data/spec/fixtures/ifconfig/fedora_8_eth0 +0 -9
- data/spec/fixtures/ifconfig/freebsd_6_0 +0 -12
- data/spec/fixtures/ifconfig/ifconfig_net_tools_1.60.txt +0 -19
- data/spec/fixtures/ifconfig/ifconfig_ubuntu_1204.txt +0 -16
- data/spec/fixtures/ifconfig/linux_ifconfig_all_with_multiple_interfaces +0 -19
- data/spec/fixtures/ifconfig/linux_ifconfig_all_with_multiple_interfaces_and_fe80 +0 -19
- data/spec/fixtures/ifconfig/linux_ifconfig_all_with_multiple_interfaces_and_no_public_ipv6 +0 -18
- data/spec/fixtures/ifconfig/linux_ifconfig_no_addr +0 -19
- data/spec/fixtures/ifconfig/linux_ifconfig_no_mac +0 -8
- data/spec/fixtures/ifconfig/linux_ifconfig_venet +0 -24
- data/spec/fixtures/ifconfig/open_solaris_10 +0 -12
- data/spec/fixtures/ifconfig/open_solaris_b132 +0 -20
- data/spec/fixtures/ifconfig/openbsd_bridge_rules +0 -11
- data/spec/fixtures/ifconfig/sunos_ifconfig_all_with_multiple_interfaces +0 -10
- data/spec/fixtures/ifconfig/ubuntu_7_04 +0 -38
- data/spec/fixtures/ifconfig/ubuntu_7_04_eth0 +0 -9
- data/spec/fixtures/ldom/ldom_v1 +0 -6
- data/spec/fixtures/netstat/centos_5_5 +0 -5
- data/spec/fixtures/netstat/darwin_10_3_0 +0 -35
- data/spec/fixtures/netstat/darwin_10_6_4 +0 -29
- data/spec/fixtures/netstat/darwin_10_6_6_dualstack +0 -34
- data/spec/fixtures/netstat/darwin_9_8_0 +0 -28
- data/spec/fixtures/netstat/fedora_10 +0 -7
- data/spec/fixtures/netstat/open_solaris_10 +0 -16
- data/spec/fixtures/netstat/open_solaris_b132 +0 -17
- data/spec/fixtures/netstat/ubuntu_7_04 +0 -7
- data/spec/fixtures/processorcount/solaris-psrinfo +0 -24
- data/spec/fixtures/processorcount/solaris-sparc-kstat-cpu-info +0 -1216
- data/spec/fixtures/processorcount/solaris-x86_64-kstat-cpu-info +0 -225
- data/spec/fixtures/unit/dhcp_servers/nmcli_devices +0 -4
- data/spec/fixtures/unit/dhcp_servers/nmcli_devices_disconnected +0 -4
- data/spec/fixtures/unit/dhcp_servers/nmcli_eth0_dhcp +0 -36
- data/spec/fixtures/unit/dhcp_servers/nmcli_eth0_static +0 -24
- data/spec/fixtures/unit/dhcp_servers/nmcli_wlan0_dhcp +0 -49
- data/spec/fixtures/unit/dhcp_servers/nmcli_wlan0_static +0 -37
- data/spec/fixtures/unit/dhcp_servers/route +0 -3
- data/spec/fixtures/unit/dhcp_servers/route_nogw +0 -1
- data/spec/fixtures/unit/ec2/rest/meta-data/root +0 -20
- data/spec/fixtures/unit/filesystems/linux +0 -28
- data/spec/fixtures/unit/gce/metadata/metadata.json +0 -69
- data/spec/fixtures/unit/interfaces/ifconfig_net_tools_1.60.txt +0 -19
- data/spec/fixtures/unit/interfaces/ifconfig_net_tools_1.60.txt.em1 +0 -10
- data/spec/fixtures/unit/interfaces/ifconfig_net_tools_1.60.txt.lo +0 -8
- data/spec/fixtures/unit/interfaces/ifconfig_net_tools_1.60_v6.txt +0 -9
- data/spec/fixtures/unit/ipaddress/ifconfig_multiple_127_addresses.txt +0 -20
- data/spec/fixtures/unit/ipaddress/ifconfig_net_tools_1.60.txt +0 -19
- data/spec/fixtures/unit/ipaddress/ifconfig_non_english_locale.txt +0 -18
- data/spec/fixtures/unit/ipaddress/ifconfig_ubuntu_1204.txt +0 -16
- data/spec/fixtures/unit/kernelrelease/openbsd-5.3 +0 -2
- data/spec/fixtures/unit/kernelrelease/openbsd-5.3-current +0 -3
- data/spec/fixtures/unit/memory/aix-svmon +0 -9
- data/spec/fixtures/unit/memory/aix-swap_l +0 -2
- data/spec/fixtures/unit/memory/darwin-swapinfo-multiple +0 -3
- data/spec/fixtures/unit/memory/darwin-swapinfo-single +0 -2
- data/spec/fixtures/unit/memory/darwin-vm_stat +0 -13
- data/spec/fixtures/unit/memory/dragonfly-vmstat +0 -3
- data/spec/fixtures/unit/memory/freebsd-vmstat +0 -3
- data/spec/fixtures/unit/memory/linux-proc_meminfo +0 -10
- data/spec/fixtures/unit/memory/openbsd-vmstat +0 -3
- data/spec/fixtures/unit/memory/smartos_zone_swap_l-single +0 -2
- data/spec/fixtures/unit/memory/solaris-prtconf +0 -4
- data/spec/fixtures/unit/memory/solaris-swap_l-multiple +0 -3
- data/spec/fixtures/unit/memory/solaris-swap_l-single +0 -2
- data/spec/fixtures/unit/memory/solaris-vmstat +0 -3
- data/spec/fixtures/unit/netmask/darwin_10_8_5.txt +0 -30
- data/spec/fixtures/unit/netmask/ifconfig_aix_7.txt +0 -3
- data/spec/fixtures/unit/netmask/ifconfig_net_tools_1.60.txt +0 -19
- data/spec/fixtures/unit/netmask/ifconfig_ubuntu_1204.txt +0 -16
- data/spec/fixtures/unit/processors/os/darwin-system-profiler +0 -287
- data/spec/fixtures/unit/selinux/selinux_sestatus +0 -6
- data/spec/fixtures/unit/selinux/selinux_sestatus2 +0 -9
- data/spec/fixtures/unit/util/dhcp_servers/route +0 -3
- data/spec/fixtures/unit/util/dhcp_servers/route_nogw +0 -1
- data/spec/fixtures/unit/util/ec2/centos-arp-ec2.out +0 -1
- data/spec/fixtures/unit/util/ec2/linux-arp-ec2.out +0 -1
- data/spec/fixtures/unit/util/ec2/linux-arp-not-ec2.out +0 -5
- data/spec/fixtures/unit/util/ec2/solaris8_arp_a_not_ec2.out +0 -7
- data/spec/fixtures/unit/util/ec2/windows-2008-arp-a-not-ec2.out +0 -6
- data/spec/fixtures/unit/util/ec2/windows-2008-arp-a.out +0 -10
- data/spec/fixtures/unit/util/ip/6.0-STABLE_FreeBSD_ifconfig +0 -12
- data/spec/fixtures/unit/util/ip/Mac_OS_X_10.5.5_ifconfig +0 -26
- data/spec/fixtures/unit/util/ip/darwin_ifconfig_all_with_multiple_interfaces +0 -10
- data/spec/fixtures/unit/util/ip/darwin_ifconfig_single_interface +0 -6
- data/spec/fixtures/unit/util/ip/debian_kfreebsd_ifconfig +0 -40
- data/spec/fixtures/unit/util/ip/hpux_1111_ifconfig_lan0 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1111_ifconfig_lan1 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1111_ifconfig_lo0 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1111_lanscan +0 -5
- data/spec/fixtures/unit/util/ip/hpux_1111_netstat_in +0 -4
- data/spec/fixtures/unit/util/ip/hpux_1131_asterisk_ifconfig_lan0 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1131_asterisk_ifconfig_lan1 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1131_asterisk_ifconfig_lo0 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1131_asterisk_lanscan +0 -5
- data/spec/fixtures/unit/util/ip/hpux_1131_asterisk_netstat_in +0 -4
- data/spec/fixtures/unit/util/ip/hpux_1131_ifconfig_lan0 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1131_ifconfig_lan1 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1131_ifconfig_lo0 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1131_lanscan +0 -4
- data/spec/fixtures/unit/util/ip/hpux_1131_netstat_in +0 -4
- data/spec/fixtures/unit/util/ip/hpux_1131_nic_bonding_ifconfig_lan1 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1131_nic_bonding_ifconfig_lan4 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1131_nic_bonding_ifconfig_lan4_1 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1131_nic_bonding_ifconfig_lo0 +0 -2
- data/spec/fixtures/unit/util/ip/hpux_1131_nic_bonding_lanscan +0 -9
- data/spec/fixtures/unit/util/ip/hpux_1131_nic_bonding_netstat_in +0 -6
- data/spec/fixtures/unit/util/ip/linux_2_6_35_proc_net_bonding_bond0 +0 -19
- data/spec/fixtures/unit/util/ip/linux_get_single_interface_eth0 +0 -10
- data/spec/fixtures/unit/util/ip/linux_get_single_interface_ib0 +0 -8
- data/spec/fixtures/unit/util/ip/linux_get_single_interface_ib0_centos7 +0 -8
- data/spec/fixtures/unit/util/ip/linux_get_single_interface_lo +0 -9
- data/spec/fixtures/unit/util/ip/linux_ifconfig_all_with_single_interface +0 -18
- data/spec/fixtures/unit/util/ip/linux_ifconfig_ib0 +0 -8
- data/spec/fixtures/unit/util/ip/linux_ifconfig_ib0_centos7 +0 -8
- data/spec/fixtures/unit/util/ip/solaris_ifconfig_all_with_multiple_interfaces +0 -8
- data/spec/fixtures/unit/util/ip/solaris_ifconfig_single_interface +0 -3
- data/spec/fixtures/unit/util/ip/windows_netsh_all_interfaces +0 -12
- data/spec/fixtures/unit/util/ip/windows_netsh_single_interface +0 -7
- data/spec/fixtures/unit/util/ip/windows_netsh_single_interface6 +0 -18
- data/spec/fixtures/unit/util/manufacturer/freebsd_dmidecode +0 -42
- data/spec/fixtures/unit/util/manufacturer/intel_linux_dmidecode +0 -549
- data/spec/fixtures/unit/util/manufacturer/linux_dmidecode_with_spaces +0 -60
- data/spec/fixtures/unit/util/manufacturer/opensolaris_smbios +0 -33
- data/spec/fixtures/unit/util/manufacturer/smartos_smbios +0 -533
- data/spec/fixtures/unit/util/manufacturer/solaris_sunfire_v120_prtdiag +0 -33
- data/spec/fixtures/unit/util/manufacturer/solaris_t5220_prtdiag +0 -136
- data/spec/fixtures/unit/util/operatingsystem/coreos.txt +0 -9
- data/spec/fixtures/unit/util/operatingsystem/cumuluslinux.txt +0 -8
- data/spec/fixtures/unit/util/operatingsystem/redhat-7.txt +0 -12
- data/spec/fixtures/unit/util/operatingsystem/sabayon.txt +0 -7
- data/spec/fixtures/unit/util/operatingsystem/wheezy.txt +0 -9
- data/spec/fixtures/unit/util/partitions/partitions/mount +0 -9
- data/spec/fixtures/unit/util/processor/solaris-i86pc +0 -28
- data/spec/fixtures/unit/util/processor/solaris-sun4u +0 -151
- data/spec/fixtures/unit/util/processor/x86-pentium2 +0 -41
- data/spec/fixtures/unit/util/uptime/kstat_boot_time +0 -1
- data/spec/fixtures/unit/util/uptime/sysctl_kern_boottime_darwin +0 -1
- data/spec/fixtures/unit/util/uptime/sysctl_kern_boottime_openbsd +0 -1
- data/spec/fixtures/unit/util/uptime/ubuntu_proc_uptime +0 -1
- data/spec/fixtures/unit/util/virtual/invalid_unicode_dmi_entries +0 -0
- data/spec/fixtures/unit/util/virtual/solaris10_proc_self_status1 +0 -0
- data/spec/fixtures/unit/util/vlans/centos-5-no-vlans +0 -2
- data/spec/fixtures/unit/util/vlans/linux_vlan_config +0 -6
- data/spec/fixtures/unit/util/xendomains/xendomains +0 -4
- data/spec/fixtures/unit/virtual/sysfs_dmi_entries_raw.txt +0 -0
- data/spec/fixtures/unit/zfs_version/freebsd_8.2 +0 -14
- data/spec/fixtures/unit/zfs_version/freebsd_9.0 +0 -13
- data/spec/fixtures/unit/zfs_version/linux-fuse_0.6.9 +0 -14
- data/spec/fixtures/unit/zfs_version/solaris_10 +0 -10
- data/spec/fixtures/unit/zfs_version/solaris_11 +0 -12
- data/spec/fixtures/unit/zfs_version/zfs_new +0 -61
- data/spec/fixtures/unit/zfs_version/zfs_old +0 -43
- data/spec/fixtures/unit/zfs_version/zfsonlinux_0.6.1 +0 -13
- data/spec/fixtures/unit/zpool_version/freebsd_8.2 +0 -26
- data/spec/fixtures/unit/zpool_version/freebsd_9.0 +0 -38
- data/spec/fixtures/unit/zpool_version/linux-fuse_0.6.9 +0 -35
- data/spec/fixtures/unit/zpool_version/solaris_10 +0 -31
- data/spec/fixtures/unit/zpool_version/solaris_11 +0 -43
- data/spec/fixtures/unit/zpool_version/zfsonlinux_0.6.1 +0 -48
- data/spec/fixtures/virtual/proc_1_cgroup/in_a_container +0 -9
- data/spec/fixtures/virtual/proc_1_cgroup/in_a_docker_container +0 -8
- data/spec/fixtures/virtual/proc_1_cgroup/in_a_docker_container_with_systemd_slices +0 -10
- data/spec/fixtures/virtual/proc_1_cgroup/not_in_a_container +0 -9
- data/spec/fixtures/virtual/proc_self_status/vserver_2_1/guest +0 -37
- data/spec/fixtures/virtual/proc_self_status/vserver_2_1/host +0 -36
- data/spec/fixtures/virtual/proc_self_status/vserver_2_3/guest +0 -39
- data/spec/fixtures/virtual/proc_self_status/vserver_2_3/host +0 -39
- data/spec/integration/facter_spec.rb +0 -39
- data/spec/integration/util/windows/user_spec.rb +0 -59
- data/spec/lib/facter_spec/cpuinfo.rb +0 -15
- data/spec/lib/facter_spec/windows_network.rb +0 -64
- data/spec/puppetlabs_spec/files.rb +0 -57
- data/spec/puppetlabs_spec/fixtures.rb +0 -49
- data/spec/puppetlabs_spec/matchers.rb +0 -87
- data/spec/puppetlabs_spec/verbose.rb +0 -9
- data/spec/puppetlabs_spec_helper.rb +0 -26
- data/spec/schema/validate_facter_schema.rb +0 -18
- data/spec/shared_contexts/platform.rb +0 -55
- data/spec/shared_formats/parses.rb +0 -3
- data/spec/spec_helper.rb +0 -68
- data/spec/unit/application_spec.rb +0 -110
- data/spec/unit/architecture_spec.rb +0 -63
- data/spec/unit/blockdevices_spec.rb +0 -109
- data/spec/unit/core/aggregate_spec.rb +0 -125
- data/spec/unit/core/directed_graph_spec.rb +0 -79
- data/spec/unit/core/execution/base_spec.rb +0 -130
- data/spec/unit/core/execution/posix_spec.rb +0 -96
- data/spec/unit/core/execution/windows_spec.rb +0 -106
- data/spec/unit/core/execution_spec.rb +0 -42
- data/spec/unit/core/logging_spec.rb +0 -223
- data/spec/unit/core/resolvable_spec.rb +0 -81
- data/spec/unit/core/suitable_spec.rb +0 -106
- data/spec/unit/dhcp_servers_spec.rb +0 -212
- data/spec/unit/domain_spec.rb +0 -310
- data/spec/unit/ec2/rest_spec.rb +0 -168
- data/spec/unit/ec2_spec.rb +0 -139
- data/spec/unit/facter_spec.rb +0 -108
- data/spec/unit/filesystems_spec.rb +0 -50
- data/spec/unit/fqdn_spec.rb +0 -16
- data/spec/unit/gce/metadata_spec.rb +0 -49
- data/spec/unit/gce_spec.rb +0 -34
- data/spec/unit/gid_spec.rb +0 -51
- data/spec/unit/hardwareisa_spec.rb +0 -41
- data/spec/unit/hardwaremodel_spec.rb +0 -58
- data/spec/unit/hostname_spec.rb +0 -40
- data/spec/unit/id_spec.rb +0 -29
- data/spec/unit/interfaces_spec.rb +0 -67
- data/spec/unit/ipaddress6_spec.rb +0 -180
- data/spec/unit/ipaddress_spec.rb +0 -114
- data/spec/unit/kernel_spec.rb +0 -24
- data/spec/unit/kernelmajversion_spec.rb +0 -22
- data/spec/unit/kernelrelease_spec.rb +0 -66
- data/spec/unit/kernelversion_spec.rb +0 -32
- data/spec/unit/ldom_spec.rb +0 -84
- data/spec/unit/lsbdistcodename_spec.rb +0 -30
- data/spec/unit/lsbdistdescription_spec.rb +0 -30
- data/spec/unit/lsbdistid_spec.rb +0 -30
- data/spec/unit/lsbdistrelease_spec.rb +0 -30
- data/spec/unit/lsbmajdistrelease_spec.rb +0 -30
- data/spec/unit/lsbminordistrelease_spec.rb +0 -31
- data/spec/unit/lsbrelease_spec.rb +0 -30
- data/spec/unit/macaddress_spec.rb +0 -76
- data/spec/unit/manufacturer_spec.rb +0 -115
- data/spec/unit/memory_spec.rb +0 -470
- data/spec/unit/netmask_spec.rb +0 -106
- data/spec/unit/operatingsystem/base_spec.rb +0 -76
- data/spec/unit/operatingsystem/cumuluslinux_spec.rb +0 -40
- data/spec/unit/operatingsystem/implementation_spec.rb +0 -50
- data/spec/unit/operatingsystem/linux_spec.rb +0 -559
- data/spec/unit/operatingsystem/sunos_spec.rb +0 -143
- data/spec/unit/operatingsystem/vmkernel_spec.rb +0 -13
- data/spec/unit/operatingsystem/windows_spec.rb +0 -77
- data/spec/unit/operatingsystem_spec.rb +0 -17
- data/spec/unit/operatingsystemmajrelease_spec.rb +0 -21
- data/spec/unit/operatingsystemrelease_spec.rb +0 -20
- data/spec/unit/os_spec.rb +0 -131
- data/spec/unit/osfamily_spec.rb +0 -17
- data/spec/unit/partitions_spec.rb +0 -88
- data/spec/unit/physicalprocessorcount_spec.rb +0 -13
- data/spec/unit/processor_spec.rb +0 -38
- data/spec/unit/processors/os_spec.rb +0 -469
- data/spec/unit/processors_spec.rb +0 -203
- data/spec/unit/ps_spec.rb +0 -42
- data/spec/unit/rackspace_spec.rb +0 -40
- data/spec/unit/rubyplatform_spec.rb +0 -7
- data/spec/unit/selinux_spec.rb +0 -119
- data/spec/unit/ssh_spec.rb +0 -77
- data/spec/unit/system32_spec.rb +0 -28
- data/spec/unit/system_uptime_spec.rb +0 -80
- data/spec/unit/uniqueid_spec.rb +0 -27
- data/spec/unit/uptime_spec.rb +0 -110
- data/spec/unit/util/collection_spec.rb +0 -258
- data/spec/unit/util/config_spec.rb +0 -120
- data/spec/unit/util/confine_spec.rb +0 -148
- data/spec/unit/util/dhcp_servers_spec.rb +0 -63
- data/spec/unit/util/directory_loader_spec.rb +0 -102
- data/spec/unit/util/ec2_spec.rb +0 -184
- data/spec/unit/util/fact_spec.rb +0 -142
- data/spec/unit/util/file_read_spec.rb +0 -29
- data/spec/unit/util/formatter_spec.rb +0 -55
- data/spec/unit/util/ip/windows_spec.rb +0 -80
- data/spec/unit/util/ip_spec.rb +0 -487
- data/spec/unit/util/loader_spec.rb +0 -286
- data/spec/unit/util/macaddress_spec.rb +0 -143
- data/spec/unit/util/macosx_spec.rb +0 -114
- data/spec/unit/util/manufacturer_spec.rb +0 -223
- data/spec/unit/util/normalization_spec.rb +0 -113
- data/spec/unit/util/operatingsystem_spec.rb +0 -107
- data/spec/unit/util/parser_spec.rb +0 -233
- data/spec/unit/util/partitions/partitions_spec.rb +0 -67
- data/spec/unit/util/partitions_spec.rb +0 -19
- data/spec/unit/util/posix_spec.rb +0 -11
- data/spec/unit/util/processor_spec.rb +0 -212
- data/spec/unit/util/registry_spec.rb +0 -76
- data/spec/unit/util/resolution_spec.rb +0 -129
- data/spec/unit/util/solaris_zones_spec.rb +0 -127
- data/spec/unit/util/uptime_spec.rb +0 -131
- data/spec/unit/util/values_spec.rb +0 -171
- data/spec/unit/util/virtual_spec.rb +0 -393
- data/spec/unit/util/vlans_spec.rb +0 -42
- data/spec/unit/util/wmi_spec.rb +0 -19
- data/spec/unit/util/xendomains_spec.rb +0 -114
- data/spec/unit/version_spec.rb +0 -42
- data/spec/unit/virtual_spec.rb +0 -585
- data/spec/unit/zfs_version_spec.rb +0 -87
- data/spec/unit/zonename_spec.rb +0 -14
- data/spec/unit/zones_spec.rb +0 -55
- data/spec/unit/zpool_version_spec.rb +0 -80
- data/spec/watchr.rb +0 -125
| @@ -0,0 +1,15 @@ | |
| 1 | 
            +
            #include "collection_fixture.hpp"
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            namespace facter { namespace testing {
         | 
| 4 | 
            +
             | 
| 5 | 
            +
                using namespace std;
         | 
| 6 | 
            +
             | 
| 7 | 
            +
                collection_fixture::collection_fixture(set<string> const& blocklist,
         | 
| 8 | 
            +
                        unordered_map<string, int64_t> const& ttls) : collection(blocklist, ttls) { }
         | 
| 9 | 
            +
             | 
| 10 | 
            +
                vector<string> collection_fixture::get_external_fact_directories() const
         | 
| 11 | 
            +
                {
         | 
| 12 | 
            +
                    return {};
         | 
| 13 | 
            +
                }
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            }}  // namespace facter::testing
         | 
| @@ -0,0 +1,19 @@ | |
| 1 | 
            +
            #pragma once
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            #include <facter/facts/collection.hpp>
         | 
| 4 | 
            +
            #include <vector>
         | 
| 5 | 
            +
            #include <string>
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            namespace facter { namespace testing {
         | 
| 8 | 
            +
             | 
| 9 | 
            +
                class collection_fixture : public facter::facts::collection
         | 
| 10 | 
            +
                {
         | 
| 11 | 
            +
                public:
         | 
| 12 | 
            +
                    collection_fixture(std::set<std::string> const& blocklist = std::set<std::string>(),
         | 
| 13 | 
            +
                            std::unordered_map<std::string, int64_t> const& ttls = std::unordered_map<std::string, int64_t>{});
         | 
| 14 | 
            +
             | 
| 15 | 
            +
                protected:
         | 
| 16 | 
            +
                    virtual std::vector<std::string> get_external_fact_directories() const override;
         | 
| 17 | 
            +
                };
         | 
| 18 | 
            +
             | 
| 19 | 
            +
            }}  // namespace facter::testing
         | 
| @@ -0,0 +1,22 @@ | |
| 1 | 
            +
            #include <catch.hpp>
         | 
| 2 | 
            +
            #include <facter/cwrapper.hpp>
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            SCENARIO("using the C wrapper function to collect default facts") {
         | 
| 5 | 
            +
                GIVEN("a get_default_facts invocation") {
         | 
| 6 | 
            +
                    char *result {nullptr};
         | 
| 7 | 
            +
             | 
| 8 | 
            +
                    THEN("no error should be thrown") {
         | 
| 9 | 
            +
                        REQUIRE_NOTHROW(get_default_facts(&result));
         | 
| 10 | 
            +
                    }
         | 
| 11 | 
            +
             | 
| 12 | 
            +
                    THEN("the function execution should succeed") {
         | 
| 13 | 
            +
                        REQUIRE(get_default_facts(&result) == 0);
         | 
| 14 | 
            +
                    }
         | 
| 15 | 
            +
             | 
| 16 | 
            +
                    THEN("the function stores the collected facts and sets the pointer arg") {
         | 
| 17 | 
            +
                        REQUIRE(result == nullptr);
         | 
| 18 | 
            +
                        get_default_facts(&result);
         | 
| 19 | 
            +
                        REQUIRE_FALSE(result == nullptr);
         | 
| 20 | 
            +
                    }
         | 
| 21 | 
            +
                }
         | 
| 22 | 
            +
            }
         | 
| @@ -0,0 +1,140 @@ | |
| 1 | 
            +
            #include <catch.hpp>
         | 
| 2 | 
            +
            #include <facter/facts/array_value.hpp>
         | 
| 3 | 
            +
            #include <facter/facts/scalar_value.hpp>
         | 
| 4 | 
            +
            #include <rapidjson/document.h>
         | 
| 5 | 
            +
            #include <yaml-cpp/yaml.h>
         | 
| 6 | 
            +
            #include <sstream>
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            using namespace std;
         | 
| 9 | 
            +
            using namespace facter::facts;
         | 
| 10 | 
            +
            using namespace rapidjson;
         | 
| 11 | 
            +
            using namespace YAML;
         | 
| 12 | 
            +
             | 
| 13 | 
            +
            SCENARIO("using an array fact value") {
         | 
| 14 | 
            +
                array_value value;
         | 
| 15 | 
            +
                REQUIRE(value.empty());
         | 
| 16 | 
            +
                GIVEN("a null value to add") {
         | 
| 17 | 
            +
                    value.add(nullptr);
         | 
| 18 | 
            +
                    THEN("it should still be empty") {
         | 
| 19 | 
            +
                        REQUIRE(value.empty());
         | 
| 20 | 
            +
                    }
         | 
| 21 | 
            +
                }
         | 
| 22 | 
            +
                GIVEN("an out of range index") {
         | 
| 23 | 
            +
                    THEN("get() raises out_of_range") {
         | 
| 24 | 
            +
                        REQUIRE_THROWS_AS(value.get<string_value>(0), std::out_of_range);
         | 
| 25 | 
            +
                    }
         | 
| 26 | 
            +
                    THEN("operator[] returns nullptr") {
         | 
| 27 | 
            +
                        REQUIRE_FALSE(value[42]);
         | 
| 28 | 
            +
                    }
         | 
| 29 | 
            +
                }
         | 
| 30 | 
            +
                GIVEN("a string value to add") {
         | 
| 31 | 
            +
                    value.add(make_value<string_value>("hello"));
         | 
| 32 | 
            +
                    THEN("it should contain the string value") {
         | 
| 33 | 
            +
                        REQUIRE_FALSE(value.empty());
         | 
| 34 | 
            +
                        REQUIRE(value.size() == 1u);
         | 
| 35 | 
            +
                        REQUIRE(value.get<string_value>(0));
         | 
| 36 | 
            +
                        REQUIRE(value.get<string_value>(0)->value() == "hello");
         | 
| 37 | 
            +
                    }
         | 
| 38 | 
            +
                }
         | 
| 39 | 
            +
                GIVEN("an integer value to add") {
         | 
| 40 | 
            +
                    value.add(make_value<integer_value>(123));
         | 
| 41 | 
            +
                    THEN("it should contain the string value") {
         | 
| 42 | 
            +
                        REQUIRE_FALSE(value.empty());
         | 
| 43 | 
            +
                        REQUIRE(value.size() == 1u);
         | 
| 44 | 
            +
                        REQUIRE(value.get<integer_value>(0));
         | 
| 45 | 
            +
                        REQUIRE(value.get<integer_value>(0)->value() == 123);
         | 
| 46 | 
            +
                    }
         | 
| 47 | 
            +
                }
         | 
| 48 | 
            +
                GIVEN("multiple values to add") {
         | 
| 49 | 
            +
                    auto subarray = make_value<array_value>();
         | 
| 50 | 
            +
                    subarray->add(make_value<string_value>("element"));
         | 
| 51 | 
            +
                    value.add(make_value<string_value>("1"));
         | 
| 52 | 
            +
                    value.add(make_value<integer_value>(2));
         | 
| 53 | 
            +
                    value.add(move(subarray));
         | 
| 54 | 
            +
                    THEN("it should contain the values in order they were added") {
         | 
| 55 | 
            +
                        REQUIRE(value.size() == 3u);
         | 
| 56 | 
            +
                        auto string_val = value.get<string_value>(0);
         | 
| 57 | 
            +
                        REQUIRE(string_val);
         | 
| 58 | 
            +
                        REQUIRE(string_val->value() == "1");
         | 
| 59 | 
            +
                        auto int_val = value.get<integer_value>(1);
         | 
| 60 | 
            +
                        REQUIRE(int_val);
         | 
| 61 | 
            +
                        REQUIRE(int_val->value() == 2);
         | 
| 62 | 
            +
                        auto subarray = value.get<array_value>(2);
         | 
| 63 | 
            +
                        REQUIRE(subarray);
         | 
| 64 | 
            +
                        REQUIRE(subarray->size() == 1u);
         | 
| 65 | 
            +
                        string_val = subarray->get<string_value>(0);
         | 
| 66 | 
            +
                        REQUIRE(string_val);
         | 
| 67 | 
            +
                        REQUIRE(string_val->value() == "element");
         | 
| 68 | 
            +
                    }
         | 
| 69 | 
            +
                    THEN("each is enumerated in order") {
         | 
| 70 | 
            +
                        size_t index = 0u;
         | 
| 71 | 
            +
                        value.each([&](struct value const* val) {
         | 
| 72 | 
            +
                            if (index == 0u) {
         | 
| 73 | 
            +
                                auto string_val = dynamic_cast<string_value const*>(val);
         | 
| 74 | 
            +
                                REQUIRE(string_val);
         | 
| 75 | 
            +
                                REQUIRE(string_val->value() == "1");
         | 
| 76 | 
            +
                            } else if (index == 1u) {
         | 
| 77 | 
            +
                                auto int_val = dynamic_cast<integer_value const*>(val);
         | 
| 78 | 
            +
                                REQUIRE(int_val);
         | 
| 79 | 
            +
                                REQUIRE(int_val->value() == 2);
         | 
| 80 | 
            +
                            } else if (index == 2u) {
         | 
| 81 | 
            +
                                auto subarray = dynamic_cast<array_value const*>(val);
         | 
| 82 | 
            +
                                REQUIRE(subarray);
         | 
| 83 | 
            +
                                REQUIRE(subarray->size() == 1u);
         | 
| 84 | 
            +
                                auto string_val = subarray->get<string_value>(0);
         | 
| 85 | 
            +
                                REQUIRE(string_val);
         | 
| 86 | 
            +
                                REQUIRE(string_val->value() == "element");
         | 
| 87 | 
            +
                            } else {
         | 
| 88 | 
            +
                                FAIL("should not be reached");
         | 
| 89 | 
            +
                            }
         | 
| 90 | 
            +
                            ++index;
         | 
| 91 | 
            +
                            return true;
         | 
| 92 | 
            +
                        });
         | 
| 93 | 
            +
                        REQUIRE(index == value.size());
         | 
| 94 | 
            +
                    }
         | 
| 95 | 
            +
                    WHEN("serialized to JSON") {
         | 
| 96 | 
            +
                        THEN("it should contain the same values") {
         | 
| 97 | 
            +
                            json_value json;
         | 
| 98 | 
            +
                            json_allocator allocator;
         | 
| 99 | 
            +
                            value.to_json(allocator, json);
         | 
| 100 | 
            +
                            REQUIRE(json.IsArray());
         | 
| 101 | 
            +
                            REQUIRE(json.Size() == 3);
         | 
| 102 | 
            +
                            REQUIRE(json[0u].IsString());
         | 
| 103 | 
            +
                            REQUIRE(string(json[0u].GetString()) == "1");
         | 
| 104 | 
            +
                            REQUIRE(json[1u].IsNumber());
         | 
| 105 | 
            +
                            REQUIRE(json[1u].GetInt64() == 2ll);
         | 
| 106 | 
            +
                            REQUIRE(json[2u].IsArray());
         | 
| 107 | 
            +
                            REQUIRE(json[2u].Size() == 1);
         | 
| 108 | 
            +
                            REQUIRE(json[2u][0u].IsString());
         | 
| 109 | 
            +
                            REQUIRE(string(json[2u][0u].GetString()) == "element");
         | 
| 110 | 
            +
                        }
         | 
| 111 | 
            +
                    }
         | 
| 112 | 
            +
                    WHEN("serialized to text") {
         | 
| 113 | 
            +
                        THEN("it should contain the same values") {
         | 
| 114 | 
            +
                            ostringstream stream;
         | 
| 115 | 
            +
                            value.write(stream);
         | 
| 116 | 
            +
                            REQUIRE(stream.str() == "[\n  \"1\",\n  2,\n  [\n    \"element\"\n  ]\n]");
         | 
| 117 | 
            +
                        }
         | 
| 118 | 
            +
                    }
         | 
| 119 | 
            +
                    WHEN("serialized to YAML") {
         | 
| 120 | 
            +
                        THEN("it should contain the same values") {
         | 
| 121 | 
            +
                            Emitter emitter;
         | 
| 122 | 
            +
                            value.write(emitter);
         | 
| 123 | 
            +
                            REQUIRE(string(emitter.c_str()) == "- \"1\"\n- 2\n-\n  - element");
         | 
| 124 | 
            +
                        }
         | 
| 125 | 
            +
                    }
         | 
| 126 | 
            +
                }
         | 
| 127 | 
            +
                GIVEN("each with a callback that returns false") {
         | 
| 128 | 
            +
                    THEN("it should stop enumerating") {
         | 
| 129 | 
            +
                        value.add(make_value<integer_value>(1));
         | 
| 130 | 
            +
                        value.add(make_value<integer_value>(2));
         | 
| 131 | 
            +
                        value.add(make_value<integer_value>(3));
         | 
| 132 | 
            +
                        size_t index = 0u;
         | 
| 133 | 
            +
                        value.each([&](struct value const* val) {
         | 
| 134 | 
            +
                            ++index;
         | 
| 135 | 
            +
                            return false;
         | 
| 136 | 
            +
                        });
         | 
| 137 | 
            +
                        REQUIRE(index == 1u);
         | 
| 138 | 
            +
                    }
         | 
| 139 | 
            +
                }
         | 
| 140 | 
            +
            }
         | 
| @@ -0,0 +1,67 @@ | |
| 1 | 
            +
            #include <catch.hpp>
         | 
| 2 | 
            +
            #include <facter/facts/scalar_value.hpp>
         | 
| 3 | 
            +
            #include <rapidjson/document.h>
         | 
| 4 | 
            +
            #include <yaml-cpp/yaml.h>
         | 
| 5 | 
            +
            #include <sstream>
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            using namespace std;
         | 
| 8 | 
            +
            using namespace facter::facts;
         | 
| 9 | 
            +
            using namespace rapidjson;
         | 
| 10 | 
            +
            using namespace YAML;
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            SCENARIO("using a boolean fact value") {
         | 
| 13 | 
            +
                GIVEN("true to the constructor") {
         | 
| 14 | 
            +
                    boolean_value value(true);
         | 
| 15 | 
            +
                    REQUIRE(value.value());
         | 
| 16 | 
            +
                    WHEN("serialized to JSON") {
         | 
| 17 | 
            +
                        THEN("it should serialize as true") {
         | 
| 18 | 
            +
                            json_value json;
         | 
| 19 | 
            +
                            json_allocator allocator;
         | 
| 20 | 
            +
                            value.to_json(allocator, json);
         | 
| 21 | 
            +
                            REQUIRE(json.IsBool());
         | 
| 22 | 
            +
                            REQUIRE(json.GetBool());
         | 
| 23 | 
            +
                        }
         | 
| 24 | 
            +
                    }
         | 
| 25 | 
            +
                    WHEN("serialized to YAML") {
         | 
| 26 | 
            +
                        THEN("it should serialize as true") {
         | 
| 27 | 
            +
                            Emitter emitter;
         | 
| 28 | 
            +
                            value.write(emitter);
         | 
| 29 | 
            +
                            REQUIRE(string(emitter.c_str()) == "true");
         | 
| 30 | 
            +
                        }
         | 
| 31 | 
            +
                    }
         | 
| 32 | 
            +
                    WHEN("serialized to text") {
         | 
| 33 | 
            +
                        THEN("it should serialize to text as true") {
         | 
| 34 | 
            +
                            ostringstream stream;
         | 
| 35 | 
            +
                            value.write(stream);
         | 
| 36 | 
            +
                            REQUIRE(stream.str() == "true");
         | 
| 37 | 
            +
                        }
         | 
| 38 | 
            +
                    }
         | 
| 39 | 
            +
                }
         | 
| 40 | 
            +
                GIVEN("false to the constructor") {
         | 
| 41 | 
            +
                    boolean_value value(false);
         | 
| 42 | 
            +
                    REQUIRE_FALSE(value.value());
         | 
| 43 | 
            +
                    WHEN("serialized to JSON") {
         | 
| 44 | 
            +
                        THEN("it should serialize as false") {
         | 
| 45 | 
            +
                            json_value json;
         | 
| 46 | 
            +
                            json_allocator allocator;
         | 
| 47 | 
            +
                            value.to_json(allocator, json);
         | 
| 48 | 
            +
                            REQUIRE(json.IsBool());
         | 
| 49 | 
            +
                            REQUIRE_FALSE(json.GetBool());
         | 
| 50 | 
            +
                        }
         | 
| 51 | 
            +
                    }
         | 
| 52 | 
            +
                    WHEN("serialized to YAML") {
         | 
| 53 | 
            +
                        THEN("it should serialize as false") {
         | 
| 54 | 
            +
                            Emitter emitter;
         | 
| 55 | 
            +
                            value.write(emitter);
         | 
| 56 | 
            +
                            REQUIRE(string(emitter.c_str()) == "false");
         | 
| 57 | 
            +
                        }
         | 
| 58 | 
            +
                    }
         | 
| 59 | 
            +
                    WHEN("serialized to text") {
         | 
| 60 | 
            +
                        THEN("it should serialize to text as false") {
         | 
| 61 | 
            +
                            ostringstream stream;
         | 
| 62 | 
            +
                            value.write(stream);
         | 
| 63 | 
            +
                            REQUIRE(stream.str() == "false");
         | 
| 64 | 
            +
                        }
         | 
| 65 | 
            +
                    }
         | 
| 66 | 
            +
                }
         | 
| 67 | 
            +
            }
         | 
| @@ -0,0 +1,100 @@ | |
| 1 | 
            +
            #include <catch.hpp>
         | 
| 2 | 
            +
            #include "../fixtures.hpp"
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            #include<internal/facts/cache.hpp>
         | 
| 5 | 
            +
            #include <facter/facts/scalar_value.hpp>
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            #include <leatherman/file_util/file.hpp>
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            using namespace std;
         | 
| 10 | 
            +
            using namespace facter::testing;
         | 
| 11 | 
            +
            using namespace facter::facts;
         | 
| 12 | 
            +
            namespace boost_file = boost::filesystem;
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            struct simple_resolver : facter::facts::resolver
         | 
| 15 | 
            +
            {
         | 
| 16 | 
            +
                simple_resolver() : resolver("test", { "foo" })
         | 
| 17 | 
            +
                {
         | 
| 18 | 
            +
                }
         | 
| 19 | 
            +
             | 
| 20 | 
            +
                virtual void resolve(collection& facts) override
         | 
| 21 | 
            +
                {
         | 
| 22 | 
            +
                    facts.add("foo", make_value<string_value>("bar"));
         | 
| 23 | 
            +
                }
         | 
| 24 | 
            +
             | 
| 25 | 
            +
                bool is_blockable() const override
         | 
| 26 | 
            +
                {
         | 
| 27 | 
            +
                    return true;
         | 
| 28 | 
            +
                }
         | 
| 29 | 
            +
            };
         | 
| 30 | 
            +
             | 
| 31 | 
            +
            SCENARIO("refreshing cache") {
         | 
| 32 | 
            +
                boost_file::path cache_dir(LIBFACTER_TESTS_DIRECTORY + string("/fixtures/cache"));
         | 
| 33 | 
            +
             | 
| 34 | 
            +
                GIVEN("a resolver that needs to be cached") {
         | 
| 35 | 
            +
                    collection_fixture facts;
         | 
| 36 | 
            +
                    auto test_res = make_shared<simple_resolver>();
         | 
| 37 | 
            +
                    boost_file::create_directories(cache_dir);
         | 
| 38 | 
            +
             | 
| 39 | 
            +
                    THEN("new JSON files should be written") {
         | 
| 40 | 
            +
                        auto cache_file = (cache_dir / "test").string();
         | 
| 41 | 
            +
                        REQUIRE_FALSE(leatherman::file_util::file_readable(cache_file));
         | 
| 42 | 
            +
             | 
| 43 | 
            +
                        cache::refresh_cache(test_res, cache_file, facts);
         | 
| 44 | 
            +
                        REQUIRE(leatherman::file_util::file_readable(cache_file));
         | 
| 45 | 
            +
                        string contents;
         | 
| 46 | 
            +
                        load_fixture("cache/test", contents);
         | 
| 47 | 
            +
                        REQUIRE(contents.find("foo") != string::npos);
         | 
| 48 | 
            +
                    }
         | 
| 49 | 
            +
                }
         | 
| 50 | 
            +
             | 
| 51 | 
            +
                // Clean up directory
         | 
| 52 | 
            +
                boost_file::remove_all(cache_dir);
         | 
| 53 | 
            +
            }
         | 
| 54 | 
            +
             | 
| 55 | 
            +
            SCENARIO("loading facts from cache") {
         | 
| 56 | 
            +
                boost_file::path cache_dir(LIBFACTER_TESTS_DIRECTORY + string("/fixtures/cache"));
         | 
| 57 | 
            +
             | 
| 58 | 
            +
                GIVEN("an existing cache directory with cached fact") {
         | 
| 59 | 
            +
                    collection_fixture facts;
         | 
| 60 | 
            +
                    auto test_res = make_shared<simple_resolver>();
         | 
| 61 | 
            +
                    boost_file::create_directories(cache_dir);
         | 
| 62 | 
            +
                    auto cache_file = cache_dir / "test";
         | 
| 63 | 
            +
                    leatherman::file_util::atomic_write_to_file("{ \"foo\" : \"bar\" }", cache_file.string());
         | 
| 64 | 
            +
             | 
| 65 | 
            +
                    THEN("facts should be loaded from the cache") {
         | 
| 66 | 
            +
                        cache::load_facts_from_cache(cache_file, test_res, facts);
         | 
| 67 | 
            +
                        REQUIRE(facts.get_resolved("foo"));
         | 
| 68 | 
            +
                    }
         | 
| 69 | 
            +
                }
         | 
| 70 | 
            +
             | 
| 71 | 
            +
                // Clean up directory
         | 
| 72 | 
            +
                boost_file::remove_all(cache_dir);
         | 
| 73 | 
            +
            }
         | 
| 74 | 
            +
             | 
| 75 | 
            +
            SCENARIO("cleaning the cache") {
         | 
| 76 | 
            +
                boost_file::path cache_dir(LIBFACTER_TESTS_DIRECTORY + string("/fixtures/cache"));
         | 
| 77 | 
            +
             | 
| 78 | 
            +
                GIVEN("an existing cache directory with a fact that should no longer be cached") {
         | 
| 79 | 
            +
                    boost_file::create_directories(cache_dir);
         | 
| 80 | 
            +
                    // unused cache file
         | 
| 81 | 
            +
                    auto unused_cache_file = (cache_dir / "unused").string();
         | 
| 82 | 
            +
                    leatherman::file_util::atomic_write_to_file("{ \"foo\" : \"bar\" }",
         | 
| 83 | 
            +
                            unused_cache_file);
         | 
| 84 | 
            +
                    // used cached file
         | 
| 85 | 
            +
                    auto used_cache_file = (cache_dir / "test").string();
         | 
| 86 | 
            +
                    leatherman::file_util::atomic_write_to_file("{ \"foo\" : \"bar\" }",
         | 
| 87 | 
            +
                            used_cache_file);
         | 
| 88 | 
            +
             | 
| 89 | 
            +
                    THEN("unused cache file should be deleted") {
         | 
| 90 | 
            +
                        // cache "test", but not "unused"
         | 
| 91 | 
            +
                        cache::clean_cache(unordered_map<string, int64_t>({
         | 
| 92 | 
            +
                                    make_pair("test", 600)
         | 
| 93 | 
            +
                                    }), cache_dir.string());
         | 
| 94 | 
            +
                        REQUIRE_FALSE(leatherman::file_util::file_readable(unused_cache_file));
         | 
| 95 | 
            +
                        REQUIRE(leatherman::file_util::file_readable(used_cache_file));
         | 
| 96 | 
            +
                    }
         | 
| 97 | 
            +
                }
         | 
| 98 | 
            +
             | 
| 99 | 
            +
                boost_file::remove_all(cache_dir);
         | 
| 100 | 
            +
            }
         | 
| @@ -0,0 +1,576 @@ | |
| 1 | 
            +
            #include <catch.hpp>
         | 
| 2 | 
            +
            #include <facter/facts/collection.hpp>
         | 
| 3 | 
            +
            #include <facter/facts/resolver.hpp>
         | 
| 4 | 
            +
            #include <facter/facts/array_value.hpp>
         | 
| 5 | 
            +
            #include <facter/facts/map_value.hpp>
         | 
| 6 | 
            +
            #include <facter/facts/scalar_value.hpp>
         | 
| 7 | 
            +
            #include <leatherman/util/environment.hpp>
         | 
| 8 | 
            +
            #include "../fixtures.hpp"
         | 
| 9 | 
            +
            #include <sstream>
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            using namespace std;
         | 
| 12 | 
            +
            using namespace facter::facts;
         | 
| 13 | 
            +
            using namespace leatherman::util;
         | 
| 14 | 
            +
            using namespace facter::testing;
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            struct simple_resolver : facter::facts::resolver
         | 
| 17 | 
            +
            {
         | 
| 18 | 
            +
                simple_resolver() : resolver("test", { "foo" })
         | 
| 19 | 
            +
                {
         | 
| 20 | 
            +
                }
         | 
| 21 | 
            +
             | 
| 22 | 
            +
                virtual void resolve(collection& facts) override
         | 
| 23 | 
            +
                {
         | 
| 24 | 
            +
                    facts.add("foo", make_value<string_value>("bar"));
         | 
| 25 | 
            +
                }
         | 
| 26 | 
            +
             | 
| 27 | 
            +
                bool is_blockable() const override
         | 
| 28 | 
            +
                {
         | 
| 29 | 
            +
                    return true;
         | 
| 30 | 
            +
                }
         | 
| 31 | 
            +
            };
         | 
| 32 | 
            +
             | 
| 33 | 
            +
            struct unblockable_resolver : facter::facts::resolver
         | 
| 34 | 
            +
            {
         | 
| 35 | 
            +
                unblockable_resolver() : resolver("unblockable", { "foo" })
         | 
| 36 | 
            +
                {
         | 
| 37 | 
            +
                }
         | 
| 38 | 
            +
             | 
| 39 | 
            +
                virtual void resolve(collection& facts) override
         | 
| 40 | 
            +
                {
         | 
| 41 | 
            +
                    facts.add("foo", make_value<string_value>("bar"));
         | 
| 42 | 
            +
                }
         | 
| 43 | 
            +
             | 
| 44 | 
            +
                bool is_blockable() const override
         | 
| 45 | 
            +
                {
         | 
| 46 | 
            +
                    return false;
         | 
| 47 | 
            +
                }
         | 
| 48 | 
            +
            };
         | 
| 49 | 
            +
             | 
| 50 | 
            +
            struct multi_resolver : facter::facts::resolver
         | 
| 51 | 
            +
            {
         | 
| 52 | 
            +
                multi_resolver() : resolver("test", { "foo", "bar" })
         | 
| 53 | 
            +
                {
         | 
| 54 | 
            +
                }
         | 
| 55 | 
            +
             | 
| 56 | 
            +
                virtual void resolve(collection& facts) override
         | 
| 57 | 
            +
                {
         | 
| 58 | 
            +
                    facts.add("foo", make_value<string_value>("bar"));
         | 
| 59 | 
            +
                    facts.add("bar", make_value<string_value>("foo"));
         | 
| 60 | 
            +
                }
         | 
| 61 | 
            +
             | 
| 62 | 
            +
                bool is_blockable() const override
         | 
| 63 | 
            +
                {
         | 
| 64 | 
            +
                    return true;
         | 
| 65 | 
            +
                }
         | 
| 66 | 
            +
            };
         | 
| 67 | 
            +
             | 
| 68 | 
            +
            struct temp_variable
         | 
| 69 | 
            +
            {
         | 
| 70 | 
            +
                temp_variable(string name, string const& value) :
         | 
| 71 | 
            +
                    _name(move(name))
         | 
| 72 | 
            +
                {
         | 
| 73 | 
            +
                    environment::set(_name, value);
         | 
| 74 | 
            +
                }
         | 
| 75 | 
            +
             | 
| 76 | 
            +
                ~temp_variable()
         | 
| 77 | 
            +
                {
         | 
| 78 | 
            +
                    environment::clear(_name);
         | 
| 79 | 
            +
                }
         | 
| 80 | 
            +
             | 
| 81 | 
            +
                string _name;
         | 
| 82 | 
            +
            };
         | 
| 83 | 
            +
             | 
| 84 | 
            +
            SCENARIO("using the fact collection") {
         | 
| 85 | 
            +
                collection_fixture facts;
         | 
| 86 | 
            +
                REQUIRE(facts.size() == 0u);
         | 
| 87 | 
            +
                REQUIRE(facts.empty());
         | 
| 88 | 
            +
             | 
| 89 | 
            +
                GIVEN("default facts") {
         | 
| 90 | 
            +
                    facts.add_default_facts(true);
         | 
| 91 | 
            +
                    THEN("facts should resolve") {
         | 
| 92 | 
            +
                        REQUIRE(facts.size() > 0u);
         | 
| 93 | 
            +
                        REQUIRE_FALSE(facts.empty());
         | 
| 94 | 
            +
                    }
         | 
| 95 | 
            +
                }
         | 
| 96 | 
            +
                GIVEN("a hidden fact and a revealed fact") {
         | 
| 97 | 
            +
                    facts.add("foo", make_value<string_value>("bar"));
         | 
| 98 | 
            +
                    facts.add("hidden_foo", make_value<string_value>("hidden_bar", true));
         | 
| 99 | 
            +
                    THEN("they should be in the collection") {
         | 
| 100 | 
            +
                        REQUIRE(facts.size() == 2u);
         | 
| 101 | 
            +
                        REQUIRE_FALSE(facts.empty());
         | 
| 102 | 
            +
                        auto fact = facts.get<string_value>("foo");
         | 
| 103 | 
            +
                        REQUIRE(fact);
         | 
| 104 | 
            +
                        REQUIRE(fact->value() == "bar");
         | 
| 105 | 
            +
                        fact = dynamic_cast<string_value const *>(facts["foo"]);
         | 
| 106 | 
            +
                        REQUIRE(fact);
         | 
| 107 | 
            +
                        REQUIRE(fact->value() == "bar");
         | 
| 108 | 
            +
                        auto hidden_fact = facts.get<string_value>("hidden_foo");
         | 
| 109 | 
            +
                        REQUIRE(hidden_fact);
         | 
| 110 | 
            +
                        REQUIRE(hidden_fact->value() == "hidden_bar");
         | 
| 111 | 
            +
                        hidden_fact = dynamic_cast<string_value const *>(facts["hidden_foo"]);
         | 
| 112 | 
            +
                        REQUIRE(hidden_fact);
         | 
| 113 | 
            +
                        REQUIRE(hidden_fact->value() == "hidden_bar");
         | 
| 114 | 
            +
                    }
         | 
| 115 | 
            +
                    WHEN("writing default facts") {
         | 
| 116 | 
            +
                        THEN("it should serialize the revealed fact to JSON") {
         | 
| 117 | 
            +
                            ostringstream ss;
         | 
| 118 | 
            +
                            facts.write(ss, format::json);
         | 
| 119 | 
            +
                            REQUIRE(ss.str() == "{\n  \"foo\": \"bar\"\n}");
         | 
| 120 | 
            +
                        }
         | 
| 121 | 
            +
                        THEN("it should serialize the revealed fact to YAML") {
         | 
| 122 | 
            +
                            ostringstream ss;
         | 
| 123 | 
            +
                            facts.write(ss, format::yaml);
         | 
| 124 | 
            +
                            REQUIRE(ss.str() == "foo: bar");
         | 
| 125 | 
            +
                        }
         | 
| 126 | 
            +
                        THEN("it should serialize the revealed fact to text") {
         | 
| 127 | 
            +
                            ostringstream ss;
         | 
| 128 | 
            +
                            facts.write(ss, format::hash);
         | 
| 129 | 
            +
                            REQUIRE(ss.str() == "foo => bar");
         | 
| 130 | 
            +
                        }
         | 
| 131 | 
            +
                    }
         | 
| 132 | 
            +
                    WHEN("writing all (hidden) facts") {
         | 
| 133 | 
            +
                        THEN("it should serialize both facts to JSON") {
         | 
| 134 | 
            +
                            ostringstream ss;
         | 
| 135 | 
            +
                            facts.write(ss, format::json, set<string>{}, true, false);
         | 
| 136 | 
            +
                            REQUIRE(ss.str() == "{\n  \"foo\": \"bar\",\n  \"hidden_foo\": \"hidden_bar\"\n}");
         | 
| 137 | 
            +
                        }
         | 
| 138 | 
            +
                        THEN("it should serialize both facts to YAML") {
         | 
| 139 | 
            +
                            ostringstream ss;
         | 
| 140 | 
            +
                            facts.write(ss, format::yaml, set<string>{}, true, false);
         | 
| 141 | 
            +
                            REQUIRE(ss.str() == "foo: bar\nhidden_foo: hidden_bar");
         | 
| 142 | 
            +
                        }
         | 
| 143 | 
            +
                        THEN("it should serialize both facts to text") {
         | 
| 144 | 
            +
                            ostringstream ss;
         | 
| 145 | 
            +
                            facts.write(ss, format::hash, set<string>{}, true, false);
         | 
| 146 | 
            +
                            REQUIRE(ss.str() == "foo => bar\nhidden_foo => hidden_bar");
         | 
| 147 | 
            +
                        }
         | 
| 148 | 
            +
                    }
         | 
| 149 | 
            +
                    WHEN("querying facts") {
         | 
| 150 | 
            +
                        THEN("it should serialize both facts to JSON") {
         | 
| 151 | 
            +
                            ostringstream ss;
         | 
| 152 | 
            +
                            facts.write(ss, format::json, {"foo", "hidden_foo"});
         | 
| 153 | 
            +
                            REQUIRE(ss.str() == "{\n  \"foo\": \"bar\",\n  \"hidden_foo\": \"hidden_bar\"\n}");
         | 
| 154 | 
            +
                        }
         | 
| 155 | 
            +
                        THEN("it should serialize both facts to YAML") {
         | 
| 156 | 
            +
                            ostringstream ss;
         | 
| 157 | 
            +
                            facts.write(ss, format::yaml, {"foo", "hidden_foo"});
         | 
| 158 | 
            +
                            REQUIRE(ss.str() == "foo: bar\nhidden_foo: hidden_bar");
         | 
| 159 | 
            +
                        }
         | 
| 160 | 
            +
                        THEN("it should serialize both facts to text") {
         | 
| 161 | 
            +
                            ostringstream ss;
         | 
| 162 | 
            +
                            facts.write(ss, format::hash, {"foo", "hidden_foo"});
         | 
| 163 | 
            +
                            REQUIRE(ss.str() == "foo => bar\nhidden_foo => hidden_bar");
         | 
| 164 | 
            +
                        }
         | 
| 165 | 
            +
                    }
         | 
| 166 | 
            +
                    WHEN("querying hidden facts") {
         | 
| 167 | 
            +
                        THEN("it should serialize both facts to JSON") {
         | 
| 168 | 
            +
                            ostringstream ss;
         | 
| 169 | 
            +
                            facts.write(ss, format::json, {"foo", "hidden_foo"}, true, false);
         | 
| 170 | 
            +
                            REQUIRE(ss.str() == "{\n  \"foo\": \"bar\",\n  \"hidden_foo\": \"hidden_bar\"\n}");
         | 
| 171 | 
            +
                        }
         | 
| 172 | 
            +
                        THEN("it should serialize both facts to YAML") {
         | 
| 173 | 
            +
                            ostringstream ss;
         | 
| 174 | 
            +
                            facts.write(ss, format::yaml, {"foo", "hidden_foo"}, true, false);
         | 
| 175 | 
            +
                            REQUIRE(ss.str() == "foo: bar\nhidden_foo: hidden_bar");
         | 
| 176 | 
            +
                        }
         | 
| 177 | 
            +
                        THEN("it should serialize both facts to text") {
         | 
| 178 | 
            +
                            ostringstream ss;
         | 
| 179 | 
            +
                            facts.write(ss, format::hash, {"foo", "hidden_foo"}, true, false);
         | 
| 180 | 
            +
                            REQUIRE(ss.str() == "foo => bar\nhidden_foo => hidden_bar");
         | 
| 181 | 
            +
                        }
         | 
| 182 | 
            +
                    }
         | 
| 183 | 
            +
                }
         | 
| 184 | 
            +
                GIVEN("a resolver that adds a single fact") {
         | 
| 185 | 
            +
                    facts.add(make_shared<simple_resolver>());
         | 
| 186 | 
            +
                    THEN("it should resolve facts into the collection") {
         | 
| 187 | 
            +
                        REQUIRE(facts.size() == 1u);
         | 
| 188 | 
            +
                        REQUIRE_FALSE(facts.empty());
         | 
| 189 | 
            +
                        auto fact = facts.get<string_value>("foo");
         | 
| 190 | 
            +
                        REQUIRE(fact);
         | 
| 191 | 
            +
                        REQUIRE(fact->value() == "bar");
         | 
| 192 | 
            +
                        fact = dynamic_cast<string_value const *>(facts["foo"]);
         | 
| 193 | 
            +
                        REQUIRE(fact);
         | 
| 194 | 
            +
                        REQUIRE(fact->value() == "bar");
         | 
| 195 | 
            +
                    }
         | 
| 196 | 
            +
                    WHEN("serializing to JSON") {
         | 
| 197 | 
            +
                        THEN("it should contain the same values") {
         | 
| 198 | 
            +
                            ostringstream ss;
         | 
| 199 | 
            +
                            facts.write(ss, format::json);
         | 
| 200 | 
            +
                            REQUIRE(ss.str() == "{\n  \"foo\": \"bar\"\n}");
         | 
| 201 | 
            +
                        }
         | 
| 202 | 
            +
                    }
         | 
| 203 | 
            +
                    WHEN("serializing to YAML") {
         | 
| 204 | 
            +
                        THEN("it should contain the same values") {
         | 
| 205 | 
            +
                            ostringstream ss;
         | 
| 206 | 
            +
                            facts.write(ss, format::yaml);
         | 
| 207 | 
            +
                            REQUIRE(ss.str() == "foo: bar");
         | 
| 208 | 
            +
                        }
         | 
| 209 | 
            +
                    }
         | 
| 210 | 
            +
                    WHEN("serializing to text") {
         | 
| 211 | 
            +
                        GIVEN("only a single query") {
         | 
| 212 | 
            +
                            THEN("it should output only the value") {
         | 
| 213 | 
            +
                                ostringstream ss;
         | 
| 214 | 
            +
                                facts.write(ss, format::hash, {"foo"});
         | 
| 215 | 
            +
                                REQUIRE(ss.str() == "bar");
         | 
| 216 | 
            +
                            }
         | 
| 217 | 
            +
                        }
         | 
| 218 | 
            +
                        GIVEN("no queries") {
         | 
| 219 | 
            +
                            THEN("it should contain the same values") {
         | 
| 220 | 
            +
                                ostringstream ss;
         | 
| 221 | 
            +
                                facts.write(ss, format::hash);
         | 
| 222 | 
            +
                                REQUIRE(ss.str() == "foo => bar");
         | 
| 223 | 
            +
                            }
         | 
| 224 | 
            +
                        }
         | 
| 225 | 
            +
                    }
         | 
| 226 | 
            +
                }
         | 
| 227 | 
            +
                GIVEN("a resolver that adds multiple facts") {
         | 
| 228 | 
            +
                    facts.add(make_shared<multi_resolver>());
         | 
| 229 | 
            +
                    THEN("it should enumerate the facts in order") {
         | 
| 230 | 
            +
                        int index = 0;
         | 
| 231 | 
            +
                        facts.each([&](string const &name, value const *val) {
         | 
| 232 | 
            +
                            auto string_val = dynamic_cast<string_value const *>(val);
         | 
| 233 | 
            +
                            REQUIRE(string_val);
         | 
| 234 | 
            +
                            if (index == 0) {
         | 
| 235 | 
            +
                                REQUIRE(name == "bar");
         | 
| 236 | 
            +
                                REQUIRE(string_val->value() == "foo");
         | 
| 237 | 
            +
                            } else if (index == 1) {
         | 
| 238 | 
            +
                                REQUIRE(name == "foo");
         | 
| 239 | 
            +
                                REQUIRE(string_val->value() == "bar");
         | 
| 240 | 
            +
                            } else {
         | 
| 241 | 
            +
                                FAIL("should not be reached");
         | 
| 242 | 
            +
                            }
         | 
| 243 | 
            +
                            ++index;
         | 
| 244 | 
            +
                            return true;
         | 
| 245 | 
            +
                        });
         | 
| 246 | 
            +
                    }
         | 
| 247 | 
            +
                    WHEN("serializing to JSON") {
         | 
| 248 | 
            +
                        THEN("it should contain the same values") {
         | 
| 249 | 
            +
                            ostringstream ss;
         | 
| 250 | 
            +
                            facts.write(ss, format::json);
         | 
| 251 | 
            +
                            REQUIRE(ss.str() == "{\n  \"bar\": \"foo\",\n  \"foo\": \"bar\"\n}");
         | 
| 252 | 
            +
                        }
         | 
| 253 | 
            +
                    }
         | 
| 254 | 
            +
                    WHEN("serializing to YAML") {
         | 
| 255 | 
            +
                        THEN("it should contain the same values") {
         | 
| 256 | 
            +
                            ostringstream ss;
         | 
| 257 | 
            +
                            facts.write(ss, format::yaml);
         | 
| 258 | 
            +
                            REQUIRE(ss.str() == "bar: foo\nfoo: bar");
         | 
| 259 | 
            +
                        }
         | 
| 260 | 
            +
                    }
         | 
| 261 | 
            +
                    WHEN("serializing to text") {
         | 
| 262 | 
            +
                        THEN("it should contain the same values") {
         | 
| 263 | 
            +
                            ostringstream ss;
         | 
| 264 | 
            +
                            facts.write(ss, format::hash);
         | 
| 265 | 
            +
                            REQUIRE(ss.str() == "bar => foo\nfoo => bar");
         | 
| 266 | 
            +
                        }
         | 
| 267 | 
            +
                    }
         | 
| 268 | 
            +
                }
         | 
| 269 | 
            +
                GIVEN("external facts paths to search") {
         | 
| 270 | 
            +
                    facts.add_external_facts({
         | 
| 271 | 
            +
                            LIBFACTER_TESTS_DIRECTORY "/fixtures/facts/external/yaml",
         | 
| 272 | 
            +
                            LIBFACTER_TESTS_DIRECTORY "/fixtures/facts/external/json",
         | 
| 273 | 
            +
                            LIBFACTER_TESTS_DIRECTORY "/fixtures/facts/external/text",
         | 
| 274 | 
            +
                    });
         | 
| 275 | 
            +
                    REQUIRE_FALSE(facts.empty());
         | 
| 276 | 
            +
                    REQUIRE(facts.size() == 20u);
         | 
| 277 | 
            +
                    WHEN("YAML files are present") {
         | 
| 278 | 
            +
                        THEN("facts should be added") {
         | 
| 279 | 
            +
                            REQUIRE(facts.get<string_value>("yaml_fact1"));
         | 
| 280 | 
            +
                            REQUIRE(facts.get<integer_value>("yaml_fact2"));
         | 
| 281 | 
            +
                            REQUIRE(facts.get<boolean_value>("yaml_fact3"));
         | 
| 282 | 
            +
                            REQUIRE(facts.get<double_value>("yaml_fact4"));
         | 
| 283 | 
            +
                            REQUIRE(facts.get<array_value>("yaml_fact5"));
         | 
| 284 | 
            +
                            REQUIRE(facts.get<map_value>("yaml_fact6"));
         | 
| 285 | 
            +
                            REQUIRE(facts.get<string_value>("yaml_fact7"));
         | 
| 286 | 
            +
                            REQUIRE(facts.get<string_value>("not_bool"));
         | 
| 287 | 
            +
                            REQUIRE(facts.get<string_value>("not_int"));
         | 
| 288 | 
            +
                            REQUIRE(facts.get<string_value>("not_double"));
         | 
| 289 | 
            +
                        }
         | 
| 290 | 
            +
                    }
         | 
| 291 | 
            +
                    WHEN("JSON files are present") {
         | 
| 292 | 
            +
                        THEN("facts should be added") {
         | 
| 293 | 
            +
                            REQUIRE(facts.get<string_value>("json_fact1"));
         | 
| 294 | 
            +
                            REQUIRE(facts.get<integer_value>("json_fact2"));
         | 
| 295 | 
            +
                            REQUIRE(facts.get<boolean_value>("json_fact3"));
         | 
| 296 | 
            +
                            REQUIRE(facts.get<double_value>("json_fact4"));
         | 
| 297 | 
            +
                            REQUIRE(facts.get<array_value>("json_fact5"));
         | 
| 298 | 
            +
                            REQUIRE(facts.get<map_value>("json_fact6"));
         | 
| 299 | 
            +
                            REQUIRE(facts.get<string_value>("json_fact7"));
         | 
| 300 | 
            +
                        }
         | 
| 301 | 
            +
                    }
         | 
| 302 | 
            +
                    WHEN("text files are present") {
         | 
| 303 | 
            +
                        THEN("facts should be added") {
         | 
| 304 | 
            +
                            REQUIRE(facts.get<string_value>("txt_fact1"));
         | 
| 305 | 
            +
                            REQUIRE(facts.get<string_value>("txt_fact2"));
         | 
| 306 | 
            +
                            REQUIRE_FALSE(facts.get<string_value>("txt_fact3"));
         | 
| 307 | 
            +
                            REQUIRE(facts.get<string_value>("txt_fact4"));
         | 
| 308 | 
            +
                        }
         | 
| 309 | 
            +
                    }
         | 
| 310 | 
            +
                }
         | 
| 311 | 
            +
                GIVEN("structured fact data") {
         | 
| 312 | 
            +
                    auto map = make_value<map_value>();
         | 
| 313 | 
            +
                    map->add("string", make_value<string_value>("hello"));
         | 
| 314 | 
            +
                    map->add("integer", make_value<integer_value>(5));
         | 
| 315 | 
            +
                    map->add("double", make_value<double_value>(0.3));
         | 
| 316 | 
            +
                    map->add("boolean", make_value<boolean_value>(true));
         | 
| 317 | 
            +
                    auto submap = make_value<map_value>();
         | 
| 318 | 
            +
                    submap->add("foo", make_value<string_value>("bar"));
         | 
| 319 | 
            +
                    map->add("submap", move(submap));
         | 
| 320 | 
            +
                    submap = make_value<map_value>();
         | 
| 321 | 
            +
                    submap->add("jam", make_value<string_value>("cakes"));
         | 
| 322 | 
            +
                    map->add("name.with.dots", move(submap));
         | 
| 323 | 
            +
                    auto array = make_value<array_value>();
         | 
| 324 | 
            +
                    array->add(make_value<string_value>("foo"));
         | 
| 325 | 
            +
                    array->add(make_value<integer_value>(10));
         | 
| 326 | 
            +
                    array->add(make_value<double_value>(2.3));
         | 
| 327 | 
            +
                    array->add(make_value<boolean_value>(false));
         | 
| 328 | 
            +
                    submap = make_value<map_value>();
         | 
| 329 | 
            +
                    submap->add("bar", make_value<string_value>("baz"));
         | 
| 330 | 
            +
                    array->add(move(submap));
         | 
| 331 | 
            +
                    map->add("array", move(array));
         | 
| 332 | 
            +
                    facts.add("map", move(map));
         | 
| 333 | 
            +
                    facts.add("string", make_value<string_value>("world"));
         | 
| 334 | 
            +
             | 
| 335 | 
            +
                    WHEN("queried with a matching top level name") {
         | 
| 336 | 
            +
                        THEN("a value should be returned") {
         | 
| 337 | 
            +
                            auto mvalue = facts.query<map_value>("map");
         | 
| 338 | 
            +
                            REQUIRE(mvalue);
         | 
| 339 | 
            +
                            REQUIRE(mvalue->size() == 7u);
         | 
| 340 | 
            +
                        }
         | 
| 341 | 
            +
                    }
         | 
| 342 | 
            +
                    WHEN("queried with a non-matching top level name") {
         | 
| 343 | 
            +
                        THEN("it should return null") {
         | 
| 344 | 
            +
                            REQUIRE_FALSE(facts.query<string_value>("does not exist"));
         | 
| 345 | 
            +
                        }
         | 
| 346 | 
            +
                    }
         | 
| 347 | 
            +
                    WHEN("querying for a sub element of a type that is not a map") {
         | 
| 348 | 
            +
                        THEN("it should return null") {
         | 
| 349 | 
            +
                            REQUIRE_FALSE(facts.query<string_value>("string.foo"));
         | 
| 350 | 
            +
                        }
         | 
| 351 | 
            +
                    }
         | 
| 352 | 
            +
                    WHEN("queried with for a sub element") {
         | 
| 353 | 
            +
                        THEN("a value should be returned") {
         | 
| 354 | 
            +
                            auto svalue = facts.query<string_value>("map.string");
         | 
| 355 | 
            +
                            REQUIRE(svalue);
         | 
| 356 | 
            +
                            REQUIRE(svalue->value() == "hello");
         | 
| 357 | 
            +
                            auto ivalue = facts.query<integer_value>("map.integer");
         | 
| 358 | 
            +
                            REQUIRE(ivalue);
         | 
| 359 | 
            +
                            REQUIRE(ivalue->value() == 5);
         | 
| 360 | 
            +
                            auto dvalue = facts.query<double_value>("map.double");
         | 
| 361 | 
            +
                            REQUIRE(dvalue);
         | 
| 362 | 
            +
                            REQUIRE(dvalue->value() == Approx(0.3));
         | 
| 363 | 
            +
                            auto bvalue = facts.query<boolean_value>("map.boolean");
         | 
| 364 | 
            +
                            REQUIRE(bvalue);
         | 
| 365 | 
            +
                            REQUIRE(bvalue->value());
         | 
| 366 | 
            +
                            auto mvalue = facts.query<map_value>("map.submap");
         | 
| 367 | 
            +
                            REQUIRE(mvalue);
         | 
| 368 | 
            +
                            REQUIRE(mvalue->size() == 1u);
         | 
| 369 | 
            +
                        }
         | 
| 370 | 
            +
                    }
         | 
| 371 | 
            +
                    WHEN("querying along a path of map values") {
         | 
| 372 | 
            +
                        THEN("a value should be returned") {
         | 
| 373 | 
            +
                            auto svalue = facts.query<string_value>("map.submap.foo");
         | 
| 374 | 
            +
                            REQUIRE(svalue);
         | 
| 375 | 
            +
                            REQUIRE(svalue->value() == "bar");
         | 
| 376 | 
            +
                        }
         | 
| 377 | 
            +
                    }
         | 
| 378 | 
            +
                    WHEN("querying into an array with an in-bounds index") {
         | 
| 379 | 
            +
                        THEN("a value should be returned") {
         | 
| 380 | 
            +
                            auto avalue = facts.query<array_value>("map.array");
         | 
| 381 | 
            +
                            REQUIRE(avalue);
         | 
| 382 | 
            +
                            REQUIRE(avalue->size() == 5u);
         | 
| 383 | 
            +
                            for (size_t i = 0; i < avalue->size(); ++i) {
         | 
| 384 | 
            +
                                REQUIRE(facts.query("map.array." + to_string(i)));
         | 
| 385 | 
            +
                            }
         | 
| 386 | 
            +
                        }
         | 
| 387 | 
            +
                    }
         | 
| 388 | 
            +
                    WHEN("querying into an array with a non-numeric index") {
         | 
| 389 | 
            +
                        THEN("it should return null") {
         | 
| 390 | 
            +
                            REQUIRE_FALSE(facts.query("map.array.foo"));
         | 
| 391 | 
            +
                        }
         | 
| 392 | 
            +
                    }
         | 
| 393 | 
            +
                    WHEN("uerying into an array with an out-of-bounds index") {
         | 
| 394 | 
            +
                        THEN("it should return null") {
         | 
| 395 | 
            +
                            REQUIRE_FALSE(facts.query("map.array.5"));
         | 
| 396 | 
            +
                        }
         | 
| 397 | 
            +
                    }
         | 
| 398 | 
            +
                    WHEN("querying into an element inside of an array") {
         | 
| 399 | 
            +
                        THEN("it should return a value") {
         | 
| 400 | 
            +
                            auto svalue = facts.query<string_value>("map.array.4.bar");
         | 
| 401 | 
            +
                            REQUIRE(svalue);
         | 
| 402 | 
            +
                            REQUIRE(svalue->value() == "baz");
         | 
| 403 | 
            +
                        }
         | 
| 404 | 
            +
                    }
         | 
| 405 | 
            +
                    WHEN("a fact name contains dots") {
         | 
| 406 | 
            +
                        THEN("it not return a value unless quoted") {
         | 
| 407 | 
            +
                            REQUIRE_FALSE(facts.query("map.name.with.dots"));
         | 
| 408 | 
            +
                        }
         | 
| 409 | 
            +
                        THEN("it should return a value when quoted") {
         | 
| 410 | 
            +
                            auto svalue = facts.query<string_value>("map.\"name.with.dots\".jam");
         | 
| 411 | 
            +
                            REQUIRE(svalue);
         | 
| 412 | 
            +
                            REQUIRE(svalue->value() == "cakes");
         | 
| 413 | 
            +
                        }
         | 
| 414 | 
            +
                    }
         | 
| 415 | 
            +
                }
         | 
| 416 | 
            +
                GIVEN("a fact from an environment variable") {
         | 
| 417 | 
            +
                    auto var = temp_variable("FACTER_Foo", "bar");
         | 
| 418 | 
            +
                    bool added = false;
         | 
| 419 | 
            +
                    facts.add_environment_facts([&](string const& name) {
         | 
| 420 | 
            +
                        added = name == "foo";
         | 
| 421 | 
            +
                    });
         | 
| 422 | 
            +
                    REQUIRE(added);
         | 
| 423 | 
            +
             | 
| 424 | 
            +
                    THEN("the fact should be present in the collection") {
         | 
| 425 | 
            +
                        REQUIRE(facts.size() == 1u);
         | 
| 426 | 
            +
                        auto value = facts.get<string_value>("foo");
         | 
| 427 | 
            +
                        REQUIRE(value);
         | 
| 428 | 
            +
                        REQUIRE(value->value() == "bar");
         | 
| 429 | 
            +
                    }
         | 
| 430 | 
            +
                }
         | 
| 431 | 
            +
                GIVEN("a fact from an environment with the same name as a built-in fact") {
         | 
| 432 | 
            +
                    facts.add_default_facts(true);
         | 
| 433 | 
            +
                    auto var = temp_variable("FACTER_KERNEL", "overridden");
         | 
| 434 | 
            +
                    bool added = false;
         | 
| 435 | 
            +
                    facts.add_environment_facts([&](string const& name) {
         | 
| 436 | 
            +
                        added = name == "kernel";
         | 
| 437 | 
            +
                    });
         | 
| 438 | 
            +
                    REQUIRE(added);
         | 
| 439 | 
            +
             | 
| 440 | 
            +
                    THEN("it should override the built-in fact's value") {
         | 
| 441 | 
            +
                        auto value = facts.get<string_value>("kernel");
         | 
| 442 | 
            +
                        REQUIRE(value);
         | 
| 443 | 
            +
                        REQUIRE(value->value() == "overridden");
         | 
| 444 | 
            +
                    }
         | 
| 445 | 
            +
                }
         | 
| 446 | 
            +
                GIVEN("two external fact directories to search") {
         | 
| 447 | 
            +
                    facts.add_external_facts({
         | 
| 448 | 
            +
                        LIBFACTER_TESTS_DIRECTORY "/fixtures/facts/external/ordering/foo",
         | 
| 449 | 
            +
                        LIBFACTER_TESTS_DIRECTORY "/fixtures/facts/external/ordering/bar"
         | 
| 450 | 
            +
                    });
         | 
| 451 | 
            +
                    THEN("it should have the fact value from the last file loaded") {
         | 
| 452 | 
            +
                        REQUIRE(facts.size() == 1u);
         | 
| 453 | 
            +
                        REQUIRE(facts.get<string_value>("foo"));
         | 
| 454 | 
            +
                        REQUIRE(facts.get<string_value>("foo")->value() == "set in bar/foo.yaml");
         | 
| 455 | 
            +
                    }
         | 
| 456 | 
            +
                    facts.clear();
         | 
| 457 | 
            +
                    facts.add_external_facts({
         | 
| 458 | 
            +
                        LIBFACTER_TESTS_DIRECTORY "/fixtures/facts/external/ordering/bar",
         | 
| 459 | 
            +
                        LIBFACTER_TESTS_DIRECTORY "/fixtures/facts/external/ordering/foo"
         | 
| 460 | 
            +
                    });
         | 
| 461 | 
            +
                    THEN("it should have the fact value from the last file loaded") {
         | 
| 462 | 
            +
                        REQUIRE(facts.size() == 1u);
         | 
| 463 | 
            +
                        REQUIRE(facts.get<string_value>("foo"));
         | 
| 464 | 
            +
                        REQUIRE(facts.get<string_value>("foo")->value() == "set in foo/foo.yaml");
         | 
| 465 | 
            +
                    }
         | 
| 466 | 
            +
                }
         | 
| 467 | 
            +
            }
         | 
| 468 | 
            +
             | 
| 469 | 
            +
            class collection_override : public collection
         | 
| 470 | 
            +
            {
         | 
| 471 | 
            +
             protected:
         | 
| 472 | 
            +
                virtual vector<string> get_external_fact_directories() const override
         | 
| 473 | 
            +
                {
         | 
| 474 | 
            +
                    return {LIBFACTER_TESTS_DIRECTORY "/fixtures/facts/external/ordering/foo"};
         | 
| 475 | 
            +
                }
         | 
| 476 | 
            +
            };
         | 
| 477 | 
            +
             | 
| 478 | 
            +
            SCENARIO("using the fact collection with a default external fact path") {
         | 
| 479 | 
            +
                collection_override facts;
         | 
| 480 | 
            +
                REQUIRE(facts.size() == 0u);
         | 
| 481 | 
            +
                REQUIRE(facts.empty());
         | 
| 482 | 
            +
             | 
| 483 | 
            +
                GIVEN("a specified external fact directory with an overriding fact to search") {
         | 
| 484 | 
            +
                    facts.add_external_facts({
         | 
| 485 | 
            +
                        LIBFACTER_TESTS_DIRECTORY "/fixtures/facts/external/ordering/bar"
         | 
| 486 | 
            +
                    });
         | 
| 487 | 
            +
                    THEN("it should have the fact value from the last file loaded") {
         | 
| 488 | 
            +
                        REQUIRE(facts.size() == 1u);
         | 
| 489 | 
            +
                        REQUIRE(facts.get<string_value>("foo"));
         | 
| 490 | 
            +
                        REQUIRE(facts.get<string_value>("foo")->value() == "set in bar/foo.yaml");
         | 
| 491 | 
            +
                    }
         | 
| 492 | 
            +
                }
         | 
| 493 | 
            +
             | 
| 494 | 
            +
                GIVEN("a specified external fact directory with new facts to search") {
         | 
| 495 | 
            +
                    facts.add_external_facts({
         | 
| 496 | 
            +
                        LIBFACTER_TESTS_DIRECTORY "/fixtures/facts/external/text",
         | 
| 497 | 
            +
                    });
         | 
| 498 | 
            +
                    REQUIRE_FALSE(facts.empty());
         | 
| 499 | 
            +
                    REQUIRE(facts.size() == 4u);
         | 
| 500 | 
            +
                    THEN("facts from both directories should be added") {
         | 
| 501 | 
            +
                        REQUIRE(facts.get<string_value>("foo"));
         | 
| 502 | 
            +
                        REQUIRE(facts.get<string_value>("txt_fact1"));
         | 
| 503 | 
            +
                        REQUIRE(facts.get<string_value>("txt_fact2"));
         | 
| 504 | 
            +
                        REQUIRE_FALSE(facts.get<string_value>("txt_fact3"));
         | 
| 505 | 
            +
                        REQUIRE(facts.get<string_value>("txt_fact4"));
         | 
| 506 | 
            +
                    }
         | 
| 507 | 
            +
                }
         | 
| 508 | 
            +
            }
         | 
| 509 | 
            +
             | 
| 510 | 
            +
            SCENARIO("using the fact collection with a blocklist") {
         | 
| 511 | 
            +
                collection_fixture facts({ "test" });
         | 
| 512 | 
            +
                REQUIRE(facts.size() == 0u);
         | 
| 513 | 
            +
                REQUIRE(facts.empty());
         | 
| 514 | 
            +
             | 
| 515 | 
            +
                GIVEN("a resolver that adds a single fact") {
         | 
| 516 | 
            +
                    facts.add(make_shared<simple_resolver>());
         | 
| 517 | 
            +
                    THEN("the fact should not be resolved") {
         | 
| 518 | 
            +
                        REQUIRE(facts.size() == 0u);
         | 
| 519 | 
            +
                        REQUIRE_FALSE(facts.get<string_value>("foo"));
         | 
| 520 | 
            +
                    }
         | 
| 521 | 
            +
                }
         | 
| 522 | 
            +
                GIVEN("a resolver that adds multiple facts") {
         | 
| 523 | 
            +
                    facts.add(make_shared<multi_resolver>());
         | 
| 524 | 
            +
                    THEN("none of the facts should resolve") {
         | 
| 525 | 
            +
                        REQUIRE(facts.size() == 0u);
         | 
| 526 | 
            +
                        REQUIRE_FALSE(facts.get<string_value>("foo"));
         | 
| 527 | 
            +
                        REQUIRE_FALSE(facts.get<string_value>("bar"));
         | 
| 528 | 
            +
                    }
         | 
| 529 | 
            +
                }
         | 
| 530 | 
            +
            }
         | 
| 531 | 
            +
             | 
| 532 | 
            +
            SCENARIO("querying blockable and cacheable fact groups") {
         | 
| 533 | 
            +
                collection_fixture facts;
         | 
| 534 | 
            +
                REQUIRE(facts.size() == 0u);
         | 
| 535 | 
            +
                REQUIRE(facts.empty());
         | 
| 536 | 
            +
             | 
| 537 | 
            +
                GIVEN("a blockable resolver that adds a single fact") {
         | 
| 538 | 
            +
                    facts.add(make_shared<simple_resolver>());
         | 
| 539 | 
            +
                    THEN("resolver and its fact should be listed as blockable") {
         | 
| 540 | 
            +
                        auto blockable = facts.get_blockable_fact_groups();
         | 
| 541 | 
            +
                        REQUIRE(blockable.size() == 1);
         | 
| 542 | 
            +
                        REQUIRE(blockable["test"] == vector<string>({"foo"}));
         | 
| 543 | 
            +
                    }
         | 
| 544 | 
            +
                    THEN("resolver and its fact should be listed as in the collection") {
         | 
| 545 | 
            +
                        auto facts_present = facts.get_fact_groups();
         | 
| 546 | 
            +
                        REQUIRE(facts_present.size() == 1);
         | 
| 547 | 
            +
                        REQUIRE(facts_present["test"] == vector<string>({"foo"}));
         | 
| 548 | 
            +
                    }
         | 
| 549 | 
            +
                }
         | 
| 550 | 
            +
                GIVEN("a blockable resolver that adds multiple facts") {
         | 
| 551 | 
            +
                    facts.add(make_shared<multi_resolver>());
         | 
| 552 | 
            +
                    THEN("resolver and its facts should be listed as blockable") {
         | 
| 553 | 
            +
                        auto blockable = facts.get_blockable_fact_groups();
         | 
| 554 | 
            +
                        REQUIRE(blockable.size() == 1);
         | 
| 555 | 
            +
                        REQUIRE(blockable["test"] == vector<string>({"foo", "bar"}));
         | 
| 556 | 
            +
                    }
         | 
| 557 | 
            +
                    THEN("resolver and its facts should be listed as in the collection") {
         | 
| 558 | 
            +
                        auto facts_present = facts.get_fact_groups();
         | 
| 559 | 
            +
                        REQUIRE(facts_present.size() == 1);
         | 
| 560 | 
            +
                        REQUIRE(facts_present["test"] == vector<string>({"foo", "bar"}));
         | 
| 561 | 
            +
                    }
         | 
| 562 | 
            +
                }
         | 
| 563 | 
            +
                GIVEN("a unblockable resolver that adds a single fact") {
         | 
| 564 | 
            +
                    facts.add(make_shared<unblockable_resolver>());
         | 
| 565 | 
            +
                    THEN("resolver and its facts should not be listed as blockable") {
         | 
| 566 | 
            +
                        auto blockable = facts.get_blockable_fact_groups();
         | 
| 567 | 
            +
                        REQUIRE(blockable.size() == 0);
         | 
| 568 | 
            +
                    }
         | 
| 569 | 
            +
                    THEN("resolver and its fact should be listed as in the collection") {
         | 
| 570 | 
            +
                        auto facts_present = facts.get_fact_groups();
         | 
| 571 | 
            +
                        REQUIRE(facts_present.size() == 1);
         | 
| 572 | 
            +
                        REQUIRE(facts_present["unblockable"] == vector<string>({"foo"}));
         | 
| 573 | 
            +
                    }
         | 
| 574 | 
            +
                }
         | 
| 575 | 
            +
             | 
| 576 | 
            +
            }
         |