foodcritic 15.0.0 → 15.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (233) hide show
  1. checksums.yaml +4 -4
  2. data/chef_dsl_metadata/{chef_14.7.17.json → chef_14.8.12.json} +61 -1
  3. data/foodcritic.gemspec +1 -3
  4. data/lib/foodcritic/linter.rb +1 -1
  5. data/lib/foodcritic/version.rb +1 -1
  6. metadata +5 -232
  7. data/Rakefile +0 -73
  8. data/features/002_check_string_interpolation.feature +0 -50
  9. data/features/005_check_for_resource_repetition.feature +0 -64
  10. data/features/006_check_file_mode.feature +0 -36
  11. data/features/009_check_for_unrecognised_resource_attributes.feature +0 -55
  12. data/features/014_check_for_long_ruby_blocks.feature +0 -30
  13. data/features/018_check_for_old_lwrp_notification_syntax.feature +0 -25
  14. data/features/019_check_for_consistent_node_access.feature +0 -108
  15. data/features/021_check_for_dodgy_lwrp_conditions.feature +0 -28
  16. data/features/022_check_for_dodgy_conditions_within_loop.feature +0 -43
  17. data/features/024_check_for_missing_platforms.feature +0 -43
  18. data/features/027_check_for_internal_attribute_use.feature +0 -22
  19. data/features/030_check_for_debugger_breakpoints.feature +0 -25
  20. data/features/032_check_for_invalid_notification_timing.feature +0 -24
  21. data/features/033_check_for_missing_template.feature +0 -39
  22. data/features/034_check_for_unused_template_variables.feature +0 -80
  23. data/features/037_check_for_invalid_notification_action.feature +0 -34
  24. data/features/038_check_for_invalid_action.feature +0 -39
  25. data/features/039_check_for_key_access_to_node_methods.feature +0 -33
  26. data/features/044_check_for_bare_attribute_keys.feature +0 -53
  27. data/features/046_check_for_assign_unless_nil_attributes.feature +0 -21
  28. data/features/047_check_for_attribute_assignment_without_precedence.feature +0 -49
  29. data/features/051_check_for_template_partial_loops.feature +0 -40
  30. data/features/build_framework_support.feature +0 -109
  31. data/features/checking_all_types_of_file.feature +0 -40
  32. data/features/choose_rules_to_apply.feature +0 -47
  33. data/features/command_line_help.feature +0 -58
  34. data/features/continuous_integration_support.feature +0 -33
  35. data/features/exclude_paths_to_lint.feature +0 -12
  36. data/features/ignore_via_line_comments.feature +0 -69
  37. data/features/include_custom_rules.feature +0 -29
  38. data/features/individual_file.feature +0 -28
  39. data/features/limit_rules_to_specific_versions.feature +0 -65
  40. data/features/multiple_paths.feature +0 -35
  41. data/features/show_lines_matched.feature +0 -20
  42. data/features/sort_warnings.feature +0 -10
  43. data/features/specify_search_grammar.feature +0 -25
  44. data/features/step_definitions/cookbook_steps.rb +0 -1826
  45. data/features/support/command_helpers.rb +0 -418
  46. data/features/support/cookbook_helpers.rb +0 -599
  47. data/features/support/env.rb +0 -19
  48. data/man/foodcritic.1.ronn +0 -76
  49. data/spec/functional/fc001_spec.rb +0 -72
  50. data/spec/functional/fc004_spec.rb +0 -84
  51. data/spec/functional/fc007_spec.rb +0 -127
  52. data/spec/functional/fc008_spec.rb +0 -33
  53. data/spec/functional/fc009_spec.rb +0 -37
  54. data/spec/functional/fc010_spec.rb +0 -32
  55. data/spec/functional/fc011_spec.rb +0 -20
  56. data/spec/functional/fc013_spec.rb +0 -39
  57. data/spec/functional/fc015_spec.rb +0 -19
  58. data/spec/functional/fc016_spec.rb +0 -57
  59. data/spec/functional/fc025_spec.rb +0 -60
  60. data/spec/functional/fc026_spec.rb +0 -66
  61. data/spec/functional/fc028_spec.rb +0 -93
  62. data/spec/functional/fc029_spec.rb +0 -33
  63. data/spec/functional/fc031_spec.rb +0 -14
  64. data/spec/functional/fc037_spec.rb +0 -75
  65. data/spec/functional/fc038_spec.rb +0 -28
  66. data/spec/functional/fc040_spec.rb +0 -156
  67. data/spec/functional/fc041_spec.rb +0 -121
  68. data/spec/functional/fc042_spec.rb +0 -13
  69. data/spec/functional/fc043_spec.rb +0 -28
  70. data/spec/functional/fc045_spec.rb +0 -18
  71. data/spec/functional/fc048_spec.rb +0 -67
  72. data/spec/functional/fc049_spec.rb +0 -56
  73. data/spec/functional/fc050_spec.rb +0 -85
  74. data/spec/functional/fc052_spec.rb +0 -13
  75. data/spec/functional/fc053_spec.rb +0 -13
  76. data/spec/functional/fc055_spec.rb +0 -18
  77. data/spec/functional/fc056_spec.rb +0 -18
  78. data/spec/functional/fc058_spec.rb +0 -102
  79. data/spec/functional/fc060_spec.rb +0 -45
  80. data/spec/functional/fc061_spec.rb +0 -48
  81. data/spec/functional/fc062_spec.rb +0 -13
  82. data/spec/functional/fc063_spec.rb +0 -18
  83. data/spec/functional/fc064_spec.rb +0 -13
  84. data/spec/functional/fc065_spec.rb +0 -13
  85. data/spec/functional/fc066_spec.rb +0 -33
  86. data/spec/functional/fc067_spec.rb +0 -13
  87. data/spec/functional/fc068_spec.rb +0 -13
  88. data/spec/functional/fc069_spec.rb +0 -38
  89. data/spec/functional/fc070_spec.rb +0 -65
  90. data/spec/functional/fc071_spec.rb +0 -36
  91. data/spec/functional/fc072_spec.rb +0 -13
  92. data/spec/functional/fc073_spec.rb +0 -56
  93. data/spec/functional/fc074_spec.rb +0 -39
  94. data/spec/functional/fc075_spec.rb +0 -41
  95. data/spec/functional/fc076_spec.rb +0 -13
  96. data/spec/functional/fc077_spec.rb +0 -13
  97. data/spec/functional/fc078_spec.rb +0 -35
  98. data/spec/functional/fc079_spec.rb +0 -21
  99. data/spec/functional/fc080_spec.rb +0 -68
  100. data/spec/functional/fc081_spec.rb +0 -25
  101. data/spec/functional/fc082_spec.rb +0 -23
  102. data/spec/functional/fc083_spec.rb +0 -34
  103. data/spec/functional/fc084_spec.rb +0 -49
  104. data/spec/functional/fc085_spec.rb +0 -77
  105. data/spec/functional/fc086_spec.rb +0 -45
  106. data/spec/functional/fc087_spec.rb +0 -43
  107. data/spec/functional/fc088_spec.rb +0 -18
  108. data/spec/functional/fc089_spec.rb +0 -23
  109. data/spec/functional/fc091_spec.rb +0 -38
  110. data/spec/functional/fc092_spec.rb +0 -31
  111. data/spec/functional/fc093_spec.rb +0 -27
  112. data/spec/functional/fc094_spec.rb +0 -18
  113. data/spec/functional/fc095_spec.rb +0 -18
  114. data/spec/functional/fc096_spec.rb +0 -18
  115. data/spec/functional/fc097_spec.rb +0 -18
  116. data/spec/functional/fc098_spec.rb +0 -18
  117. data/spec/functional/fc099_spec.rb +0 -18
  118. data/spec/functional/fc100_spec.rb +0 -18
  119. data/spec/functional/fc101_spec.rb +0 -23
  120. data/spec/functional/fc102_spec.rb +0 -18
  121. data/spec/functional/fc103_spec.rb +0 -30
  122. data/spec/functional/fc104_spec.rb +0 -54
  123. data/spec/functional/fc105_spec.rb +0 -36
  124. data/spec/functional/fc106_spec.rb +0 -21
  125. data/spec/functional/fc107_spec.rb +0 -22
  126. data/spec/functional/fc108_spec.rb +0 -43
  127. data/spec/functional/fc109_spec.rb +0 -22
  128. data/spec/functional/fc110_spec.rb +0 -21
  129. data/spec/functional/fc111_spec.rb +0 -17
  130. data/spec/functional/fc112_spec.rb +0 -17
  131. data/spec/functional/fc113_spec.rb +0 -98
  132. data/spec/functional/fc114_spec.rb +0 -31
  133. data/spec/functional/fc115_spec.rb +0 -24
  134. data/spec/functional/fc116_spec.rb +0 -18
  135. data/spec/functional/fc117_spec.rb +0 -23
  136. data/spec/functional/fc118_spec.rb +0 -17
  137. data/spec/functional/fc119_spec.rb +0 -27
  138. data/spec/functional/fc120_spec.rb +0 -21
  139. data/spec/functional/fc121_spec.rb +0 -45
  140. data/spec/functional/fc122_spec.rb +0 -18
  141. data/spec/functional/root_aliases_spec.rb +0 -13
  142. data/spec/regression/cookbooks.txt +0 -83
  143. data/spec/regression/expected/activemq.txt +0 -6
  144. data/spec/regression/expected/aix.txt +0 -27
  145. data/spec/regression/expected/apparmor.txt +0 -9
  146. data/spec/regression/expected/apt.txt +0 -14
  147. data/spec/regression/expected/ark.txt +0 -3
  148. data/spec/regression/expected/auditd.txt +0 -2
  149. data/spec/regression/expected/aws.txt +0 -16
  150. data/spec/regression/expected/bluepill.txt +0 -12
  151. data/spec/regression/expected/boost.txt +0 -8
  152. data/spec/regression/expected/build-essential.txt +0 -8
  153. data/spec/regression/expected/chef-client.txt +0 -17
  154. data/spec/regression/expected/chef-ingredient.txt +0 -6
  155. data/spec/regression/expected/chef-server.txt +0 -13
  156. data/spec/regression/expected/chef-vault.txt +0 -7
  157. data/spec/regression/expected/chef.txt +0 -104
  158. data/spec/regression/expected/chef_client_updater.txt +0 -2
  159. data/spec/regression/expected/chef_handler.txt +0 -7
  160. data/spec/regression/expected/chef_hostname.txt +0 -3
  161. data/spec/regression/expected/chef_nginx.txt +0 -4
  162. data/spec/regression/expected/cron.txt +0 -7
  163. data/spec/regression/expected/database.txt +0 -42
  164. data/spec/regression/expected/dmg.txt +0 -11
  165. data/spec/regression/expected/docker.txt +0 -4
  166. data/spec/regression/expected/drbd.txt +0 -29
  167. data/spec/regression/expected/dynect.txt +0 -33
  168. data/spec/regression/expected/erlang.txt +0 -6
  169. data/spec/regression/expected/fail2ban.txt +0 -5
  170. data/spec/regression/expected/firewall.txt +0 -11
  171. data/spec/regression/expected/gecode.txt +0 -10
  172. data/spec/regression/expected/gems.txt +0 -32
  173. data/spec/regression/expected/gunicorn.txt +0 -11
  174. data/spec/regression/expected/heartbeat.txt +0 -8
  175. data/spec/regression/expected/homebrew.txt +0 -7
  176. data/spec/regression/expected/iis.txt +0 -22
  177. data/spec/regression/expected/iptables.txt +0 -9
  178. data/spec/regression/expected/jetty.txt +0 -13
  179. data/spec/regression/expected/jpackage.txt +0 -9
  180. data/spec/regression/expected/keepalived.txt +0 -3
  181. data/spec/regression/expected/kickstart.txt +0 -15
  182. data/spec/regression/expected/libarchive.txt +0 -6
  183. data/spec/regression/expected/logwatch.txt +0 -5
  184. data/spec/regression/expected/lvm.txt +0 -14
  185. data/spec/regression/expected/maradns.txt +0 -14
  186. data/spec/regression/expected/maven.txt +0 -8
  187. data/spec/regression/expected/memcached.txt +0 -31
  188. data/spec/regression/expected/motd-tail.txt +0 -5
  189. data/spec/regression/expected/mysql.txt +0 -19
  190. data/spec/regression/expected/ohai.txt +0 -9
  191. data/spec/regression/expected/openldap.txt +0 -12
  192. data/spec/regression/expected/openssh.txt +0 -6
  193. data/spec/regression/expected/openssl.txt +0 -6
  194. data/spec/regression/expected/partial_search.txt +0 -7
  195. data/spec/regression/expected/passenger_apache2.txt +0 -31
  196. data/spec/regression/expected/perl.txt +0 -14
  197. data/spec/regression/expected/php.txt +0 -6
  198. data/spec/regression/expected/postfix.txt +0 -8
  199. data/spec/regression/expected/powershell.txt +0 -8
  200. data/spec/regression/expected/resolver.txt +0 -7
  201. data/spec/regression/expected/rsync.txt +0 -9
  202. data/spec/regression/expected/rsyslog.txt +0 -11
  203. data/spec/regression/expected/runit.txt +0 -4
  204. data/spec/regression/expected/smokeping.txt +0 -6
  205. data/spec/regression/expected/sql_server.txt +0 -7
  206. data/spec/regression/expected/ssh_known_hosts.txt +0 -6
  207. data/spec/regression/expected/stompserver.txt +0 -6
  208. data/spec/regression/expected/subversion.txt +0 -6
  209. data/spec/regression/expected/sudo.txt +0 -10
  210. data/spec/regression/expected/tar.txt +0 -10
  211. data/spec/regression/expected/tftp.txt +0 -6
  212. data/spec/regression/expected/tomcat.txt +0 -18
  213. data/spec/regression/expected/transmission.txt +0 -13
  214. data/spec/regression/expected/ubuntu.txt +0 -5
  215. data/spec/regression/expected/ufw.txt +0 -12
  216. data/spec/regression/expected/unicorn.txt +0 -7
  217. data/spec/regression/expected/users.txt +0 -12
  218. data/spec/regression/expected/vcruntime.txt +0 -8
  219. data/spec/regression/expected/vim.txt +0 -7
  220. data/spec/regression/expected/webpi.txt +0 -7
  221. data/spec/regression/expected/whitelist-node-attrs.txt +0 -7
  222. data/spec/regression/expected/windows.txt +0 -35
  223. data/spec/regression/expected/wix.txt +0 -5
  224. data/spec/regression/expected/xml.txt +0 -7
  225. data/spec/regression/expected/yum.txt +0 -15
  226. data/spec/regression/regression_spec.rb +0 -23
  227. data/spec/spec_helper.rb +0 -132
  228. data/spec/unit/api_spec.rb +0 -1939
  229. data/spec/unit/chef_spec.rb +0 -66
  230. data/spec/unit/command_line_spec.rb +0 -136
  231. data/spec/unit/domain_spec.rb +0 -78
  232. data/spec/unit/linter_spec.rb +0 -107
  233. data/spec/unit/template_spec.rb +0 -53
