foodcritic 15.0.0 → 15.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/chef_dsl_metadata/{chef_14.7.17.json → chef_14.8.12.json} +61 -1
- data/foodcritic.gemspec +1 -3
- data/lib/foodcritic/linter.rb +1 -1
- data/lib/foodcritic/version.rb +1 -1
- metadata +5 -232
- data/Rakefile +0 -73
- data/features/002_check_string_interpolation.feature +0 -50
- data/features/005_check_for_resource_repetition.feature +0 -64
- data/features/006_check_file_mode.feature +0 -36
- data/features/009_check_for_unrecognised_resource_attributes.feature +0 -55
- data/features/014_check_for_long_ruby_blocks.feature +0 -30
- data/features/018_check_for_old_lwrp_notification_syntax.feature +0 -25
- data/features/019_check_for_consistent_node_access.feature +0 -108
- data/features/021_check_for_dodgy_lwrp_conditions.feature +0 -28
- data/features/022_check_for_dodgy_conditions_within_loop.feature +0 -43
- data/features/024_check_for_missing_platforms.feature +0 -43
- data/features/027_check_for_internal_attribute_use.feature +0 -22
- data/features/030_check_for_debugger_breakpoints.feature +0 -25
- data/features/032_check_for_invalid_notification_timing.feature +0 -24
- data/features/033_check_for_missing_template.feature +0 -39
- data/features/034_check_for_unused_template_variables.feature +0 -80
- data/features/037_check_for_invalid_notification_action.feature +0 -34
- data/features/038_check_for_invalid_action.feature +0 -39
- data/features/039_check_for_key_access_to_node_methods.feature +0 -33
- data/features/044_check_for_bare_attribute_keys.feature +0 -53
- data/features/046_check_for_assign_unless_nil_attributes.feature +0 -21
- data/features/047_check_for_attribute_assignment_without_precedence.feature +0 -49
- data/features/051_check_for_template_partial_loops.feature +0 -40
- data/features/build_framework_support.feature +0 -109
- data/features/checking_all_types_of_file.feature +0 -40
- data/features/choose_rules_to_apply.feature +0 -47
- data/features/command_line_help.feature +0 -58
- data/features/continuous_integration_support.feature +0 -33
- data/features/exclude_paths_to_lint.feature +0 -12
- data/features/ignore_via_line_comments.feature +0 -69
- data/features/include_custom_rules.feature +0 -29
- data/features/individual_file.feature +0 -28
- data/features/limit_rules_to_specific_versions.feature +0 -65
- data/features/multiple_paths.feature +0 -35
- data/features/show_lines_matched.feature +0 -20
- data/features/sort_warnings.feature +0 -10
- data/features/specify_search_grammar.feature +0 -25
- data/features/step_definitions/cookbook_steps.rb +0 -1826
- data/features/support/command_helpers.rb +0 -418
- data/features/support/cookbook_helpers.rb +0 -599
- data/features/support/env.rb +0 -19
- data/man/foodcritic.1.ronn +0 -76
- data/spec/functional/fc001_spec.rb +0 -72
- data/spec/functional/fc004_spec.rb +0 -84
- data/spec/functional/fc007_spec.rb +0 -127
- data/spec/functional/fc008_spec.rb +0 -33
- data/spec/functional/fc009_spec.rb +0 -37
- data/spec/functional/fc010_spec.rb +0 -32
- data/spec/functional/fc011_spec.rb +0 -20
- data/spec/functional/fc013_spec.rb +0 -39
- data/spec/functional/fc015_spec.rb +0 -19
- data/spec/functional/fc016_spec.rb +0 -57
- data/spec/functional/fc025_spec.rb +0 -60
- data/spec/functional/fc026_spec.rb +0 -66
- data/spec/functional/fc028_spec.rb +0 -93
- data/spec/functional/fc029_spec.rb +0 -33
- data/spec/functional/fc031_spec.rb +0 -14
- data/spec/functional/fc037_spec.rb +0 -75
- data/spec/functional/fc038_spec.rb +0 -28
- data/spec/functional/fc040_spec.rb +0 -156
- data/spec/functional/fc041_spec.rb +0 -121
- data/spec/functional/fc042_spec.rb +0 -13
- data/spec/functional/fc043_spec.rb +0 -28
- data/spec/functional/fc045_spec.rb +0 -18
- data/spec/functional/fc048_spec.rb +0 -67
- data/spec/functional/fc049_spec.rb +0 -56
- data/spec/functional/fc050_spec.rb +0 -85
- data/spec/functional/fc052_spec.rb +0 -13
- data/spec/functional/fc053_spec.rb +0 -13
- data/spec/functional/fc055_spec.rb +0 -18
- data/spec/functional/fc056_spec.rb +0 -18
- data/spec/functional/fc058_spec.rb +0 -102
- data/spec/functional/fc060_spec.rb +0 -45
- data/spec/functional/fc061_spec.rb +0 -48
- data/spec/functional/fc062_spec.rb +0 -13
- data/spec/functional/fc063_spec.rb +0 -18
- data/spec/functional/fc064_spec.rb +0 -13
- data/spec/functional/fc065_spec.rb +0 -13
- data/spec/functional/fc066_spec.rb +0 -33
- data/spec/functional/fc067_spec.rb +0 -13
- data/spec/functional/fc068_spec.rb +0 -13
- data/spec/functional/fc069_spec.rb +0 -38
- data/spec/functional/fc070_spec.rb +0 -65
- data/spec/functional/fc071_spec.rb +0 -36
- data/spec/functional/fc072_spec.rb +0 -13
- data/spec/functional/fc073_spec.rb +0 -56
- data/spec/functional/fc074_spec.rb +0 -39
- data/spec/functional/fc075_spec.rb +0 -41
- data/spec/functional/fc076_spec.rb +0 -13
- data/spec/functional/fc077_spec.rb +0 -13
- data/spec/functional/fc078_spec.rb +0 -35
- data/spec/functional/fc079_spec.rb +0 -21
- data/spec/functional/fc080_spec.rb +0 -68
- data/spec/functional/fc081_spec.rb +0 -25
- data/spec/functional/fc082_spec.rb +0 -23
- data/spec/functional/fc083_spec.rb +0 -34
- data/spec/functional/fc084_spec.rb +0 -49
- data/spec/functional/fc085_spec.rb +0 -77
- data/spec/functional/fc086_spec.rb +0 -45
- data/spec/functional/fc087_spec.rb +0 -43
- data/spec/functional/fc088_spec.rb +0 -18
- data/spec/functional/fc089_spec.rb +0 -23
- data/spec/functional/fc091_spec.rb +0 -38
- data/spec/functional/fc092_spec.rb +0 -31
- data/spec/functional/fc093_spec.rb +0 -27
- data/spec/functional/fc094_spec.rb +0 -18
- data/spec/functional/fc095_spec.rb +0 -18
- data/spec/functional/fc096_spec.rb +0 -18
- data/spec/functional/fc097_spec.rb +0 -18
- data/spec/functional/fc098_spec.rb +0 -18
- data/spec/functional/fc099_spec.rb +0 -18
- data/spec/functional/fc100_spec.rb +0 -18
- data/spec/functional/fc101_spec.rb +0 -23
- data/spec/functional/fc102_spec.rb +0 -18
- data/spec/functional/fc103_spec.rb +0 -30
- data/spec/functional/fc104_spec.rb +0 -54
- data/spec/functional/fc105_spec.rb +0 -36
- data/spec/functional/fc106_spec.rb +0 -21
- data/spec/functional/fc107_spec.rb +0 -22
- data/spec/functional/fc108_spec.rb +0 -43
- data/spec/functional/fc109_spec.rb +0 -22
- data/spec/functional/fc110_spec.rb +0 -21
- data/spec/functional/fc111_spec.rb +0 -17
- data/spec/functional/fc112_spec.rb +0 -17
- data/spec/functional/fc113_spec.rb +0 -98
- data/spec/functional/fc114_spec.rb +0 -31
- data/spec/functional/fc115_spec.rb +0 -24
- data/spec/functional/fc116_spec.rb +0 -18
- data/spec/functional/fc117_spec.rb +0 -23
- data/spec/functional/fc118_spec.rb +0 -17
- data/spec/functional/fc119_spec.rb +0 -27
- data/spec/functional/fc120_spec.rb +0 -21
- data/spec/functional/fc121_spec.rb +0 -45
- data/spec/functional/fc122_spec.rb +0 -18
- data/spec/functional/root_aliases_spec.rb +0 -13
- data/spec/regression/cookbooks.txt +0 -83
- data/spec/regression/expected/activemq.txt +0 -6
- data/spec/regression/expected/aix.txt +0 -27
- data/spec/regression/expected/apparmor.txt +0 -9
- data/spec/regression/expected/apt.txt +0 -14
- data/spec/regression/expected/ark.txt +0 -3
- data/spec/regression/expected/auditd.txt +0 -2
- data/spec/regression/expected/aws.txt +0 -16
- data/spec/regression/expected/bluepill.txt +0 -12
- data/spec/regression/expected/boost.txt +0 -8
- data/spec/regression/expected/build-essential.txt +0 -8
- data/spec/regression/expected/chef-client.txt +0 -17
- data/spec/regression/expected/chef-ingredient.txt +0 -6
- data/spec/regression/expected/chef-server.txt +0 -13
- data/spec/regression/expected/chef-vault.txt +0 -7
- data/spec/regression/expected/chef.txt +0 -104
- data/spec/regression/expected/chef_client_updater.txt +0 -2
- data/spec/regression/expected/chef_handler.txt +0 -7
- data/spec/regression/expected/chef_hostname.txt +0 -3
- data/spec/regression/expected/chef_nginx.txt +0 -4
- data/spec/regression/expected/cron.txt +0 -7
- data/spec/regression/expected/database.txt +0 -42
- data/spec/regression/expected/dmg.txt +0 -11
- data/spec/regression/expected/docker.txt +0 -4
- data/spec/regression/expected/drbd.txt +0 -29
- data/spec/regression/expected/dynect.txt +0 -33
- data/spec/regression/expected/erlang.txt +0 -6
- data/spec/regression/expected/fail2ban.txt +0 -5
- data/spec/regression/expected/firewall.txt +0 -11
- data/spec/regression/expected/gecode.txt +0 -10
- data/spec/regression/expected/gems.txt +0 -32
- data/spec/regression/expected/gunicorn.txt +0 -11
- data/spec/regression/expected/heartbeat.txt +0 -8
- data/spec/regression/expected/homebrew.txt +0 -7
- data/spec/regression/expected/iis.txt +0 -22
- data/spec/regression/expected/iptables.txt +0 -9
- data/spec/regression/expected/jetty.txt +0 -13
- data/spec/regression/expected/jpackage.txt +0 -9
- data/spec/regression/expected/keepalived.txt +0 -3
- data/spec/regression/expected/kickstart.txt +0 -15
- data/spec/regression/expected/libarchive.txt +0 -6
- data/spec/regression/expected/logwatch.txt +0 -5
- data/spec/regression/expected/lvm.txt +0 -14
- data/spec/regression/expected/maradns.txt +0 -14
- data/spec/regression/expected/maven.txt +0 -8
- data/spec/regression/expected/memcached.txt +0 -31
- data/spec/regression/expected/motd-tail.txt +0 -5
- data/spec/regression/expected/mysql.txt +0 -19
- data/spec/regression/expected/ohai.txt +0 -9
- data/spec/regression/expected/openldap.txt +0 -12
- data/spec/regression/expected/openssh.txt +0 -6
- data/spec/regression/expected/openssl.txt +0 -6
- data/spec/regression/expected/partial_search.txt +0 -7
- data/spec/regression/expected/passenger_apache2.txt +0 -31
- data/spec/regression/expected/perl.txt +0 -14
- data/spec/regression/expected/php.txt +0 -6
- data/spec/regression/expected/postfix.txt +0 -8
- data/spec/regression/expected/powershell.txt +0 -8
- data/spec/regression/expected/resolver.txt +0 -7
- data/spec/regression/expected/rsync.txt +0 -9
- data/spec/regression/expected/rsyslog.txt +0 -11
- data/spec/regression/expected/runit.txt +0 -4
- data/spec/regression/expected/smokeping.txt +0 -6
- data/spec/regression/expected/sql_server.txt +0 -7
- data/spec/regression/expected/ssh_known_hosts.txt +0 -6
- data/spec/regression/expected/stompserver.txt +0 -6
- data/spec/regression/expected/subversion.txt +0 -6
- data/spec/regression/expected/sudo.txt +0 -10
- data/spec/regression/expected/tar.txt +0 -10
- data/spec/regression/expected/tftp.txt +0 -6
- data/spec/regression/expected/tomcat.txt +0 -18
- data/spec/regression/expected/transmission.txt +0 -13
- data/spec/regression/expected/ubuntu.txt +0 -5
- data/spec/regression/expected/ufw.txt +0 -12
- data/spec/regression/expected/unicorn.txt +0 -7
- data/spec/regression/expected/users.txt +0 -12
- data/spec/regression/expected/vcruntime.txt +0 -8
- data/spec/regression/expected/vim.txt +0 -7
- data/spec/regression/expected/webpi.txt +0 -7
- data/spec/regression/expected/whitelist-node-attrs.txt +0 -7
- data/spec/regression/expected/windows.txt +0 -35
- data/spec/regression/expected/wix.txt +0 -5
- data/spec/regression/expected/xml.txt +0 -7
- data/spec/regression/expected/yum.txt +0 -15
- data/spec/regression/regression_spec.rb +0 -23
- data/spec/spec_helper.rb +0 -132
- data/spec/unit/api_spec.rb +0 -1939
- data/spec/unit/chef_spec.rb +0 -66
- data/spec/unit/command_line_spec.rb +0 -136
- data/spec/unit/domain_spec.rb +0 -78
- data/spec/unit/linter_spec.rb +0 -107
- 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
|