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,25 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC081" do
4
- context "with a cookbook with a metadata file that depends on partial_search cookbook" do
5
- metadata_file <<-META
6
- name 'my_cookbook'
7
- depends 'partial_search'
8
- META
9
- it { is_expected.to violate_rule }
10
- end
11
-
12
- context "with a cookbook with a metadata file that depends on partial_search cookbook and others" do
13
- metadata_file <<-META
14
- name 'my_cookbook'
15
- depends 'partial_search'
16
- depends 'windows'
17
- META
18
- it { is_expected.to violate_rule }
19
- end
20
-
21
- context "with a cookbook with a metadata file that depends on no cookbooks" do
22
- metadata_file "name 'my_cookbook'"
23
- it { is_expected.not_to violate_rule }
24
- end
25
- end
@@ -1,23 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC082" do
4
- context "with a cookbook with a recipe that sets an attribute with node.set" do
5
- recipe_file "node.set['foo']['bar'] = baz"
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a recipe that sets an attribute with node.set_unless" do
10
- recipe_file "node.set_unless['foo']['bar'] = baz"
11
- it { is_expected.to violate_rule }
12
- end
13
-
14
- context "with a cookbook with a recipe that sets an attribute with node.normal" do
15
- recipe_file "node.normal['foo']['bar'] = baz"
16
- it { is_expected.to_not violate_rule }
17
- end
18
-
19
- context "with a cookbook with a recipe that reads a value using node.set" do
20
- recipe_file "foo = node.set['foo']"
21
- it { is_expected.to violate_rule }
22
- end
23
- end
@@ -1,34 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC083" do
4
- context "with a cookbook with a recipe that includes a execute resource specifying path" do
5
- recipe_file <<-EOF
6
- execute 'food' do
7
- path '/some/path'
8
- command 'build.sh'
9
- end
10
- EOF
11
- it { is_expected.to violate_rule }
12
- end
13
-
14
- context "with a cookbook with a recipe that includes a execute resource not specifying path" do
15
- recipe_file <<-EOF
16
- execute 'food' do
17
- command 'build.sh'
18
- end
19
- EOF
20
- it { is_expected.not_to violate_rule }
21
- end
22
-
23
- context "with a cookbook with a recipe that doesn't include an execute resource" do
24
- recipe_file <<-EOF
25
- directory '/tmp/something' do
26
- owner 'root'
27
- group 'root'
28
- mode '0755'
29
- action :create
30
- end
31
- EOF
32
- it { is_expected.not_to violate_rule }
33
- end
34
- end
@@ -1,49 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC084" do
4
- context "with a cookbook with a recipe that includes Chef::REST" do
5
- recipe_file 'Chef::REST::RESTRequest.new(:GET, "http://foo.com", nil).call'
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a library that includes Chef::REST" do
10
- recipe_file <<-EOF
11
- def response
12
- response = Chef::REST::RESTRequest.new(:GET, 'http://foo.com', nil).call
13
- end
14
- EOF
15
- it { is_expected.to violate_rule }
16
- end
17
-
18
- context "with a cookbook with a LWRP that includes Chef::REST" do
19
- recipe_file <<-EOF
20
- action :doit do
21
- Chef::REST::RESTRequest.new(:GET, 'http://foo.com', nil).call
22
- end
23
- EOF
24
- it { is_expected.to violate_rule }
25
- end
26
-
27
- context "with a cookbook with a recipe that includes Chef::ServerAPI" do
28
- recipe_file "server_conn = Chef::ServerAPI.new"
29
- it { is_expected.not_to violate_rule }
30
- end
31
-
32
- context "with a cookbook with a library that includes Chef::ServerAPI" do
33
- recipe_file <<-EOF
34
- def server_conn
35
- server_conn = Chef::ServerAPI.new
36
- end
37
- EOF
38
- it { is_expected.not_to violate_rule }
39
- end
40
-
41
- context "with a cookbook with a LWRP that includes Chef::ServerAPI" do
42
- recipe_file <<-EOF
43
- action :doit do
44
- Chef::ServerAPI.new
45
- end
46
- EOF
47
- it { is_expected.not_to violate_rule }
48
- end
49
- end
@@ -1,77 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC085" do
4
- context "with a cookbook with a custom resource that converges with new_resource.updated_by_last_action" do
5
- resource_file <<-EOF
6
- action :create do
7
- template "/etc/something.conf" do
8
- notifies :restart, "service[something]"
9
- end
10
-
11
- new_resource.updated_by_last_action(true)
12
- end
13
- EOF
14
- it { is_expected.to violate_rule }
15
- end
16
-
17
- context "with a cookbook with a LWRP that converges with @new_resource.updated_by_last_action" do
18
- provider_file <<-EOF
19
- use_inline_resources
20
-
21
- action :create do
22
- template "/etc/something.conf" do
23
- notifies :restart, "service[something]"
24
- end
25
-
26
- @new_resource.updated_by_last_action(true)
27
- end
28
- EOF
29
- it { is_expected.to violate_rule }
30
- end
31
-
32
- context "with a cookbook with a LWRP that converges with new_resource.updated_by_last_action in a method" do
33
- provider_file <<-EOF
34
- def update_me(new_resource)
35
- new_resource.updated_by_last_action(true)
36
- end
37
- EOF
38
- it { is_expected.to violate_rule }
39
- end
40
-
41
- context "with a cookbook with a custom resource that relies on resources for convergence" do
42
- resource_file <<-EOF
43
- action :create do
44
- file "the_file" do
45
- template "/etc/something.conf" do
46
- notifies :restart, "service[something]"
47
- end
48
- end
49
- EOF
50
- it { is_expected.to_not violate_rule }
51
- end
52
-
53
- context "with a cookbook with a LWRP that relies on resources for convergence" do
54
- provider_file <<-EOF
55
- use_inline_resources
56
-
57
- action :create do
58
- file "the_file" do
59
- template "/etc/something.conf" do
60
- notifies :restart, "service[something]"
61
- end
62
- end
63
- EOF
64
- it { is_expected.to_not violate_rule }
65
- end
66
-
67
- context "with a cookbook with a LWRP that calls foo.updated_by_last_action" do
68
- provider_file <<-EOF
69
- use_inline_resources
70
-
71
- action :create do
72
- foo.updated_by_last_action(true)
73
- EOF
74
- it { is_expected.to_not violate_rule }
75
- end
76
-
77
- end
@@ -1,45 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC086" do
4
- context "with a recipe that uses Chef::EncryptedDataBagItem.load" do
5
- recipe_file 'Chef::EncryptedDataBagItem.load("users", "tsmith", key)'
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a recipe that uses Chef::DataBagItem.load" do
10
- recipe_file 'Chef::DataBagItem.load("users", "tsmith")'
11
- it { is_expected.to violate_rule }
12
- end
13
-
14
- context "with a resource that uses Chef::EncryptedDataBagItem.load" do
15
- resource_file <<-EOF
16
- action :create do
17
- data = Chef::EncryptedDataBagItem.load("users", "tsmith", key)
18
- end
19
- EOF
20
- it { is_expected.to violate_rule }
21
- end
22
-
23
- context "with a resource that uses Chef::DataBagItem.load" do
24
- resource_file <<-EOF
25
- action :create do
26
- data = Chef::DataBagItem.load("users", "tsmith")
27
- end
28
- EOF
29
- it { is_expected.to violate_rule }
30
- end
31
-
32
- context "with a recipe that uses data_bag_item" do
33
- recipe_file "data_bag_item('bag', 'item', IO.read('secret_file').strip)"
34
- it { is_expected.not_to violate_rule }
35
- end
36
-
37
- context "with a recipe that uses other Chef::EncryptedDataBagItem methods" do
38
- recipe_file <<-EOF
39
- data_bag_item('bag', 'item', Chef::EncryptedDataBagItem.load_secret('secret_file'))
40
- encrypted_item = Chef::EncryptedDataBagItem.encrypt_data_bag_item(original_item, Chef::EncryptedDataBagItem.load_secret)
41
- bag = Chef::DataBagItem.new
42
- EOF
43
- it { is_expected.not_to violate_rule }
44
- end
45
- end
@@ -1,43 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC087" do
4
- context "with a cookbook with a library that maps platforms with Chef::Platform.set" do
5
- library_file <<-EOF
6
- Chef::Platform.set platform: :amazon, resource: :mysql_chef_gem, provider: Chef::Provider::MysqlChefGem::Mysql
7
- Chef::Platform.set platform: :centos, version: '< 7.0', resource: :mysql_chef_gem, provider: Chef::Provider::MysqlChefGem::Mysql
8
- EOF
9
- it { is_expected.to violate_rule }
10
- end
11
-
12
- context "with a cookbook with a library that maps providers with Chef::Platform.provider_for_resource" do
13
- library_file <<-EOF
14
- provider = Chef::Platform.provider_for_resource(resource, :create)
15
- EOF
16
- it { is_expected.to violate_rule }
17
- end
18
-
19
- context "with a cookbook with a library that maps providers with Chef::Platform.provider_for_resource" do
20
- library_file <<-EOF
21
- provider = Chef::Platform.find_provider("ubuntu", "16.04", resource)
22
- EOF
23
- it { is_expected.to violate_rule }
24
- end
25
-
26
- context "with a cookbook with a library that includes Chef::Platform.foo" do
27
- library_file <<-EOF
28
- module AuditD
29
- module Helper
30
- def auditd_package_name_for(platform_family)
31
- case platform_family
32
- when 'rhel', 'fedora'
33
- 'audit'
34
- else
35
- 'auditd'
36
- end
37
- end
38
- end
39
- end
40
- EOF
41
- it { is_expected.to_not violate_rule }
42
- end
43
- end
@@ -1,18 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC088" do
4
- context "with a cookbook with a library that uses Chef::Mixin::Command" do
5
- library_file "include Chef::Mixin::Command"
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a resource that uses Chef::Mixin::Command" do
10
- resource_file "include Chef::Mixin::Command"
11
- it { is_expected.to violate_rule }
12
- end
13
-
14
- context "with a cookbook with a resource that uses Bob::Mixin::Command" do
15
- resource_file "include Bob::Mixin::Command"
16
- it { is_expected.not_to violate_rule }
17
- end
18
- end
@@ -1,23 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC089" do
4
- context "with a cookbook with a library that uses Chef::ShellOut" do
5
- library_file "include Chef::ShellOut"
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a resource that uses Chef::ShellOut" do
10
- resource_file "include Chef::ShellOut"
11
- it { is_expected.to violate_rule }
12
- end
13
-
14
- context "with a cookbook with a resource that uses Miblib::Shellout" do
15
- resource_file "include Mixlib::Shellout"
16
- it { is_expected.not_to violate_rule }
17
- end
18
-
19
- context "with a cookbook with a resource that uses Chef::Mixin::ShellOut" do
20
- resource_file "include Chef::Mixin::ShellOut"
21
- it { is_expected.not_to violate_rule }
22
- end
23
- end
@@ -1,38 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC091" do
4
- context "with a cookbook with a custom resource that uses attributes" do
5
- resource_file <<-EOF
6
- attribute :source, String, name_attribute: true
7
- attribute :headers, Hash, default: {}
8
-
9
- action :create do
10
- puts "something"
11
- end
12
- EOF
13
- it { is_expected.to violate_rule }
14
- end
15
-
16
- context "with a cookbook with a custom resource that uses properties" do
17
- resource_file <<-EOF
18
- property :source, String, name_property: true
19
- property :headers, Hash, default: {}
20
-
21
- action :create do
22
- puts "something"
23
- end
24
- EOF
25
- it { is_expected.not_to violate_rule }
26
- end
27
-
28
- context "with a cookbook with a LWRP that uses attributes" do
29
- resource_file <<-EOF
30
- attribute :source, String, name_attribute: true
31
- attribute :headers, Hash, default: {}
32
-
33
- actions :create
34
- default_action :create
35
- EOF
36
- it { is_expected.not_to violate_rule }
37
- end
38
- end
@@ -1,31 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC092" do
4
- context "with a cookbook with a custom resource that defines actions" do
5
- resource_file <<-EOF
6
- actions :create
7
-
8
- action :create do
9
- puts "something"
10
- end
11
- EOF
12
- it { is_expected.to violate_rule }
13
- end
14
-
15
- context "with a cookbook with a custom resource that doesn't define actions" do
16
- resource_file <<-EOF
17
- action :create do
18
- puts "something"
19
- end
20
- EOF
21
- it { is_expected.not_to violate_rule }
22
- end
23
-
24
- context "with a cookbook with a LWRP that defines actions" do
25
- resource_file <<-EOF
26
- actions :create
27
- default_action :create
28
- EOF
29
- it { is_expected.not_to violate_rule }
30
- end
31
- end
@@ -1,27 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC093" do
4
- context "with a README.md file containing generated TODO item" do
5
- readme_file <<-EOF
6
- # cookbook
7
-
8
- TODO: Enter the cookbook description here.
9
- EOF
10
- metadata_file <<-META
11
- name 'cookbook'
12
- META
13
- it { is_expected.to violate_rule }
14
- end
15
-
16
- context "with a README.md without generated TODO item" do
17
- readme_file <<-EOF
18
- # cookbook
19
-
20
- Some description.
21
- EOF
22
- metadata_file <<-META
23
- name 'cookbook'
24
- META
25
- it { is_expected.not_to violate_rule }
26
- end
27
- end