@@ -1,32 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC010" do
4
- context "with a cookbook with a recipe that attempts to perform a search with invalid syntax" do
5
- recipe_file <<-EOH
6
- search(:node, 'run_list:recipe[foo::bar]') do |matching_node|
7
- puts matching_node.to_s
8
- end
9
- EOH
10
- it { is_expected.to violate_rule }
11
- end
12
-
13
- context "with a cookbook with a recipe that attempts to perform a search with valid syntax" do
14
- recipe_file <<-EOH
15
- search(:node, 'run_list:recipe\\[foo\\:\\:bar\\]') do |matching_node|
16
- puts matching_node.to_s
17
- end
18
- EOH
19
-
20
- it { is_expected.not_to violate_rule }
21
- end
22
-
23
- context "with a cookbook with a recipe that attempts to perform a search with a subexpression" do
24
- recipe_file <<-EOH
25
- search(:node, "roles:\#{node['foo']['role']}") do |matching_node|
26
- puts matching_node.to_s
27
- end
28
- EOH
29
-
30
- it { is_expected.not_to violate_rule }
31
- end
32
- end
@@ -1,20 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC011" do
4
- context "with a cookbook with a README.md file" do
5
- metadata_file "name 'mycookbook'"
6
- file("README.md")
7
- it { is_expected.not_to violate_rule }
8
- end
9
-
10
- context "with a cookbook without a README.md file" do
11
- metadata_file "name 'mycookbook'"
12
- it { is_expected.to violate_rule }
13
- end
14
-
15
- context "with a cookbook with a README.rdoc file" do
16
- metadata_file "name 'mycookbook'"
17
- file("README.rdoc")
18
- it { is_expected.to violate_rule }
19
- end
20
- end
@@ -1,39 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC013" do
4
- context "with a cookbook that downloads a file to /tmp" do
5
- recipe_file <<-EOH
6
- remote_file "/tmp/large-file.tar.gz" do
7
- source "http://www.example.org/large-file.tar.gz"
8
- end
9
- EOH
10
- it { is_expected.to violate_rule }
11
- end
12
-
13
- context "with a cookbook that downloads a file to /tmp with an expression" do
14
- recipe_file <<-'EOH'
15
- remote_file "/tmp/#{the_file}" do
16
- source "http://www.example.org/large-file.tar.gz"
17
- end
18
- EOH
19
- it { is_expected.to violate_rule }
20
- end
21
-
22
- context "with a cookbook that downloads a file to a users home directory" do
23
- recipe_file <<-EOH
24
- remote_file "/home/ernie/large-file.tar.gz" do
25
- source "http://www.example.org/large-file.tar.gz"
26
- end
27
- EOH
28
- it { is_expected.not_to violate_rule }
29
- end
30
-
31
- context "with a cookbook that downloads a file to the Chef file cache" do
32
- recipe_file <<-'EOH'
33
- remote_file '#{Chef::Config[:file_cache_path]}/large-file.tar.gz' do
34
- source "http://www.example.org/large-file.tar.gz"
35
- end
36
- EOH
37
- it { is_expected.not_to violate_rule }
38
- end
39
- end
@@ -1,19 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC015" do
4
- context "with a cookbook that contains a definition" do
5
- definition_file <<-EOH
6
- define :apache_site, :enable => true do
7
- log "I am a definition"
8
- end
9
- EOH
10
- it { is_expected.to violate_rule }
11
- end
12
-
13
- context "with a cookbook that does not contain a definition" do
14
- recipe_file <<-EOH
15
- cookbook_file "/etc/foo"
16
- EOH
17
- it { is_expected.not_to violate_rule }
18
- end
19
- end
@@ -1,57 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC016" do
4
-
5
- context "with a cookbook with a LWRP that includes a default_action" do
6
- resource_file <<-EOH
7
- actions :create, :remove
8
- default_action :create
9
-
10
- attribute :name, String, name_attribute: true
11
- EOH
12
- it { is_expected.to_not violate_rule }
13
- end
14
-
15
- context "with a cookbook with a LWRP that includes a non-DSL default_action" do
16
- resource_file <<-EOH
17
- actions :create, :remove,
18
-
19
- def initialize(*args)
20
- super
21
- @action = :create
22
- end
23
-
24
- attribute :name, String, name_attribute: true
25
- EOH
26
- it { is_expected.to_not violate_rule }
27
- end
28
-
29
- context "with a cookbook with a LWRP that does not include a default_action" do
30
- resource_file <<-EOH
31
- actions :create, :remove,
32
-
33
- attribute :name, String, name_attribute: true
34
- EOH
35
- it { is_expected.to violate_rule }
36
- end
37
-
38
- context "with a custom resource that includes a property" do
39
- resource_file <<-EOH
40
- property :name, String, name_property: true
41
-
42
- action :create do
43
- cookbook_file "/etc/something"
44
- end
45
- EOH
46
- it { is_expected.to_not violate_rule }
47
- end
48
-
49
- context "with a custom resource that includes only an action" do
50
- resource_file <<-EOH
51
- action :create do
52
- cookbook_file "/etc/something"
53
- end
54
- EOH
55
- it { is_expected.to_not violate_rule }
56
- end
57
- end
@@ -1,60 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC025" do
4
- context "with a recipe that does a blockless gem_package install" do
5
- recipe_file <<-EOH
6
- gem_package 'foo'
7
- EOH
8
- it { is_expected.not_to violate_rule }
9
- end
10
-
11
- context "with a recipe that does a gem_package install" do
12
- recipe_file <<-EOH
13
- gem_package 'foo' do
14
- action :install
15
- EOH
16
- it { is_expected.not_to violate_rule }
17
- end
18
-
19
- context "with a recipe that does a gem_package install with a nothing action" do
20
- recipe_file <<-EOH
21
- gem_package 'foo' do
22
- action :nothing
23
- EOH
24
- it { is_expected.not_to violate_rule }
25
- end
26
-
27
- context "with a recipe that does a compile_time gem install from an array" do
28
- recipe_file <<-EOH
29
- %w{bencode i18n transmission-simple}.each do |pkg|
30
- r = gem_package pkg do
31
- action :nothing
32
- end
33
- r.run_action(:install)
34
- end
35
- EOH
36
- it { is_expected.to violate_rule }
37
- end
38
-
39
- context "with a recipe that does a compile_time gem install" do
40
- recipe_file <<-EOH
41
- r = gem_package "activesupport" do
42
- version '2.3.11'
43
- action :nothing
44
- end
45
- r.run_action(:install)
46
- EOH
47
- it { is_expected.to violate_rule }
48
- end
49
-
50
- context "with a recipe that does a compile_time gem upgrade" do
51
- recipe_file <<-EOH
52
- r = gem_package "activesupport" do
53
- version '2.3.11'
54
- action :nothing
55
- end
56
- r.run_action(:upgrade)
57
- EOH
58
- it { is_expected.to violate_rule }
59
- end
60
- end
@@ -1,66 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC026" do
4
- context "with a recipe that has a bracketed conditional that shouldn't be in a block" do
5
- recipe_file <<-EOH
6
- file 'foo' do
7
- not_if { "ls foo" }
8
- end
9
- EOH
10
- it { is_expected.to violate_rule }
11
- end
12
-
13
- context "with a recipe that has a conditional that shouldn't be in a block" do
14
- recipe_file <<-EOH
15
- file 'foo' do
16
- not_if do "ls foo" end
17
- end
18
- EOH
19
- it { is_expected.to violate_rule }
20
- end
21
-
22
- context "with a recipe that has a conditional with a variable that shouldn't be in a block" do
23
- recipe_file <<-EOH
24
- file 'foo' do
25
- only_if { "ls \#{node['foo']['path']}" }
26
- end
27
- EOH
28
- it { is_expected.to violate_rule }
29
- end
30
-
31
- context "with a recipe that has a conditional with a method that shouldn't be in a block" do
32
- recipe_file <<-EOH
33
- file 'foo' do
34
- not_if { "ls \#{foo.method()}" }
35
- end
36
- EOH
37
- it { is_expected.to violate_rule }
38
- end
39
-
40
- context "with a recipe that has a conditional of foo.bar" do
41
- recipe_file <<-EOH
42
- file 'foo' do
43
- only_if { foo.bar }
44
- end
45
- EOH
46
- it { is_expected.not_to violate_rule }
47
- end
48
-
49
- context "with a recipe that has a conditional of foo.to_s" do
50
- recipe_file <<-EOH
51
- file 'foo' do
52
- not_if { foo.to_s }
53
- end
54
- EOH
55
- it { is_expected.not_to violate_rule }
56
- end
57
-
58
- context "with a recipe that has a conditional of File.exists?('/etc/foo')" do
59
- recipe_file <<-EOH
60
- file 'foo' do
61
- not_if { File.exists?("/etc/foo") }
62
- end
63
- EOH
64
- it { is_expected.not_to violate_rule }
65
- end
66
- end
@@ -1,93 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC028" do
4
- context "with a cookbook with a single recipe that calls platform? without parentheses for a single platform" do
5
- recipe_file "platform? 'ubuntu'"
6
- it { is_expected.not_to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a single recipe that calls platform? without parentheses for two platforms" do
10
- recipe_file "platform?('ubuntu','windows')"
11
- it { is_expected.not_to violate_rule }
12
- end
13
-
14
- context "with a cookbook with a single recipe that calls platform? with parentheses for a single platform" do
15
- recipe_file "platform?('ubuntu')"
16
- it { is_expected.not_to violate_rule }
17
- end
18
-
19
- context "with a cookbook with a single recipe that calls platform? with parentheses for two platforms" do
20
- recipe_file "platform?('ubuntu', 'windows')"
21
- it { is_expected.not_to violate_rule }
22
- end
23
-
24
- context "with a cookbook with a single recipe that compares a value against node.platform" do
25
- recipe_file "node.platform == 'ubuntu'"
26
- it { is_expected.not_to violate_rule }
27
- end
28
-
29
- context "with a cookbook with a single recipe that uses checks a value against node.platform" do
30
- recipe_file "node.platform == 'ubuntu'"
31
- it { is_expected.not_to violate_rule }
32
- end
33
-
34
- context "with a cookbook with a single recipe that calls node.platform? without a parentheses" do
35
- recipe_file "node.platform? 'ubuntu'"
36
- it { is_expected.to violate_rule }
37
- end
38
-
39
- context "with a cookbook with a single recipe that calls node.platform? with a parentheses" do
40
- recipe_file "node.platform?('ubuntu')"
41
- it { is_expected.to violate_rule }
42
- end
43
-
44
- context "with a cookbook with a single recipe that calls node.platform? with a parentheses for 2 platforms" do
45
- recipe_file "node.platform?('ubuntu', 'windows')"
46
- it { is_expected.to violate_rule }
47
- end
48
-
49
- context "with a cookbook with a single recipe that calls platform_family? without parentheses for a single platform family" do
50
- recipe_file "platform_family? 'debian'"
51
- it { is_expected.not_to violate_rule }
52
- end
53
-
54
- context "with a cookbook with a single recipe that calls platform_family? without parentheses for two plaform families" do
55
- recipe_file "platform_family?('debian','windows')"
56
- it { is_expected.not_to violate_rule }
57
- end
58
-
59
- context "with a cookbook with a single recipe that calls platform_family? with parentheses for a single plaform family" do
60
- recipe_file "platform_family?('debian')"
61
- it { is_expected.not_to violate_rule }
62
- end
63
-
64
- context "with a cookbook with a single recipe that calls platform_family? with parentheses for two plaform families" do
65
- recipe_file "platform_family?('debian', 'windows')"
66
- it { is_expected.not_to violate_rule }
67
- end
68
-
69
- context "with a cookbook with a single recipe that compares a value against node.platform_family" do
70
- recipe_file "node.platform_family == 'debian'"
71
- it { is_expected.not_to violate_rule }
72
- end
73
-
74
- context "with a cookbook with a single recipe that uses checks a value against node.platform_family" do
75
- recipe_file "node.platform_family == 'debian'"
76
- it { is_expected.not_to violate_rule }
77
- end
78
-
79
- context "with a cookbook with a single recipe that calls node.platform_family? without a parentheses" do
80
- recipe_file "node.platform_family? 'debian'"
81
- it { is_expected.to violate_rule }
82
- end
83
-
84
- context "with a cookbook with a single recipe that calls node.platform_family? with a parentheses" do
85
- recipe_file "node.platform_family?('debian')"
86
- it { is_expected.to violate_rule }
87
- end
88
-
89
- context "with a cookbook with a single recipe that calls node.platform_family? with a parentheses for 2 plaform families" do
90
- recipe_file "node.platform_family?('debian', 'windows')"
91
- it { is_expected.to violate_rule }
92
- end
93
- end
@@ -1,33 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC029" do
4
- context "with a cookbook with a metadata file that doesn't contain the recipe keyword" do
5
- metadata_file("name 'example'")
6
- it { is_expected.not_to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a metadata file that contains contain the recipe keyword with the cookbook name only" do
10
- metadata_file("name 'example'\nrecipe 'example', 'Installs Example'")
11
- it { is_expected.not_to violate_rule }
12
- end
13
-
14
- context "with a cookbook with a metadata file that contains the recipe keyword with the cookbook::recipe format name" do
15
- metadata_file("name 'example'\nrecipe 'example::default', 'Installs Example'")
16
- it { is_expected.not_to violate_rule }
17
- end
18
-
19
- context "with a cookbook with a metadata file that contains the recipe keyword and lacks the cookbook name" do
20
- metadata_file("name 'example'\nrecipe 'default', 'Installs Example'")
21
- it { is_expected.to violate_rule }
22
- end
23
-
24
- context "with a cookbook with a metadata file that contains the recipe keyword and stores full recipe name as a var" do
25
- metadata_file("name 'example'\nvar = 'example::default'\nrecipe my_var, 'Installs Example'")
26
- it { is_expected.not_to violate_rule }
27
- end
28
-
29
- context "with a cookbook with a metadata file that contains the recipe keyword and stores part of the recipe name as a var" do
30
- metadata_file('name "example"\nvar = "example"\nrecipe "#{my_var}::default", "Installs Example"')
31
- it { is_expected.not_to violate_rule }
32
- end
33
- end
@@ -1,14 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC031" do
4
- context "with a cookbook with a metadata file" do
5
- metadata_file
6
- recipe_file
7
- it { is_expected.to_not violate_rule }
8
- end
9
-
10
- context "with a cookbook without a metadata file" do
11
- recipe_file
12
- it { is_expected.to violate_rule }
13
- end
14
- end
@@ -1,75 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC037" do
4
- context "with a resource that notifies using an action that is a string" do
5
- recipe_file <<-EOF
6
- file '/tmp/b.txt' do
7
- content 'content'
8
- notifies 'restart', 'service[httpd]', :delayed
9
- end
10
- EOF
11
- it { is_expected.to violate_rule }
12
- end
13
-
14
- context "with a resource that notifies using an action as a symbol" do
15
- recipe_file <<-EOF
16
- file '/tmp/a.txt' do
17
- content 'content'
18
- notifies :restart, 'service[httpd]', :delayed
19
- end
20
- EOF
21
- it { is_expected.not_to violate_rule }
22
- end
23
-
24
- context "with a resource that notifies using an action as a :'symbol'" do
25
- recipe_file <<-EOF
26
- file '/tmp/a.txt' do
27
- content 'content'
28
- notifies :'restart', 'service[httpd]', :delayed
29
- end
30
- EOF
31
- it { is_expected.not_to violate_rule }
32
- end
33
-
34
- context "with a resource that notifies using an action that is an attribute" do
35
- recipe_file <<-EOF
36
- file '/tmp/a.txt' do
37
- content 'content'
38
- notifies node['foo']['bar'], 'service[httpd]', :delayed
39
- end
40
- EOF
41
- it { is_expected.not_to violate_rule }
42
- end
43
-
44
- context "with a resource that notifies using an action that is a resource property" do
45
- recipe_file <<-EOF
46
- file '/tmp/a.txt' do
47
- content 'content'
48
- notifies new_resource.bob, 'service[httpd]', :delayed
49
- end
50
- EOF
51
- it { is_expected.not_to violate_rule }
52
- end
53
-
54
- context "with a resource that notifies using an action that is a variable" do
55
- recipe_file <<-EOF
56
- file '/tmp/a.txt' do
57
- content 'content'
58
- notifies foo, 'service[httpd]', :delayed
59
- end
60
- EOF
61
- it { is_expected.not_to violate_rule }
62
- end
63
-
64
- context "with a resource that notifies with a variable in a loop" do
65
- recipe_file <<-EOF
66
- file '/tmp/a.txt' do
67
- content 'content'
68
- Array(node['foo']['bar']).each do |action|
69
- notifies action, 'service[httpd]', :delayed
70
- end
71
- end
72
- EOF
73
- it { is_expected.not_to violate_rule }
74
- end
75
- end