File tree 4 files changed +5
-40
lines changed
4 files changed +5
-40
lines changed Original file line number Diff line number Diff line change @@ -223,7 +223,9 @@ def sync
223
223
newparam ( :path ) do
224
224
desc "The search path used for command execution.
225
225
Commands must be fully qualified if no path is specified. Paths
226
- can be specified as an array or as a '#{ File ::PATH_SEPARATOR } ' separated list."
226
+ can be specified as an array or as a '#{ File ::PATH_SEPARATOR } ' separated list. Defaults to the `path` fact."
227
+
228
+ defaultto Puppet . runtime [ :facter ] . value ( 'path' )
227
229
228
230
# Support both arrays and colon-separated fields.
229
231
def value = ( *values )
Original file line number Diff line number Diff line change @@ -649,31 +649,6 @@ def with_another_agent_running(&block)
649
649
) ) . to_stdout
650
650
. and output ( /No more routes to fileserver/ ) . to_stderr
651
651
end
652
-
653
- it 'preserves the old cached catalog if validation fails with the old one' do
654
- catalog_handler = -> ( req , res ) {
655
- catalog = compile_to_catalog ( <<-MANIFEST , node )
656
- exec { 'unqualified_command': }
657
- MANIFEST
658
-
659
- res . body = formatter . render ( catalog )
660
- res [ 'Content-Type' ] = formatter . mime
661
- }
662
-
663
- server . start_server ( mounts : { catalog : catalog_handler } ) do |port |
664
- Puppet [ :serverport ] = port
665
- expect {
666
- agent . command_line . args << '--test'
667
- agent . run
668
- } . to exit_with ( 1 )
669
- . and output ( %r{Retrieving plugin} ) . to_stdout
670
- . and output ( %r{Validation of Exec\[ unqualified_command\] failed: 'unqualified_command' is not qualified and no path was specified} ) . to_stderr
671
- end
672
-
673
- # cached catalog should not be updated
674
- cached_catalog = "#{ File . join ( Puppet [ :client_datadir ] , 'catalog' , Puppet [ :certname ] ) } .json"
675
- expect ( File ) . to_not be_exist ( cached_catalog )
676
- end
677
652
end
678
653
679
654
context "reporting" do
Original file line number Diff line number Diff line change @@ -73,20 +73,6 @@ def echo_from_ruby_exit_1(message)
73
73
end
74
74
75
75
context "when validating the command" do
76
- it "redacts the arguments if the command is relative" do
77
- expect {
78
- apply_compiled_manifest ( <<-MANIFEST )
79
- exec { 'echo':
80
- command => Sensitive.new('echo #{ supersecret } ')
81
- }
82
- MANIFEST
83
- } . to raise_error do |err |
84
- expect ( err ) . to be_a ( Puppet ::Error )
85
- expect ( err . message ) . to match ( /'echo' is not qualified and no path was specified. Please qualify the command or specify a path./ )
86
- expect ( err . message ) . to_not match ( /#{ supersecret } / )
87
- end
88
- end
89
-
90
76
it "redacts the arguments if the command is a directory" do
91
77
dir = tmpdir ( 'exec' )
92
78
apply_compiled_manifest ( <<-MANIFEST )
Original file line number Diff line number Diff line change @@ -910,6 +910,8 @@ def instance(path)
910
910
let :abs do make_absolute ( '/bin/echo' ) end
911
911
let :path do make_absolute ( '/bin' ) end
912
912
913
+ allow ( Facter ) . to receive ( :value ) . with ( 'path' ) . and_return ( '/usr/bin:/bin' )
914
+
913
915
it "should fail with relative command and no path" do
914
916
expect { type . new ( :command => rel ) } .
915
917
to raise_error Puppet ::Error , /no path was specified/
You can’t perform that action at this time.
0 commit comments