1
+ # frozen_string_literal: true
2
+ #
3
+ # ------------------------------------------------------------------------------
4
+ # NOTICE: **This file is maintained with puppetsync**
5
+ #
6
+ # This file is automatically updated as part of a puppet module baseline.
7
+ # The next baseline sync will overwrite any local changes made to this file.
8
+ # ------------------------------------------------------------------------------
9
+
1
10
require 'puppetlabs_spec_helper/module_spec_helper'
2
11
require 'rspec-puppet'
3
12
require 'simp/rspec-puppet-facts'
7
16
8
17
# RSpec Material
9
18
fixture_path = File . expand_path ( File . join ( __FILE__ , '..' , 'fixtures' ) )
10
- module_name = File . basename ( File . expand_path ( File . join ( __FILE__ , '../..' ) ) )
19
+ module_name = File . basename ( File . expand_path ( File . join ( __FILE__ , '../..' ) ) )
11
20
12
- # Add fixture lib dirs to LOAD_PATH. Work-around for PUP-3336
13
- if Puppet . version < "4.0.0"
14
- Dir [ "#{ fixture_path } /modules/*/lib" ] . entries . each do |lib_dir |
15
- $LOAD_PATH << lib_dir
16
- end
21
+ if ENV [ 'PUPPET_DEBUG' ]
22
+ Puppet ::Util ::Log . level = :debug
23
+ Puppet ::Util ::Log . newdestination ( :console )
17
24
end
18
25
19
-
20
- if !ENV . key? ( 'TRUSTED_NODE_DATA' )
21
- warn '== WARNING: TRUSTED_NODE_DATA is unset, using TRUSTED_NODE_DATA=yes'
22
- ENV [ 'TRUSTED_NODE_DATA' ] = 'yes'
23
- end
24
-
25
- default_hiera_config = <<-EOM
26
+ default_hiera_config = <<~HIERA_CONFIG
26
27
---
27
28
version: 5
28
29
hierarchy:
39
40
defaults:
40
41
data_hash: yaml_data
41
42
datadir: "stub"
42
- EOM
43
+ HIERA_CONFIG
43
44
44
45
# This can be used from inside your spec tests to set the testable environment.
45
46
# You can use this to stub out an ENC.
52
53
# end
53
54
#
54
55
def set_environment ( environment = :production )
55
- RSpec . configure { |c | c . default_facts [ 'environment' ] = environment . to_s }
56
+ RSpec . configure { |c | c . default_facts [ 'environment' ] = environment . to_s }
56
57
end
57
58
58
59
# This can be used from inside your spec tests to load custom hieradata within
@@ -74,39 +75,39 @@ def set_environment(environment = :production)
74
75
#
75
76
# Note: Any colons (:) are replaced with underscores (_) in the class name.
76
77
def set_hieradata ( hieradata )
77
- RSpec . configure { |c | c . default_facts [ 'custom_hiera' ] = hieradata }
78
+ RSpec . configure { |c | c . default_facts [ 'custom_hiera' ] = hieradata }
78
79
end
79
80
80
- if not File . directory? ( File . join ( fixture_path , 'hieradata' ) ) then
81
- FileUtils . mkdir_p ( File . join ( fixture_path , 'hieradata' ) )
81
+ unless File . directory? ( File . join ( fixture_path , 'hieradata' ) )
82
+ FileUtils . mkdir_p ( File . join ( fixture_path , 'hieradata' ) )
82
83
end
83
84
84
- if not File . directory? ( File . join ( fixture_path , 'modules' , module_name ) ) then
85
- FileUtils . mkdir_p ( File . join ( fixture_path , 'modules' , module_name ) )
85
+ unless File . directory? ( File . join ( fixture_path , 'modules' , module_name ) )
86
+ FileUtils . mkdir_p ( File . join ( fixture_path , 'modules' , module_name ) )
86
87
end
87
88
88
89
RSpec . configure do |c |
89
90
# If nothing else...
90
91
c . default_facts = {
91
- : production => {
92
+ production : {
92
93
#:fqdn => 'production.rspec.test.localdomain',
93
- : path => '/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin' ,
94
- : concat_basedir => '/tmp'
94
+ path : '/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin' ,
95
+ concat_basedir : '/tmp'
95
96
}
96
97
}
97
98
98
99
c . mock_framework = :rspec
99
- c . mock_with :mocha
100
+ c . mock_with :rspec
100
101
101
102
c . module_path = File . join ( fixture_path , 'modules' )
102
103
c . manifest_dir = File . join ( fixture_path , 'manifests' ) if c . respond_to? ( :manifest_dir )
103
104
104
- c . hiera_config = File . join ( fixture_path , 'hieradata' , 'hiera.yaml' )
105
+ c . hiera_config = File . join ( fixture_path , 'hieradata' , 'hiera.yaml' )
105
106
106
107
# Useless backtrace noise
107
108
backtrace_exclusion_patterns = [
108
- / spec_helper/ ,
109
- / gems/
109
+ %r{ spec_helper} ,
110
+ %r{ gems} ,
110
111
]
111
112
112
113
if c . respond_to? ( :backtrace_exclusion_patterns )
@@ -115,9 +116,10 @@ def set_hieradata(hieradata)
115
116
c . backtrace_clean_patterns = backtrace_exclusion_patterns
116
117
end
117
118
119
+ # rubocop:disable RSpec/BeforeAfterAll
118
120
c . before ( :all ) do
119
- data = YAML . load ( default_hiera_config )
120
- data . keys . each do |key |
121
+ data = YAML . safe_load ( default_hiera_config )
122
+ data . each_key do |key |
121
123
next unless data [ key ] . is_a? ( Hash )
122
124
123
125
if data [ key ] [ :datadir ] == 'stub'
@@ -131,26 +133,27 @@ def set_hieradata(hieradata)
131
133
f . write data . to_yaml
132
134
end
133
135
end
136
+ # rubocop:enable RSpec/BeforeAfterAll
134
137
135
138
c . before ( :each ) do
136
139
@spec_global_env_temp = Dir . mktmpdir ( 'simpspec' )
137
140
138
141
if defined? ( environment )
139
142
set_environment ( environment )
140
- FileUtils . mkdir_p ( File . join ( @spec_global_env_temp , environment . to_s ) )
143
+ FileUtils . mkdir_p ( File . join ( @spec_global_env_temp , environment . to_s ) )
141
144
end
142
145
143
146
# ensure the user running these tests has an accessible environmentpath
147
+ Puppet [ :digest_algorithm ] = 'sha256'
144
148
Puppet [ :environmentpath ] = @spec_global_env_temp
145
149
Puppet [ :user ] = Etc . getpwuid ( Process . uid ) . name
146
150
Puppet [ :group ] = Etc . getgrgid ( Process . gid ) . name
147
- Puppet [ :digest_algorithm ] = 'sha256'
148
151
149
152
# sanitize hieradata
150
153
if defined? ( hieradata )
151
- set_hieradata ( hieradata . gsub ( ':' , '_' ) )
154
+ set_hieradata ( hieradata . gsub ( ':' , '_' ) )
152
155
elsif defined? ( class_name )
153
- set_hieradata ( class_name . gsub ( ':' , '_' ) )
156
+ set_hieradata ( class_name . gsub ( ':' , '_' ) )
154
157
end
155
158
end
156
159
@@ -164,7 +167,7 @@ def set_hieradata(hieradata)
164
167
Dir . glob ( "#{ RSpec . configuration . module_path } /*" ) . each do |dir |
165
168
begin
166
169
Pathname . new ( dir ) . realpath
167
- rescue
168
- fail "ERROR: The module '#{ dir } ' is not installed. Tests cannot continue."
170
+ rescue StandardError
171
+ raise "ERROR: The module '#{ dir } ' is not installed. Tests cannot continue."
169
172
end
170
173
end
0 commit comments