puppet 3.1.1 → 3.2.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of puppet might be problematic. Click here for more details.
- data/CONTRIBUTING.md +2 -2
- data/Gemfile +32 -19
- data/README_DEVELOPER.md +332 -14
- data/Rakefile +9 -5
- data/ext/build_defaults.yaml +2 -3
- data/ext/debian/changelog.erb +6 -0
- data/ext/debian/control +6 -6
- data/ext/envpuppet +4 -4
- data/ext/project_data.yaml +1 -0
- data/ext/puppet-nm-dispatcher +13 -0
- data/ext/redhat/puppet.spec.erb +17 -0
- data/ext/suse/client.init +1 -1
- data/ext/systemd/puppetagent.service +2 -2
- data/ext/systemd/puppetmaster.service +2 -2
- data/lib/hiera/scope.rb +29 -11
- data/lib/hiera_puppet.rb +1 -3
- data/lib/puppet/agent.rb +3 -3
- data/lib/puppet/application.rb +2 -2
- data/lib/puppet/application/agent.rb +27 -12
- data/lib/puppet/application/apply.rb +11 -1
- data/lib/puppet/application/describe.rb +1 -1
- data/lib/puppet/application/doc.rb +13 -9
- data/lib/puppet/application/filebucket.rb +0 -1
- data/lib/puppet/application/kick.rb +1 -0
- data/lib/puppet/application/master.rb +16 -8
- data/lib/puppet/daemon.rb +19 -64
- data/lib/puppet/defaults.rb +61 -5
- data/lib/puppet/error.rb +15 -4
- data/lib/puppet/external/nagios/grammar.ry +1 -1
- data/lib/puppet/external/nagios/makefile +1 -1
- data/lib/puppet/external/nagios/parser.rb +185 -618
- data/lib/puppet/external/pson/pure/parser.rb +47 -1
- data/lib/puppet/face/certificate.rb +3 -3
- data/lib/puppet/face/module.rb +1 -1
- data/lib/puppet/face/module/changes.rb +3 -1
- data/lib/puppet/face/module/uninstall.rb +1 -1
- data/lib/puppet/face/node/clean.rb +5 -5
- data/lib/puppet/feature/base.rb +3 -1
- data/lib/puppet/feature/libuser.rb +8 -0
- data/lib/puppet/file_serving/fileset.rb +9 -1
- data/lib/puppet/forge.rb +28 -5
- data/lib/puppet/forge/errors.rb +34 -0
- data/lib/puppet/forge/repository.rb +1 -1
- data/lib/puppet/indirector.rb +4 -1
- data/lib/puppet/indirector/catalog/compiler.rb +37 -30
- data/lib/puppet/indirector/facts/inventory_active_record.rb +1 -0
- data/lib/puppet/indirector/indirection.rb +28 -15
- data/lib/puppet/indirector/rest.rb +18 -10
- data/lib/puppet/interface.rb +11 -4
- data/lib/puppet/interface/action.rb +1 -3
- data/lib/puppet/interface/action_builder.rb +0 -3
- data/lib/puppet/interface/action_manager.rb +0 -3
- data/lib/puppet/interface/face_collection.rb +0 -2
- data/lib/puppet/interface/option.rb +0 -2
- data/lib/puppet/interface/option_builder.rb +0 -2
- data/lib/puppet/interface/option_manager.rb +0 -2
- data/lib/puppet/metatype/manager.rb +1 -1
- data/lib/puppet/module_tool.rb +1 -0
- data/lib/puppet/module_tool/applications/application.rb +0 -3
- data/lib/puppet/module_tool/applications/builder.rb +8 -20
- data/lib/puppet/module_tool/applications/checksummer.rb +1 -1
- data/lib/puppet/module_tool/applications/installer.rb +1 -0
- data/lib/puppet/module_tool/applications/unpacker.rb +3 -11
- data/lib/puppet/module_tool/checksums.rb +1 -1
- data/lib/puppet/module_tool/errors/installer.rb +18 -1
- data/lib/puppet/module_tool/modulefile.rb +2 -2
- data/lib/puppet/module_tool/skeleton/templates/generator/Modulefile.erb +1 -1
- data/lib/puppet/module_tool/tar.rb +17 -0
- data/lib/puppet/module_tool/tar/gnu.rb +9 -0
- data/lib/puppet/module_tool/tar/mini.rb +39 -0
- data/lib/puppet/module_tool/tar/solaris.rb +5 -0
- data/lib/puppet/network/http.rb +1 -0
- data/lib/puppet/network/http/connection.rb +9 -23
- data/lib/puppet/network/http/handler.rb +38 -7
- data/lib/puppet/network/http/rack/rest.rb +14 -3
- data/lib/puppet/network/http/webrick.rb +3 -1
- data/lib/puppet/network/http/webrick/rest.rb +11 -2
- data/lib/puppet/node/environment.rb +3 -1
- data/lib/puppet/parameter.rb +32 -29
- data/lib/puppet/parameter/package_options.rb +1 -1
- data/lib/puppet/parameter/path.rb +1 -1
- data/lib/puppet/parameter/value.rb +1 -1
- data/lib/puppet/parameter/value_collection.rb +7 -3
- data/lib/puppet/parser/ast.rb +3 -1
- data/lib/puppet/parser/ast/arithmetic_operator.rb +56 -12
- data/lib/puppet/parser/ast/astarray.rb +1 -1
- data/lib/puppet/parser/ast/block_expression.rb +41 -0
- data/lib/puppet/parser/ast/function.rb +13 -2
- data/lib/puppet/parser/ast/lambda.rb +107 -0
- data/lib/puppet/parser/ast/leaf.rb +1 -2
- data/lib/puppet/parser/ast/method_call.rb +77 -0
- data/lib/puppet/parser/ast/vardef.rb +7 -0
- data/lib/puppet/parser/compiler.rb +27 -16
- data/lib/puppet/parser/e_parser_adapter.rb +120 -0
- data/lib/puppet/parser/files.rb +7 -6
- data/lib/puppet/parser/functions.rb +10 -8
- data/lib/puppet/parser/functions/collect.rb +43 -0
- data/lib/puppet/parser/functions/each.rb +96 -0
- data/lib/puppet/parser/functions/foreach.rb +96 -0
- data/lib/puppet/parser/functions/fqdn_rand.rb +2 -2
- data/lib/puppet/parser/functions/hiera.rb +20 -2
- data/lib/puppet/parser/functions/hiera_array.rb +21 -2
- data/lib/puppet/parser/functions/hiera_hash.rb +23 -2
- data/lib/puppet/parser/functions/hiera_include.rb +33 -2
- data/lib/puppet/parser/functions/inline_template.rb +4 -4
- data/lib/puppet/parser/functions/reduce.rb +74 -0
- data/lib/puppet/parser/functions/reject.rb +46 -0
- data/lib/puppet/parser/functions/select.rb +46 -0
- data/lib/puppet/parser/functions/slice.rb +96 -0
- data/lib/puppet/parser/functions/template.rb +2 -2
- data/lib/puppet/parser/grammar.ra +7 -4
- data/lib/puppet/parser/lexer.rb +10 -0
- data/lib/puppet/parser/methods.rb +69 -0
- data/lib/puppet/parser/parser.rb +855 -808
- data/lib/puppet/parser/parser_factory.rb +62 -0
- data/lib/puppet/parser/parser_support.rb +8 -2
- data/lib/puppet/parser/scope.rb +153 -47
- data/lib/puppet/parser/templatewrapper.rb +28 -21
- data/lib/puppet/parser/type_loader.rb +3 -1
- data/lib/puppet/pops.rb +40 -0
- data/lib/puppet/pops/adaptable.rb +190 -0
- data/lib/puppet/pops/adapters.rb +65 -0
- data/lib/puppet/pops/containment.rb +37 -0
- data/lib/puppet/pops/issues.rb +258 -0
- data/lib/puppet/pops/label_provider.rb +71 -0
- data/lib/puppet/pops/model/ast_transformer.rb +636 -0
- data/lib/puppet/pops/model/ast_tree_dumper.rb +378 -0
- data/lib/puppet/pops/model/factory.rb +804 -0
- data/lib/puppet/pops/model/model.rb +567 -0
- data/lib/puppet/pops/model/model_label_provider.rb +75 -0
- data/lib/puppet/pops/model/model_tree_dumper.rb +352 -0
- data/lib/puppet/pops/model/tree_dumper.rb +59 -0
- data/lib/puppet/pops/parser/egrammar.ra +723 -0
- data/lib/puppet/pops/parser/eparser.rb +2300 -0
- data/lib/puppet/pops/parser/grammar.ra +746 -0
- data/lib/puppet/pops/parser/lexer.rb +842 -0
- data/lib/puppet/pops/parser/makefile +13 -0
- data/lib/puppet/pops/parser/parser_support.rb +203 -0
- data/lib/puppet/pops/patterns.rb +35 -0
- data/lib/puppet/pops/utils.rb +104 -0
- data/lib/puppet/pops/validation.rb +297 -0
- data/lib/puppet/pops/validation/checker3_1.rb +551 -0
- data/lib/puppet/pops/validation/validator_factory_3_1.rb +41 -0
- data/lib/puppet/pops/visitable.rb +6 -0
- data/lib/puppet/pops/visitor.rb +50 -0
- data/lib/puppet/property.rb +37 -28
- data/lib/puppet/property/ensure.rb +2 -2
- data/lib/puppet/property/ordered_list.rb +1 -1
- data/lib/puppet/provider.rb +26 -30
- data/lib/puppet/provider/aixobject.rb +45 -44
- data/lib/puppet/provider/augeas/augeas.rb +0 -1
- data/lib/puppet/provider/confiner.rb +1 -1
- data/lib/puppet/provider/cron/crontab.rb +107 -67
- data/lib/puppet/provider/group/groupadd.rb +59 -3
- data/lib/puppet/provider/interface/cisco.rb +4 -4
- data/lib/puppet/provider/mount/parsed.rb +1 -1
- data/lib/puppet/provider/nameservice.rb +22 -6
- data/lib/puppet/provider/nameservice/pw.rb +1 -1
- data/lib/puppet/provider/package/aix.rb +28 -4
- data/lib/puppet/provider/package/gem.rb +0 -2
- data/lib/puppet/provider/package/macports.rb +1 -1
- data/lib/puppet/provider/package/nim.rb +249 -4
- data/lib/puppet/provider/package/opkg.rb +77 -0
- data/lib/puppet/provider/package/pacman.rb +2 -2
- data/lib/puppet/provider/package/rpm.rb +30 -16
- data/lib/puppet/provider/package/yum.rb +3 -3
- data/lib/puppet/provider/parsedfile.rb +80 -3
- data/lib/puppet/provider/selmodule/semodule.rb +2 -2
- data/lib/puppet/provider/service/debian.rb +0 -4
- data/lib/puppet/provider/service/freebsd.rb +2 -2
- data/lib/puppet/provider/service/gentoo.rb +0 -9
- data/lib/puppet/provider/service/init.rb +27 -2
- data/lib/puppet/provider/service/launchd.rb +1 -1
- data/lib/puppet/provider/service/openwrt.rb +36 -0
- data/lib/puppet/provider/service/redhat.rb +0 -9
- data/lib/puppet/provider/service/src.rb +38 -4
- data/lib/puppet/provider/service/systemd.rb +2 -2
- data/lib/puppet/provider/service/upstart.rb +1 -8
- data/lib/puppet/provider/user/aix.rb +4 -10
- data/lib/puppet/provider/user/pw.rb +6 -10
- data/lib/puppet/provider/user/useradd.rb +129 -31
- data/lib/puppet/provider/vlan/cisco.rb +4 -4
- data/lib/puppet/reference/function.rb +2 -2
- data/lib/puppet/reference/indirection.rb +46 -5
- data/lib/puppet/reference/metaparameter.rb +2 -2
- data/lib/puppet/reports.rb +5 -5
- data/lib/puppet/reports/rrdgraph.rb +4 -4
- data/lib/puppet/reports/tagmail.rb +1 -1
- data/lib/puppet/resource.rb +1 -1
- data/lib/puppet/resource/type.rb +13 -11
- data/lib/puppet/scheduler.rb +16 -0
- data/lib/puppet/scheduler/job.rb +53 -0
- data/lib/puppet/scheduler/scheduler.rb +45 -0
- data/lib/puppet/scheduler/splay_job.rb +32 -0
- data/lib/puppet/scheduler/timer.rb +13 -0
- data/lib/puppet/settings/base_setting.rb +1 -1
- data/lib/puppet/simple_graph.rb +4 -4
- data/lib/puppet/ssl/base.rb +12 -2
- data/lib/puppet/ssl/certificate.rb +4 -1
- data/lib/puppet/ssl/certificate_request.rb +4 -1
- data/lib/puppet/ssl/certificate_revocation_list.rb +4 -1
- data/lib/puppet/ssl/configuration.rb +32 -0
- data/lib/puppet/ssl/host.rb +18 -21
- data/lib/puppet/ssl/key.rb +4 -1
- data/lib/puppet/ssl/validator.rb +116 -0
- data/lib/puppet/transaction.rb +1 -1
- data/lib/puppet/transaction/event.rb +3 -10
- data/lib/puppet/transaction/event_manager.rb +8 -1
- data/lib/puppet/transaction/report.rb +17 -16
- data/lib/puppet/type.rb +77 -69
- data/lib/puppet/type/cron.rb +20 -8
- data/lib/puppet/type/exec.rb +9 -3
- data/lib/puppet/type/file.rb +95 -21
- data/lib/puppet/type/file/content.rb +1 -1
- data/lib/puppet/type/file/mode.rb +7 -1
- data/lib/puppet/type/file/source.rb +2 -2
- data/lib/puppet/type/group.rb +11 -0
- data/lib/puppet/type/scheduled_task.rb +5 -1
- data/lib/puppet/type/service.rb +1 -1
- data/lib/puppet/type/ssh_authorized_key.rb +2 -2
- data/lib/puppet/type/user.rb +24 -6
- data/lib/puppet/util.rb +12 -2
- data/lib/puppet/util/classgen.rb +4 -4
- data/lib/puppet/util/colors.rb +55 -0
- data/lib/puppet/util/command_line/trollop.rb +4 -4
- data/lib/puppet/util/errors.rb +39 -3
- data/lib/puppet/util/fileparsing.rb +5 -0
- data/lib/puppet/util/filetype.rb +11 -9
- data/lib/puppet/util/instrumentation/instrumentable.rb +2 -2
- data/lib/puppet/util/libuser.conf +15 -0
- data/lib/puppet/util/libuser.rb +12 -0
- data/lib/puppet/util/monkey_patches.rb +48 -0
- data/lib/puppet/util/network_device.rb +1 -1
- data/lib/puppet/util/network_device/base.rb +2 -2
- data/lib/puppet/util/network_device/cisco/device.rb +29 -19
- data/lib/puppet/util/network_device/config.rb +5 -2
- data/lib/puppet/util/network_device/ipcalc.rb +1 -1
- data/lib/puppet/util/network_device/transport/ssh.rb +4 -3
- data/lib/puppet/util/network_device/transport/telnet.rb +4 -2
- data/lib/puppet/util/plugins.rb +4 -4
- data/lib/puppet/util/posix.rb +1 -1
- data/lib/puppet/util/profiler.rb +28 -0
- data/lib/puppet/util/profiler/logging.rb +47 -0
- data/lib/puppet/util/profiler/none.rb +8 -0
- data/lib/puppet/util/profiler/object_counts.rb +17 -0
- data/lib/puppet/util/profiler/wall_clock.rb +34 -0
- data/lib/puppet/util/provider_features.rb +1 -1
- data/lib/puppet/util/rdoc/parser.rb +5 -5
- data/lib/puppet/util/ssl.rb +38 -0
- data/lib/puppet/util/subclass_loader.rb +1 -5
- data/lib/puppet/util/windows.rb +1 -0
- data/lib/puppet/util/windows/process.rb +3 -0
- data/lib/puppet/util/windows/root_certs.rb +86 -0
- data/lib/puppet/util/windows/security.rb +1 -0
- data/lib/puppet/version.rb +1 -1
- data/spec/fixtures/integration/provider/cron/crontab/create_normal_entry +19 -0
- data/spec/fixtures/integration/provider/cron/crontab/create_special_entry +18 -0
- data/spec/fixtures/integration/provider/cron/crontab/crontab_user1 +15 -0
- data/spec/fixtures/integration/provider/cron/crontab/crontab_user2 +4 -0
- data/spec/fixtures/integration/provider/cron/crontab/modify_entry +13 -0
- data/spec/fixtures/integration/provider/cron/crontab/moved_cronjob_input1 +15 -0
- data/spec/fixtures/integration/provider/cron/crontab/moved_cronjob_input2 +6 -0
- data/spec/fixtures/integration/provider/cron/crontab/remove_named_resource +12 -0
- data/spec/fixtures/integration/provider/cron/crontab/remove_unnamed_resource +14 -0
- data/spec/fixtures/unit/pops/parser/lexer/aliastest.pp +16 -0
- data/spec/fixtures/unit/pops/parser/lexer/append.pp +11 -0
- data/spec/fixtures/unit/pops/parser/lexer/argumentdefaults.pp +14 -0
- data/spec/fixtures/unit/pops/parser/lexer/arithmetic_expression.pp +8 -0
- data/spec/fixtures/unit/pops/parser/lexer/arraytrailingcomma.pp +3 -0
- data/spec/fixtures/unit/pops/parser/lexer/casestatement.pp +65 -0
- data/spec/fixtures/unit/pops/parser/lexer/classheirarchy.pp +15 -0
- data/spec/fixtures/unit/pops/parser/lexer/classincludes.pp +17 -0
- data/spec/fixtures/unit/pops/parser/lexer/classpathtest.pp +11 -0
- data/spec/fixtures/unit/pops/parser/lexer/collection.pp +10 -0
- data/spec/fixtures/unit/pops/parser/lexer/collection_override.pp +8 -0
- data/spec/fixtures/unit/pops/parser/lexer/collection_within_virtual_definitions.pp +20 -0
- data/spec/fixtures/unit/pops/parser/lexer/componentmetaparams.pp +11 -0
- data/spec/fixtures/unit/pops/parser/lexer/componentrequire.pp +8 -0
- data/spec/fixtures/unit/pops/parser/lexer/deepclassheirarchy.pp +23 -0
- data/spec/fixtures/unit/pops/parser/lexer/defineoverrides.pp +17 -0
- data/spec/fixtures/unit/pops/parser/lexer/emptyclass.pp +9 -0
- data/spec/fixtures/unit/pops/parser/lexer/emptyexec.pp +3 -0
- data/spec/fixtures/unit/pops/parser/lexer/emptyifelse.pp +9 -0
- data/spec/fixtures/unit/pops/parser/lexer/falsevalues.pp +3 -0
- data/spec/fixtures/unit/pops/parser/lexer/filecreate.pp +11 -0
- data/spec/fixtures/unit/pops/parser/lexer/fqdefinition.pp +5 -0
- data/spec/fixtures/unit/pops/parser/lexer/fqparents.pp +11 -0
- data/spec/fixtures/unit/pops/parser/lexer/funccomma.pp +5 -0
- data/spec/fixtures/unit/pops/parser/lexer/hash.pp +33 -0
- data/spec/fixtures/unit/pops/parser/lexer/ifexpression.pp +12 -0
- data/spec/fixtures/unit/pops/parser/lexer/implicititeration.pp +15 -0
- data/spec/fixtures/unit/pops/parser/lexer/multilinecomments.pp +10 -0
- data/spec/fixtures/unit/pops/parser/lexer/multipleclass.pp +9 -0
- data/spec/fixtures/unit/pops/parser/lexer/multipleinstances.pp +7 -0
- data/spec/fixtures/unit/pops/parser/lexer/multisubs.pp +13 -0
- data/spec/fixtures/unit/pops/parser/lexer/namevartest.pp +9 -0
- data/spec/fixtures/unit/pops/parser/lexer/scopetest.pp +13 -0
- data/spec/fixtures/unit/pops/parser/lexer/selectorvalues.pp +49 -0
- data/spec/fixtures/unit/pops/parser/lexer/simpledefaults.pp +5 -0
- data/spec/fixtures/unit/pops/parser/lexer/simpleselector.pp +38 -0
- data/spec/fixtures/unit/pops/parser/lexer/singleary.pp +19 -0
- data/spec/fixtures/unit/pops/parser/lexer/singlequote.pp +11 -0
- data/spec/fixtures/unit/pops/parser/lexer/singleselector.pp +22 -0
- data/spec/fixtures/unit/pops/parser/lexer/subclass_name_duplication.pp +11 -0
- data/spec/fixtures/unit/pops/parser/lexer/tag.pp +9 -0
- data/spec/fixtures/unit/pops/parser/lexer/tagged.pp +35 -0
- data/spec/fixtures/unit/pops/parser/lexer/virtualresources.pp +14 -0
- data/spec/fixtures/unit/provider/cron/crontab/single_line.yaml +4 -4
- data/spec/fixtures/unit/provider/cron/crontab/vixie_header.txt +3 -0
- data/spec/fixtures/unit/provider/cron/parsed/managed +6 -0
- data/spec/fixtures/unit/provider/cron/parsed/simple +9 -0
- data/spec/fixtures/unit/provider/parsedfile/simple.txt +4 -0
- data/spec/fixtures/unit/provider/service/systemd/list_units +18 -0
- data/spec/integration/parser/collector_spec.rb +1 -1
- data/spec/integration/parser/compiler_spec.rb +252 -227
- data/spec/integration/parser/parser_spec.rb +171 -53
- data/spec/integration/parser/scope_spec.rb +1 -1
- data/spec/integration/provider/cron/crontab_spec.rb +187 -0
- data/spec/integration/provider/service/systemd_spec.rb +20 -0
- data/spec/integration/type/file_spec.rb +21 -21
- data/spec/integration/type/package_spec.rb +1 -1
- data/spec/lib/puppet_spec/database.rb +2 -5
- data/spec/spec_helper.rb +6 -1
- data/spec/unit/application/apply_spec.rb +16 -1
- data/spec/unit/application/describe_spec.rb +1 -1
- data/spec/unit/application/doc_spec.rb +55 -32
- data/spec/unit/application/kick_spec.rb +8 -6
- data/spec/unit/application/master_spec.rb +4 -4
- data/spec/unit/daemon_spec.rb +1 -1
- data/spec/unit/forge/errors_spec.rb +40 -0
- data/spec/unit/forge/repository_spec.rb +11 -1
- data/spec/unit/forge_spec.rb +13 -3
- data/spec/unit/hiera/backend/puppet_backend_spec.rb +1 -0
- data/spec/unit/hiera/scope_spec.rb +48 -25
- data/spec/unit/indirector/catalog/active_record_spec.rb +6 -3
- data/spec/unit/indirector/catalog/compiler_spec.rb +3 -28
- data/spec/unit/indirector/catalog/static_compiler_spec.rb +1 -1
- data/spec/unit/indirector/facts/inventory_active_record_spec.rb +154 -150
- data/spec/unit/indirector/indirection_spec.rb +5 -0
- data/spec/unit/indirector/resource/active_record_spec.rb +5 -22
- data/spec/unit/indirector_spec.rb +7 -1
- data/spec/unit/interface/action_builder_spec.rb +1 -1
- data/spec/unit/interface/action_manager_spec.rb +0 -2
- data/spec/unit/interface/action_spec.rb +1 -1
- data/spec/unit/interface/documentation_spec.rb +0 -2
- data/spec/unit/interface/face_collection_spec.rb +1 -1
- data/spec/unit/interface/option_builder_spec.rb +1 -1
- data/spec/unit/interface/option_spec.rb +0 -1
- data/spec/unit/module_spec.rb +17 -19
- data/spec/unit/module_tool/application_spec.rb +1 -3
- data/spec/unit/module_tool/applications/builder_spec.rb +38 -0
- data/spec/unit/module_tool/applications/checksummer_spec.rb +134 -0
- data/spec/unit/module_tool/applications/installer_spec.rb +71 -91
- data/spec/unit/module_tool/applications/searcher_spec.rb +1 -3
- data/spec/unit/module_tool/applications/uninstaller_spec.rb +18 -26
- data/spec/unit/module_tool/applications/unpacker_spec.rb +19 -52
- data/spec/unit/module_tool/tar/gnu_spec.rb +19 -0
- data/spec/unit/module_tool/tar/mini_spec.rb +59 -0
- data/spec/unit/module_tool/tar/solaris_spec.rb +19 -0
- data/spec/unit/network/http/connection_spec.rb +17 -2
- data/spec/unit/network/http/handler_spec.rb +195 -167
- data/spec/unit/network/http/rack/rest_spec.rb +26 -4
- data/spec/unit/network/http/webrick/rest_spec.rb +28 -1
- data/spec/unit/network/http/webrick_spec.rb +12 -3
- data/spec/unit/node/environment_spec.rb +421 -404
- data/spec/unit/parser/ast/arithmetic_operator_spec.rb +98 -2
- data/spec/unit/parser/collector_spec.rb +4 -4
- data/spec/unit/parser/compiler_spec.rb +13 -13
- data/spec/unit/parser/eparser_adapter_spec.rb +407 -0
- data/spec/unit/parser/functions/extlookup_spec.rb +20 -17
- data/spec/unit/parser/functions/fqdn_rand_spec.rb +5 -0
- data/spec/unit/parser/functions/hiera_include_spec.rb +0 -2
- data/spec/unit/parser/functions/hiera_spec.rb +0 -2
- data/spec/unit/parser/functions_spec.rb +27 -15
- data/spec/unit/parser/methods/collect_spec.rb +110 -0
- data/spec/unit/parser/methods/each_spec.rb +91 -0
- data/spec/unit/parser/methods/foreach_spec.rb +91 -0
- data/spec/unit/parser/methods/reduce_spec.rb +67 -0
- data/spec/unit/parser/methods/reject_spec.rb +73 -0
- data/spec/unit/parser/methods/select_spec.rb +79 -0
- data/spec/unit/parser/methods/shared.rb +61 -0
- data/spec/unit/parser/methods/slice_spec.rb +97 -0
- data/spec/unit/parser/parser_spec.rb +2 -2
- data/spec/unit/parser/scope_spec.rb +39 -16
- data/spec/unit/parser/templatewrapper_spec.rb +6 -5
- data/spec/unit/parser/type_loader_spec.rb +191 -165
- data/spec/unit/pops/adaptable_spec.rb +143 -0
- data/spec/unit/pops/containment_spec.rb +25 -0
- data/spec/unit/pops/factory_rspec_helper.rb +77 -0
- data/spec/unit/pops/factory_spec.rb +329 -0
- data/spec/unit/pops/issues_spec.rb +26 -0
- data/spec/unit/pops/label_provider_spec.rb +42 -0
- data/spec/unit/pops/model/ast_transformer_spec.rb +65 -0
- data/spec/unit/pops/model/model_spec.rb +37 -0
- data/spec/unit/pops/parser/lexer_spec.rb +884 -0
- data/spec/unit/pops/parser/parse_basic_expressions_spec.rb +248 -0
- data/spec/unit/pops/parser/parse_calls_spec.rb +93 -0
- data/spec/unit/pops/parser/parse_conditionals_spec.rb +159 -0
- data/spec/unit/pops/parser/parse_containers_spec.rb +175 -0
- data/spec/unit/pops/parser/parse_resource_spec.rb +228 -0
- data/spec/unit/pops/parser/parser_rspec_helper.rb +11 -0
- data/spec/unit/pops/parser/parser_spec.rb +15 -0
- data/spec/unit/pops/parser/rgen_sanitycheck_spec.rb +16 -0
- data/spec/unit/pops/transformer/transform_basic_expressions_spec.rb +243 -0
- data/spec/unit/pops/transformer/transform_calls_spec.rb +80 -0
- data/spec/unit/pops/transformer/transform_conditionals_spec.rb +132 -0
- data/spec/unit/pops/transformer/transform_containers_spec.rb +182 -0
- data/spec/unit/pops/transformer/transform_resource_spec.rb +185 -0
- data/spec/unit/pops/transformer/transformer_rspec_helper.rb +27 -0
- data/spec/unit/pops/visitor_spec.rb +94 -0
- data/spec/unit/property_spec.rb +11 -0
- data/spec/unit/provider/augeas/augeas_spec.rb +3 -0
- data/spec/unit/provider/cron/crontab_spec.rb +97 -7
- data/spec/unit/provider/cron/parsed_spec.rb +325 -0
- data/spec/unit/provider/exec/posix_spec.rb +1 -1
- data/spec/unit/provider/group/groupadd_spec.rb +33 -3
- data/spec/unit/provider/group/pw_spec.rb +5 -5
- data/spec/unit/provider/nameservice_spec.rb +304 -0
- data/spec/unit/provider/package/aix_spec.rb +53 -11
- data/spec/unit/provider/package/aptrpm_spec.rb +6 -0
- data/spec/unit/provider/package/gem_spec.rb +6 -11
- data/spec/unit/provider/package/nim_spec.rb +216 -7
- data/spec/unit/provider/package/opkg_spec.rb +180 -0
- data/spec/unit/provider/package/rpm_spec.rb +149 -3
- data/spec/unit/provider/package/yum_spec.rb +6 -5
- data/spec/unit/provider/parsedfile_spec.rb +122 -28
- data/spec/unit/provider/service/freebsd_spec.rb +18 -0
- data/spec/unit/provider/service/init_spec.rb +108 -87
- data/spec/unit/provider/service/launchd_spec.rb +2 -2
- data/spec/unit/provider/service/openwrt_spec.rb +109 -0
- data/spec/unit/provider/service/src_spec.rb +117 -41
- data/spec/unit/provider/service/systemd_spec.rb +125 -17
- data/spec/unit/provider/service/upstart_spec.rb +1 -1
- data/spec/unit/provider/user/aix_spec.rb +42 -0
- data/spec/unit/provider/user/directoryservice_spec.rb +1 -0
- data/spec/unit/provider/user/pw_spec.rb +24 -12
- data/spec/unit/provider/user/user_role_add_spec.rb +1 -1
- data/spec/unit/provider/user/useradd_spec.rb +179 -15
- data/spec/unit/resource/type_spec.rb +3 -3
- data/spec/unit/scheduler/job_spec.rb +79 -0
- data/spec/unit/scheduler/scheduler_spec.rb +129 -0
- data/spec/unit/scheduler/splay_job_spec.rb +35 -0
- data/spec/unit/ssl/base_spec.rb +3 -9
- data/spec/unit/ssl/certificate_authority_spec.rb +1 -0
- data/spec/unit/ssl/certificate_request_spec.rb +3 -1
- data/spec/unit/ssl/certificate_spec.rb +3 -1
- data/spec/unit/ssl/configuration_spec.rb +74 -0
- data/spec/unit/ssl/host_spec.rb +28 -7
- data/spec/unit/ssl/validator_spec.rb +311 -0
- data/spec/unit/transaction/event_manager_spec.rb +49 -0
- data/spec/unit/transaction/event_spec.rb +20 -5
- data/spec/unit/transaction/report_spec.rb +8 -0
- data/spec/unit/type/cron_spec.rb +9 -0
- data/spec/unit/type/exec_spec.rb +11 -0
- data/spec/unit/type/file/content_spec.rb +20 -20
- data/spec/unit/type/file/mode_spec.rb +6 -0
- data/spec/unit/type/file/source_spec.rb +9 -7
- data/spec/unit/type/file_spec.rb +22 -3
- data/spec/unit/type/service_spec.rb +34 -21
- data/spec/unit/type_spec.rb +46 -1
- data/spec/unit/util/backups_spec.rb +2 -2
- data/spec/unit/util/execution_spec.rb +4 -1
- data/spec/unit/util/filetype_spec.rb +6 -0
- data/spec/unit/util/monkey_patches_spec.rb +18 -0
- data/spec/unit/util/network_device/cisco/device_spec.rb +37 -0
- data/spec/unit/util/network_device/config_spec.rb +14 -0
- data/spec/unit/util/network_device_spec.rb +3 -3
- data/spec/unit/util/profiler/logging_spec.rb +81 -0
- data/spec/unit/util/profiler/none_spec.rb +12 -0
- data/spec/unit/util/profiler/object_counts_spec.rb +14 -0
- data/spec/unit/util/profiler/wall_clock_spec.rb +13 -0
- data/spec/unit/util/pson_spec.rb +5 -0
- data/spec/unit/util/ssl_spec.rb +51 -0
- data/spec/unit/util/windows/root_certs_spec.rb +15 -0
- data/spec/unit/util_spec.rb +28 -0
- metadata +2593 -2307
- data/spec/unit/module_tool/applications/application_spec.rb +0 -19
@@ -715,13 +715,13 @@ describe Puppet::Resource::Type do
|
|
715
715
|
dest.doc.should == "foonessyayness"
|
716
716
|
end
|
717
717
|
|
718
|
-
it "should turn its code into
|
718
|
+
it "should turn its code into a BlockExpression if necessary" do
|
719
719
|
dest = Puppet::Resource::Type.new(:hostclass, "bar", :code => code("foo"))
|
720
720
|
source = Puppet::Resource::Type.new(:hostclass, "foo", :code => code("bar"))
|
721
721
|
|
722
722
|
dest.merge(source)
|
723
723
|
|
724
|
-
dest.code.should be_instance_of(Puppet::Parser::AST::
|
724
|
+
dest.code.should be_instance_of(Puppet::Parser::AST::BlockExpression)
|
725
725
|
end
|
726
726
|
|
727
727
|
it "should set the other class's code as its code if it has none" do
|
@@ -742,7 +742,7 @@ describe Puppet::Resource::Type do
|
|
742
742
|
|
743
743
|
dest.merge(source)
|
744
744
|
|
745
|
-
dest.code.children.collect { |l| l.value }.should == %w{dest source}
|
745
|
+
dest.code.children.collect { |l| l[0].value }.should == %w{dest source}
|
746
746
|
end
|
747
747
|
end
|
748
748
|
end
|
@@ -0,0 +1,79 @@
|
|
1
|
+
#! /usr/bin/env ruby
|
2
|
+
require 'spec_helper'
|
3
|
+
require 'puppet/scheduler'
|
4
|
+
|
5
|
+
describe Puppet::Scheduler::Job do
|
6
|
+
let(:run_interval) { 10 }
|
7
|
+
let(:job) { described_class.new(run_interval) }
|
8
|
+
|
9
|
+
it "has a minimum run interval of 0" do
|
10
|
+
Puppet::Scheduler::Job.new(-1).run_interval.should == 0
|
11
|
+
end
|
12
|
+
|
13
|
+
describe "when not run yet" do
|
14
|
+
it "is ready" do
|
15
|
+
job.ready?(2).should be
|
16
|
+
end
|
17
|
+
|
18
|
+
it "gives the time to next run as 0" do
|
19
|
+
job.interval_to_next_from(2).should == 0
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
describe "when run at least once" do
|
24
|
+
let(:last_run) { 50 }
|
25
|
+
|
26
|
+
before(:each) do
|
27
|
+
job.run(last_run)
|
28
|
+
end
|
29
|
+
|
30
|
+
it "is ready when the time is greater than the last run plus the interval" do
|
31
|
+
job.ready?(last_run + run_interval + 1).should be
|
32
|
+
end
|
33
|
+
|
34
|
+
it "is ready when the time is equal to the last run plus the interval" do
|
35
|
+
job.ready?(last_run + run_interval).should be
|
36
|
+
end
|
37
|
+
|
38
|
+
it "is not ready when the time is less than the last run plus the interval" do
|
39
|
+
job.ready?(last_run + run_interval - 1).should_not be
|
40
|
+
end
|
41
|
+
|
42
|
+
context "when calculating the next run" do
|
43
|
+
it "returns the run interval if now == last run" do
|
44
|
+
job.interval_to_next_from(last_run).should == run_interval
|
45
|
+
end
|
46
|
+
|
47
|
+
it "when time is between the last and next runs gives the remaining portion of the run_interval" do
|
48
|
+
time_since_last_run = 2
|
49
|
+
now = last_run + time_since_last_run
|
50
|
+
job.interval_to_next_from(now).should == run_interval - time_since_last_run
|
51
|
+
end
|
52
|
+
|
53
|
+
it "when time is later than last+interval returns 0" do
|
54
|
+
time_since_last_run = run_interval + 5
|
55
|
+
now = last_run + time_since_last_run
|
56
|
+
job.interval_to_next_from(now).should == 0
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
it "starts enabled" do
|
62
|
+
job.enabled?.should be
|
63
|
+
end
|
64
|
+
|
65
|
+
it "can be disabled" do
|
66
|
+
job.disable
|
67
|
+
job.enabled?.should_not be
|
68
|
+
end
|
69
|
+
|
70
|
+
it "has the job instance as a parameter" do
|
71
|
+
passed_job = nil
|
72
|
+
job = Puppet::Scheduler::Job.new(run_interval) do |j|
|
73
|
+
passed_job = j
|
74
|
+
end
|
75
|
+
job.run(5)
|
76
|
+
|
77
|
+
passed_job.should eql(job)
|
78
|
+
end
|
79
|
+
end
|
@@ -0,0 +1,129 @@
|
|
1
|
+
#! /usr/bin/env ruby
|
2
|
+
require 'spec_helper'
|
3
|
+
require 'puppet/scheduler'
|
4
|
+
|
5
|
+
describe Puppet::Scheduler::Scheduler do
|
6
|
+
let(:now) { 183550 }
|
7
|
+
let(:timer) { MockTimer.new(now) }
|
8
|
+
|
9
|
+
class MockTimer
|
10
|
+
attr_reader :wait_for_calls
|
11
|
+
|
12
|
+
def initialize(start=1729)
|
13
|
+
@now = start
|
14
|
+
@wait_for_calls = []
|
15
|
+
end
|
16
|
+
|
17
|
+
def wait_for(seconds)
|
18
|
+
@wait_for_calls << seconds
|
19
|
+
@now += seconds
|
20
|
+
end
|
21
|
+
|
22
|
+
def now
|
23
|
+
@now
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
def one_time_job(interval)
|
28
|
+
Puppet::Scheduler::Job.new(interval) { |j| j.disable }
|
29
|
+
end
|
30
|
+
|
31
|
+
def disabled_job(interval)
|
32
|
+
job = Puppet::Scheduler::Job.new(interval) { |j| j.disable }
|
33
|
+
job.disable
|
34
|
+
job
|
35
|
+
end
|
36
|
+
|
37
|
+
it "uses the minimum interval" do
|
38
|
+
later_job = one_time_job(7)
|
39
|
+
earlier_job = one_time_job(2)
|
40
|
+
scheduler = Puppet::Scheduler::Scheduler.new([later_job, earlier_job], timer)
|
41
|
+
later_job.last_run = now
|
42
|
+
earlier_job.last_run = now
|
43
|
+
|
44
|
+
scheduler.run_loop
|
45
|
+
|
46
|
+
timer.wait_for_calls.should == [2, 5]
|
47
|
+
end
|
48
|
+
|
49
|
+
it "ignores disabled jobs when calculating intervals" do
|
50
|
+
enabled = one_time_job(7)
|
51
|
+
enabled.last_run = now
|
52
|
+
disabled = disabled_job(2)
|
53
|
+
scheduler = Puppet::Scheduler::Scheduler.new([enabled, disabled], timer)
|
54
|
+
|
55
|
+
scheduler.run_loop
|
56
|
+
|
57
|
+
timer.wait_for_calls.should == [7]
|
58
|
+
end
|
59
|
+
|
60
|
+
it "asks the timer to wait for the job interval" do
|
61
|
+
job = one_time_job(5)
|
62
|
+
job.last_run = now
|
63
|
+
scheduler = Puppet::Scheduler::Scheduler.new([job], timer)
|
64
|
+
|
65
|
+
scheduler.run_loop
|
66
|
+
|
67
|
+
timer.wait_for_calls.should == [5]
|
68
|
+
end
|
69
|
+
|
70
|
+
it "does not run when there are no jobs" do
|
71
|
+
timer = mock 'no run timer'
|
72
|
+
scheduler = Puppet::Scheduler::Scheduler.new([], timer)
|
73
|
+
|
74
|
+
timer.stubs(:now).returns(now)
|
75
|
+
timer.expects(:wait_for).never
|
76
|
+
|
77
|
+
scheduler.run_loop
|
78
|
+
end
|
79
|
+
|
80
|
+
it "does not run when there are only disabled jobs" do
|
81
|
+
timer = mock 'no run timer'
|
82
|
+
disabled_job = Puppet::Scheduler::Job.new(0)
|
83
|
+
scheduler = Puppet::Scheduler::Scheduler.new([disabled_job], timer)
|
84
|
+
|
85
|
+
disabled_job.disable
|
86
|
+
timer.stubs(:now).returns(now)
|
87
|
+
timer.expects(:wait_for).never
|
88
|
+
|
89
|
+
scheduler.run_loop
|
90
|
+
end
|
91
|
+
|
92
|
+
it "stops running when there are no more enabled jobs" do
|
93
|
+
timer = mock 'run once timer'
|
94
|
+
disabling_job = Puppet::Scheduler::Job.new(0) do |j|
|
95
|
+
j.disable
|
96
|
+
end
|
97
|
+
scheduler = Puppet::Scheduler::Scheduler.new([disabling_job], timer)
|
98
|
+
|
99
|
+
timer.stubs(:now).returns(now)
|
100
|
+
timer.expects(:wait_for).once
|
101
|
+
|
102
|
+
scheduler.run_loop
|
103
|
+
end
|
104
|
+
|
105
|
+
it "marks the start of the run loop" do
|
106
|
+
disabled_job = Puppet::Scheduler::Job.new(0)
|
107
|
+
|
108
|
+
disabled_job.disable
|
109
|
+
|
110
|
+
scheduler = Puppet::Scheduler::Scheduler.new([disabled_job], timer)
|
111
|
+
scheduler.run_loop
|
112
|
+
|
113
|
+
disabled_job.start_time.should == now
|
114
|
+
end
|
115
|
+
|
116
|
+
it "calculates the next interval from the start of a job" do
|
117
|
+
countdown = 2
|
118
|
+
slow_job = Puppet::Scheduler::Job.new(10) do |job|
|
119
|
+
timer.wait_for(3)
|
120
|
+
countdown -= 1
|
121
|
+
job.disable if countdown == 0
|
122
|
+
end
|
123
|
+
|
124
|
+
scheduler = Puppet::Scheduler::Scheduler.new([slow_job], timer)
|
125
|
+
scheduler.run_loop
|
126
|
+
|
127
|
+
timer.wait_for_calls.should == [0, 3, 7, 3]
|
128
|
+
end
|
129
|
+
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
#! /usr/bin/env ruby
|
2
|
+
require 'spec_helper'
|
3
|
+
require 'puppet/scheduler'
|
4
|
+
|
5
|
+
describe Puppet::Scheduler::SplayJob do
|
6
|
+
let(:run_interval) { 10 }
|
7
|
+
let(:last_run) { 50 }
|
8
|
+
let(:splay_limit) { 5 }
|
9
|
+
let(:start_time) { 23 }
|
10
|
+
let(:job) { described_class.new(run_interval, splay_limit) }
|
11
|
+
|
12
|
+
it "does not apply a splay after the first run" do
|
13
|
+
job.run(last_run)
|
14
|
+
job.interval_to_next_from(last_run).should == run_interval
|
15
|
+
end
|
16
|
+
|
17
|
+
it "calculates the first run splayed from the start time" do
|
18
|
+
job.start_time = start_time
|
19
|
+
|
20
|
+
job.interval_to_next_from(start_time).should == job.splay
|
21
|
+
end
|
22
|
+
|
23
|
+
it "interval to the next run decreases as time advances" do
|
24
|
+
time_passed = 3
|
25
|
+
job.start_time = start_time
|
26
|
+
|
27
|
+
job.interval_to_next_from(start_time + time_passed).should == job.splay - time_passed
|
28
|
+
end
|
29
|
+
|
30
|
+
it "is not immediately ready if splayed" do
|
31
|
+
job.start_time = start_time
|
32
|
+
job.expects(:splay).returns(6)
|
33
|
+
job.ready?(start_time).should_not be
|
34
|
+
end
|
35
|
+
end
|
data/spec/unit/ssl/base_spec.rb
CHANGED
@@ -38,16 +38,10 @@ describe Puppet::SSL::Certificate do
|
|
38
38
|
end
|
39
39
|
|
40
40
|
describe "when determining a name from a certificate subject" do
|
41
|
-
it "should
|
41
|
+
it "should extract only the CN and not any other components" do
|
42
42
|
subject = stub 'sub'
|
43
|
-
|
44
|
-
|
45
|
-
@class.name_from_subject(subject).should == 'foo'
|
46
|
-
end
|
47
|
-
|
48
|
-
it "should strip the prefix" do
|
49
|
-
subject = '/CN=foo'
|
50
|
-
@class.name_from_subject(subject).should == 'foo'
|
43
|
+
Puppet::Util::SSL.expects(:cn_from_subject).with(subject).returns 'host.domain.com'
|
44
|
+
@class.name_from_subject(subject).should == 'host.domain.com'
|
51
45
|
end
|
52
46
|
end
|
53
47
|
|
@@ -31,7 +31,9 @@ describe Puppet::SSL::CertificateRequest do
|
|
31
31
|
|
32
32
|
describe "when converting from a string" do
|
33
33
|
it "should create a CSR instance with its name set to the CSR subject and its content set to the extracted CSR" do
|
34
|
-
csr = stub 'csr',
|
34
|
+
csr = stub 'csr',
|
35
|
+
:subject => OpenSSL::X509::Name.parse("/CN=Foo.madstop.com"),
|
36
|
+
:is_a? => true
|
35
37
|
OpenSSL::X509::Request.expects(:new).with("my csr").returns(csr)
|
36
38
|
|
37
39
|
mycsr = stub 'sslcsr'
|
@@ -26,7 +26,9 @@ describe Puppet::SSL::Certificate do
|
|
26
26
|
|
27
27
|
describe "when converting from a string" do
|
28
28
|
it "should create a certificate instance with its name set to the certificate subject and its content set to the extracted certificate" do
|
29
|
-
cert = stub 'certificate',
|
29
|
+
cert = stub 'certificate',
|
30
|
+
:subject => OpenSSL::X509::Name.parse("/CN=Foo.madstop.com"),
|
31
|
+
:is_a? => true
|
30
32
|
OpenSSL::X509::Certificate.expects(:new).with("my certificate").returns(cert)
|
31
33
|
|
32
34
|
mycert = stub 'sslcert'
|
@@ -1,6 +1,7 @@
|
|
1
1
|
#! /usr/bin/env ruby
|
2
2
|
#
|
3
3
|
|
4
|
+
require 'spec_helper'
|
4
5
|
require 'puppet/ssl/configuration'
|
5
6
|
|
6
7
|
describe Puppet::SSL::Configuration do
|
@@ -40,6 +41,12 @@ describe Puppet::SSL::Configuration do
|
|
40
41
|
it "#ca_auth_file == ssl_server_ca_auth" do
|
41
42
|
subject.ca_auth_file.should == ssl_server_ca_auth
|
42
43
|
end
|
44
|
+
it "#ca_auth_certificates returns an Array<OpenSSL::X509::Certificate>" do
|
45
|
+
subject.stubs(:read_file).returns(master_ca_pem + root_ca_pem)
|
46
|
+
|
47
|
+
certs = subject.ca_auth_certificates
|
48
|
+
certs.each { |cert| cert.should be_a_kind_of OpenSSL::X509::Certificate }
|
49
|
+
end
|
43
50
|
end
|
44
51
|
|
45
52
|
context "Partially configured" do
|
@@ -57,4 +64,71 @@ describe Puppet::SSL::Configuration do
|
|
57
64
|
end
|
58
65
|
end
|
59
66
|
end
|
67
|
+
|
68
|
+
# This is the Intermediate CA specifically designated for issuing master
|
69
|
+
# certificates. It is signed by the Root CA.
|
70
|
+
def master_ca_pem
|
71
|
+
@master_ca_pem ||= <<-AUTH_BUNDLE
|
72
|
+
-----BEGIN CERTIFICATE-----
|
73
|
+
MIICljCCAf+gAwIBAgIBAjANBgkqhkiG9w0BAQUFADBJMRAwDgYDVQQDDAdSb290
|
74
|
+
IENBMRowGAYDVQQLDBFTZXJ2ZXIgT3BlcmF0aW9uczEZMBcGA1UECgwQRXhhbXBs
|
75
|
+
ZSBPcmcsIExMQzAeFw0xMzAzMzAwNTUwNDhaFw0zMzAzMjUwNTUwNDhaMH4xJDAi
|
76
|
+
BgNVBAMTG0ludGVybWVkaWF0ZSBDQSAobWFzdGVyLWNhKTEfMB0GCSqGSIb3DQEJ
|
77
|
+
ARYQdGVzdEBleGFtcGxlLm9yZzEZMBcGA1UEChMQRXhhbXBsZSBPcmcsIExMQzEa
|
78
|
+
MBgGA1UECxMRU2VydmVyIE9wZXJhdGlvbnMwXDANBgkqhkiG9w0BAQEFAANLADBI
|
79
|
+
AkEAvo/az3oR69SP92jGnUHMJLEyyD1Ui1BZ/rUABJcQTRQqn3RqtlfYePWZnUaZ
|
80
|
+
srKbXRS4q0w5Vqf1kx5w3q5tIwIDAQABo4GcMIGZMHkGA1UdIwRyMHCAFDBN1mqO
|
81
|
+
Nc4gUraE4zRtw6ueFDDaoU2kSzBJMRAwDgYDVQQDDAdSb290IENBMRowGAYDVQQL
|
82
|
+
DBFTZXJ2ZXIgT3BlcmF0aW9uczEZMBcGA1UECgwQRXhhbXBsZSBPcmcsIExMQ4IJ
|
83
|
+
ALf2Pk2HvtBzMA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgEGMA0GCSqGSIb3
|
84
|
+
DQEBBQUAA4GBACRfa1YPS7RQUuhYovGgV0VYqxuATC7WwdIRihVh5FceSXKgSIbz
|
85
|
+
BKmOBAy/KixEhpnHTbkpaJ0d9ITkvjMTmj3M5YMahKaQA5niVPckQPecMMd6jg9U
|
86
|
+
l1k75xLLIcrlsDYo3999KOSSchH2K7bLT7TuQ2okdP6FHWmeWmudewlu
|
87
|
+
-----END CERTIFICATE-----
|
88
|
+
AUTH_BUNDLE
|
89
|
+
end
|
90
|
+
|
91
|
+
# This is the Root CA
|
92
|
+
def root_ca_pem
|
93
|
+
@root_ca_pem ||= <<-LOCALCACERT
|
94
|
+
-----BEGIN CERTIFICATE-----
|
95
|
+
MIICYDCCAcmgAwIBAgIJALf2Pk2HvtBzMA0GCSqGSIb3DQEBBQUAMEkxEDAOBgNV
|
96
|
+
BAMMB1Jvb3QgQ0ExGjAYBgNVBAsMEVNlcnZlciBPcGVyYXRpb25zMRkwFwYDVQQK
|
97
|
+
DBBFeGFtcGxlIE9yZywgTExDMB4XDTEzMDMzMDA1NTA0OFoXDTMzMDMyNTA1NTA0
|
98
|
+
OFowSTEQMA4GA1UEAwwHUm9vdCBDQTEaMBgGA1UECwwRU2VydmVyIE9wZXJhdGlv
|
99
|
+
bnMxGTAXBgNVBAoMEEV4YW1wbGUgT3JnLCBMTEMwgZ8wDQYJKoZIhvcNAQEBBQAD
|
100
|
+
gY0AMIGJAoGBAMGSpafR4lboYOPfPJC1wVHHl0gD49ZVRjOlJ9jidEUjBdFXK6SA
|
101
|
+
S1tecDv2G4tM1ANmfMKjZl0m+KaZ8O2oq0g6kxkq1Mg0eSNvlnEyehjmTLRzHC2i
|
102
|
+
a0biH2wMtCLzfAoXDKy4GPlciBPE9mup5I8Kien5s91t92tc7K8AJ8oBAgMBAAGj
|
103
|
+
UDBOMB0GA1UdDgQWBBQwTdZqjjXOIFK2hOM0bcOrnhQw2jAfBgNVHSMEGDAWgBQw
|
104
|
+
TdZqjjXOIFK2hOM0bcOrnhQw2jAMBgNVHRMEBTADAQH/MA0GCSqGSIb3DQEBBQUA
|
105
|
+
A4GBACs8EZRrzgzAlcKC1Tz8GYlNHQg0XhpbEDm+p2mOV//PuDD190O+UBpWxo9Q
|
106
|
+
rrkkx8En0wXQZJf6iH3hwewwHLOq5yXZKbJN+SmvJvRNL95Yhyy08Y9N65tJveE7
|
107
|
+
rPsNU/Tx19jHC87oXlmAePLI4IaUHXrWb7CRbY9TEcPdmj1R
|
108
|
+
-----END CERTIFICATE-----
|
109
|
+
LOCALCACERT
|
110
|
+
end
|
111
|
+
|
112
|
+
# This is the intermediate CA designated to issue Agent SSL certs. It is
|
113
|
+
# signed by the Root CA.
|
114
|
+
def agent_ca_pem
|
115
|
+
@agent_ca_pem ||= <<-AGENT_CA
|
116
|
+
-----BEGIN CERTIFICATE-----
|
117
|
+
MIIClTCCAf6gAwIBAgIBATANBgkqhkiG9w0BAQUFADBJMRAwDgYDVQQDDAdSb290
|
118
|
+
IENBMRowGAYDVQQLDBFTZXJ2ZXIgT3BlcmF0aW9uczEZMBcGA1UECgwQRXhhbXBs
|
119
|
+
ZSBPcmcsIExMQzAeFw0xMzAzMzAwNTUwNDhaFw0zMzAzMjUwNTUwNDhaMH0xIzAh
|
120
|
+
BgNVBAMTGkludGVybWVkaWF0ZSBDQSAoYWdlbnQtY2EpMR8wHQYJKoZIhvcNAQkB
|
121
|
+
FhB0ZXN0QGV4YW1wbGUub3JnMRkwFwYDVQQKExBFeGFtcGxlIE9yZywgTExDMRow
|
122
|
+
GAYDVQQLExFTZXJ2ZXIgT3BlcmF0aW9uczBcMA0GCSqGSIb3DQEBAQUAA0sAMEgC
|
123
|
+
QQDkEj/Msmi4hJImxP5+ocixMTHuYC1M1E2p4QcuzOkZYrfHf+5hJMcahfYhLiXU
|
124
|
+
jHBredOXhgSisHh6CLSb/rKzAgMBAAGjgZwwgZkweQYDVR0jBHIwcIAUME3Wao41
|
125
|
+
ziBStoTjNG3Dq54UMNqhTaRLMEkxEDAOBgNVBAMMB1Jvb3QgQ0ExGjAYBgNVBAsM
|
126
|
+
EVNlcnZlciBPcGVyYXRpb25zMRkwFwYDVQQKDBBFeGFtcGxlIE9yZywgTExDggkA
|
127
|
+
t/Y+TYe+0HMwDwYDVR0TAQH/BAUwAwEB/zALBgNVHQ8EBAMCAQYwDQYJKoZIhvcN
|
128
|
+
AQEFBQADgYEAujSj9rxIxJHEuuYXb15L30yxs9Tdvy4OCLiKdjvs9Z7gG8Pbutls
|
129
|
+
ooCwyYAkmzKVs/8cYjZJnvJrPEW1gFwqX7Xknp85Cfrl+/pQEPYq5sZVa5BIm9tI
|
130
|
+
0EvlDax/Hd28jI6Bgq5fsTECNl9GDGknCy7vwRZem0h+hI56lzR3pYE=
|
131
|
+
-----END CERTIFICATE-----
|
132
|
+
AGENT_CA
|
133
|
+
end
|
60
134
|
end
|
data/spec/unit/ssl/host_spec.rb
CHANGED
@@ -710,17 +710,38 @@ describe Puppet::SSL::Host do
|
|
710
710
|
before do
|
711
711
|
@crl = stub 'crl', :content => "real_crl"
|
712
712
|
Puppet::SSL::CertificateRevocationList.indirection.stubs(:find).returns @crl
|
713
|
-
Puppet[:certificate_revocation] = true
|
714
713
|
end
|
715
714
|
|
716
|
-
|
717
|
-
|
718
|
-
|
715
|
+
describe "and 'certificate_revocation' is true" do
|
716
|
+
before do
|
717
|
+
Puppet[:certificate_revocation] = true
|
718
|
+
end
|
719
|
+
|
720
|
+
it "should add the CRL" do
|
721
|
+
@store.expects(:add_crl).with "real_crl"
|
722
|
+
@host.ssl_store
|
723
|
+
end
|
724
|
+
|
725
|
+
it "should set the flags to OpenSSL::X509::V_FLAG_CRL_CHECK_ALL|OpenSSL::X509::V_FLAG_CRL_CHECK" do
|
726
|
+
@store.expects(:flags=).with OpenSSL::X509::V_FLAG_CRL_CHECK_ALL|OpenSSL::X509::V_FLAG_CRL_CHECK
|
727
|
+
@host.ssl_store
|
728
|
+
end
|
719
729
|
end
|
720
730
|
|
721
|
-
|
722
|
-
|
723
|
-
|
731
|
+
describe "and 'certificate_revocation' is false" do
|
732
|
+
before do
|
733
|
+
Puppet[:certificate_revocation] = false
|
734
|
+
end
|
735
|
+
|
736
|
+
it "should not add the CRL" do
|
737
|
+
@store.expects(:add_crl).never
|
738
|
+
@host.ssl_store
|
739
|
+
end
|
740
|
+
|
741
|
+
it "should not set the flags" do
|
742
|
+
@store.expects(:flags=).never
|
743
|
+
@host.ssl_store
|
744
|
+
end
|
724
745
|
end
|
725
746
|
end
|
726
747
|
end
|