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,85 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC050" do
4
- context "with a role" do
5
- foodcritic_command("--no-progress", "-R", "roles")
6
- let(:role_name) { "" }
7
- file("roles/webserver.rb") { "name '#{role_name}'\nrun_list ['recipe[apache]']" }
8
-
9
- context "with name webserver" do
10
- let(:role_name) { "webserver" }
11
- it { is_expected.to_not violate_rule }
12
- end
13
-
14
- context "with name web_server" do
15
- let(:role_name) { "web_server" }
16
- it { is_expected.to_not violate_rule }
17
- end
18
-
19
- context "with name web-server" do
20
- let(:role_name) { "web-server" }
21
- it { is_expected.to_not violate_rule }
22
- end
23
-
24
- context "with name webserver123" do
25
- let(:role_name) { "webserver123" }
26
- it { is_expected.to_not violate_rule }
27
- end
28
-
29
- context "with name Webserver" do
30
- let(:role_name) { "Webserver" }
31
- it { is_expected.to_not violate_rule }
32
- end
33
-
34
- context "with name web server" do
35
- let(:role_name) { "web server" }
36
- it { is_expected.to violate_rule }
37
- end
38
-
39
- context "with name webserver%" do
40
- let(:role_name) { "webserver%" }
41
- it { is_expected.to violate_rule }
42
- end
43
- end
44
-
45
- context "with an environment" do
46
- foodcritic_command("--no-progress", "-E", "environments")
47
- let(:environment_name) { "" }
48
- file("environments/production.rb") { "name '#{environment_name}'\ncookbook 'apache2'" }
49
-
50
- context "with name production" do
51
- let(:environment_name) { "production" }
52
- it { is_expected.to_not violate_rule }
53
- end
54
-
55
- context "with name pre_production" do
56
- let(:environment_name) { "pre_production" }
57
- it { is_expected.to_not violate_rule }
58
- end
59
-
60
- context "with name production-eu" do
61
- let(:environment_name) { "production-eu" }
62
- it { is_expected.to_not violate_rule }
63
- end
64
-
65
- context "with name production2" do
66
- let(:environment_name) { "production2" }
67
- it { is_expected.to_not violate_rule }
68
- end
69
-
70
- context "with name Production" do
71
- let(:environment_name) { "Production" }
72
- it { is_expected.to_not violate_rule }
73
- end
74
-
75
- context "with name EU West" do
76
- let(:environment_name) { "EU West" }
77
- it { is_expected.to violate_rule }
78
- end
79
-
80
- context "with name production (eu-west)" do
81
- let(:environment_name) { "production (eu-west)" }
82
- it { is_expected.to violate_rule }
83
- end
84
- end
85
- end
@@ -1,13 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC052" do
4
- context "with a cookbook with a metadata file that does contain the suggests keyword" do
5
- metadata_file "suggests 'runit'"
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a metadata file that does not contain the suggests keyword" do
10
- metadata_file
11
- it { is_expected.to_not violate_rule }
12
- end
13
- end
@@ -1,13 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC053" do
4
- context "with a cookbook with a metadata file that does contain the recommends keyword" do
5
- metadata_file "recommends 'runit'"
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a metadata file that does not contain the recommends keyword" do
10
- metadata_file
11
- it { is_expected.to_not violate_rule }
12
- end
13
- end
@@ -1,18 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC055" do
4
- context "with a cookbook with a metadata file that does not specify a maintainer" do
5
- metadata_file "name 'my_cookbook'"
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a metadata file that specifies a maintainer" do
10
- metadata_file "maintainer 'Some Person'"
11
- it { is_expected.to_not violate_rule }
12
- end
13
-
14
- context "with a cookbook with a metadata file that specifies a maintainer as an expression" do
15
- metadata_file("maintainer an(expression)")
16
- it { is_expected.to_not violate_rule }
17
- end
18
- end
@@ -1,18 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC056" do
4
- context "with a cookbook with a metadata file that does not specify a maintainer_email" do
5
- metadata_file
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a metadata file that specifies a maintainer_email" do
10
- metadata_file "maintainer_email 'foo@example.com'"
11
- it { is_expected.to_not violate_rule }
12
- end
13
-
14
- context "with a cookbook with a metadata file that specifies a maintainer_email as an expression" do
15
- metadata_file("maintainer_email an(expression)")
16
- it { is_expected.to_not violate_rule }
17
- end
18
- end
@@ -1,102 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC058" do
4
- context "with a cookbook with a library provider with use_inline_resources and uses def action_create" do
5
- library_file <<-EOF
6
- class MyResources
7
- class Site < Chef::Resource::LWRPBase
8
- provides :site
9
- resource_name :site
10
- actions :create
11
- attribute :name, :kind_of => String, :name_attribute => true
12
- end
13
- end
14
-
15
- class MyProviders
16
- class Site < Chef::Provider::LWRPBase
17
- provides :site
18
-
19
- use_inline_resources
20
-
21
- def action_create
22
- file "/tmp/foo.txt"
23
- end
24
- end
25
- end
26
- EOF
27
- it { is_expected.to violate_rule }
28
- end
29
-
30
- context "with a cookbook with a library provider without use_inline_resources and uses def action_create" do
31
- library_file <<-EOF
32
- class MyResources
33
- class Site < Chef::Resource::LWRPBase
34
- provides :site
35
- resource_name :site
36
- actions :create
37
- attribute :name, :kind_of => String, :name_attribute => true
38
- end
39
- end
40
-
41
- class MyProviders
42
- class Site < Chef::Provider::LWRPBase
43
- provides :site
44
-
45
- def action_create
46
- file "/tmp/foo.txt"
47
- end
48
- end
49
- end
50
- EOF
51
- it { is_expected.to_not violate_rule }
52
- end
53
-
54
- context "with a cookbook with a cookbook that contains a library provider with use_inline_resources" do
55
- library_file <<-EOF
56
- class MyResources
57
- class Site < Chef::Resource::LWRPBase
58
- provides :site
59
- resource_name :site
60
- actions :create
61
- attribute :name, :kind_of => String, :name_attribute => true
62
- end
63
- end
64
-
65
- class MyProviders
66
- class Site < Chef::Provider::LWRPBase
67
- provides :site
68
- use_inline_resources
69
-
70
- action :create do
71
- file "/tmp/foo.txt"
72
- end
73
- end
74
- end
75
- EOF
76
- it { is_expected.not_to violate_rule }
77
- end
78
-
79
- context "with a cookbook with a library provider without use_inline_resources" do
80
- library_file <<-EOF
81
- class MyResources
82
- class Site < Chef::Resource::LWRPBase
83
- provides :site
84
- resource_name :site
85
- actions :create
86
- attribute :name, :kind_of => String, :name_attribute => true
87
- end
88
- end
89
-
90
- class MyProviders
91
- class Site < Chef::Provider::LWRPBase
92
- provides :site
93
-
94
- action :create do
95
- file "/tmp/foo.txt"
96
- end
97
- end
98
- end
99
- EOF
100
- it { is_expected.not_to violate_rule }
101
- end
102
- end
@@ -1,45 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC060" do
4
- context "with a cookbook with LWRP with use_inline_resources and with bad action_create" do
5
- provider_file <<-EOF
6
- use_inline_resources
7
-
8
- def action_create
9
- cookbook_file "/etc/something.conf"
10
- end
11
- EOF
12
- it { is_expected.to violate_rule }
13
- end
14
-
15
- context "with a cookbook with LWRP without use_inline_resources and with bad action_create" do
16
- provider_file <<-EOF
17
- def action_create
18
- cookbook_file "/etc/something.conf"
19
- end
20
- EOF
21
- it { is_expected.not_to violate_rule }
22
- end
23
-
24
- context "with a cookbook with LWRP without use_inline_resources" do
25
- provider_file <<-EOF
26
- action :create do
27
- cookbook_file "/etc/something.conf"
28
- end
29
- EOF
30
- it { is_expected.not_to violate_rule }
31
- end
32
-
33
- context "with a cookbook with LWRP using use_inline_resources" do
34
- provider_file <<-EOF
35
- use_inline_resources
36
-
37
- action :create do
38
- template "/etc/something.conf" do
39
- notifies :restart, "service[something]"
40
- end
41
- end
42
- EOF
43
- it { is_expected.not_to violate_rule }
44
- end
45
- end
@@ -1,48 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC061" do
4
- context "with a cookbook with metadata that includes the version keyword and a valid version string" do
5
- metadata_file("version '1.2.3'")
6
- it { is_expected.not_to violate_rule }
7
- end
8
-
9
- context "with a cookbook with metadata that includes the version keyword and a valid version string with double quotes" do
10
- metadata_file('version "1.2.3"')
11
- it { is_expected.not_to violate_rule }
12
- end
13
-
14
- context "with a cookbook with metadata that includes the version keyword and a valid x.y version string" do
15
- metadata_file("version '1.2'")
16
- it { is_expected.not_to violate_rule }
17
- end
18
-
19
- context "with a cookbook with metadata that does not include a version keyword" do
20
- metadata_file("name 'something'")
21
- it { is_expected.not_to violate_rule }
22
- end
23
-
24
- context "with a cookbook with metadata that includes the version keyword and an invalid version string" do
25
- metadata_file("version 'one'")
26
- it { is_expected.to violate_rule }
27
- end
28
-
29
- context "with a cookbook metadata that includes the version keyword and an invalid single digit version string" do
30
- metadata_file("version '1'")
31
- it { is_expected.to violate_rule }
32
- end
33
-
34
- context "with a cookbook metadata that includes the version keyword and an invalid four digit version string" do
35
- metadata_file("version '1.2.3.4'")
36
- it { is_expected.to violate_rule }
37
- end
38
-
39
- context "with a cookbook metadata that includes the version keyword that uses string interpolation" do
40
- metadata_file('patch = 3\nversion "1.2.#{patch}"')
41
- it { is_expected.not_to violate_rule }
42
- end
43
-
44
- context "with a cookbook metadata that includes the version keyword that is not a string literal" do
45
- metadata_file('v = "1.2.3"\nversion v')
46
- it { is_expected.not_to violate_rule }
47
- end
48
- end
@@ -1,13 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC062" do
4
- context "with a cookbook with metadata that includes the version keyword and a valid version string" do
5
- metadata_file("version '1.2.3'")
6
- it { is_expected.not_to violate_rule }
7
- end
8
-
9
- context "with a cookbook with metadata that does not include a version keyword" do
10
- metadata_file
11
- it { is_expected.to violate_rule }
12
- end
13
- end
@@ -1,18 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC063" do
4
- context "with a cookbook with a metadata file that depends on itself" do
5
- metadata_file "name 'something'\ndepends 'something'"
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a metadata file that depends on a cookbook, but not itself" do
10
- metadata_file "name 'something'\ndepends 'another_thing'"
11
- it { is_expected.to_not violate_rule }
12
- end
13
-
14
- context "with a cookbook with a metadata file that doesn't depend on any cookbooks" do
15
- metadata_file "name 'something'"
16
- it { is_expected.to_not violate_rule }
17
- end
18
- end
@@ -1,13 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC064" do
4
- context "with a cookbook with a metadata file that does not specify issues_url" do
5
- metadata_file
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a metadata file that specifies a issues_url" do
10
- metadata_file "issues_url 'http://wwww.something.com/'"
11
- it { is_expected.to_not violate_rule }
12
- end
13
- end
@@ -1,13 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC065" do
4
- context "with a cookbook with a metadata file that does not specify source_url" do
5
- metadata_file
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a metadata file that specifies a source_url" do
10
- metadata_file "source_url 'http://wwww.something.com/'"
11
- it { is_expected.to_not violate_rule }
12
- end
13
- end
@@ -1,33 +0,0 @@
1
- require "spec_helper"
2
-
3
- describe "FC066" do
4
- context "with a cookbook with a metadata file that does not specify chef_version" do
5
- metadata_file "name 'my_cookbook'"
6
- it { is_expected.to violate_rule }
7
- end
8
-
9
- context "with a cookbook with a metadata file that specifies a chef_version" do
10
- metadata_file "chef_version '>= 12.1'"
11
- it { is_expected.to_not violate_rule }
12
- end
13
-
14
- context "with a cookbook with a metadata file that specifies a chef_version with a guard" do
15
- metadata_file "chef_version '>= 12.1' if defined?(chef_version)"
16
- it { is_expected.to_not violate_rule }
17
- end
18
-
19
- context "with a cookbook with a metadata file that specifies a chef_version with parens" do
20
- metadata_file "chef_version('>= 12.1')"
21
- it { is_expected.to_not violate_rule }
22
- end
23
-
24
- context "with a cookbook with a metadata file that specifies a chef_version with multiple arguments" do
25
- metadata_file "chef_version '>= 12.1', '< 14'"
26
- it { is_expected.to_not violate_rule }
27
- end
28
-
29
- context "with a cookbook with a metadata file that specifies a chef_version with a splat" do
30
- metadata_file "chef_version(*['>= 12.1', '< 14'])"
31
- it { is_expected.to_not violate_rule }
32
- end
33
- end