puppet-lint-file_ensure-check 1.1.0 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 24a250bf3d18fc54957c0fcc5dd769f814eac13dcd25fd431e7feecad2efd859
4
- data.tar.gz: 983689aa805f26a121d8c1cb27c0fb9b7321bdf40e1dbae2e86cb23e8c834380
3
+ metadata.gz: b48ce5731053c1de17397093cad95f8631d850fe035a67eda564a2a9e5f964c4
4
+ data.tar.gz: 2796c85a8bcf88f44cec483123302ec3462b7222714757a43118ffe8ae006038
5
5
  SHA512:
6
- metadata.gz: 8fa3b8e16f13802f579aa029bc8c668e9cca8d16037403aa53468be154458b289f9758690de7f55cf235f9d871e5e7cae7525fc3d75fe565d5ba3505c35b8654
7
- data.tar.gz: 606cc86fe430246fcb6e6ca8327f90749bfda0b309a1613b067cc00e761e48e79c6fe90ec04cbf44d7277792f532d4022fd3380b50ed1e1f55d6bc83d446e916
6
+ metadata.gz: 877b8d312a41f5826f89ace52995161464f815e8bde6ef41b306bf9a0297414776f1ffc65f8cc5749bc4c1b535335cf01566ba8d8f2aafaa3d0d9b202555cc7f
7
+ data.tar.gz: 262bb14424190e2070a6e10b8090de6ff911e33eeed17e48539fb3c0aed40b3d5599c3a9033927f115cc3486b0780f6ab1d789c2d0a2dba9a6adfd795fcaff3b
@@ -1,33 +1,39 @@
1
1
  PuppetLint.new_check(:file_ensure) do
2
2
  def check
3
3
  resource_indexes.each do |resource|
4
- if resource[:type].value == 'file'
5
- attr = resource[:tokens].select { |t| t.type == :NAME && \
6
- t.value == 'ensure' && \
7
- t.next_code_token.type == :FARROW }
8
- next if attr.empty?
9
- val_token = attr[0].next_code_token.next_code_token
10
- next unless val_token.value == 'present'
11
- next unless [:NAME, :STRING, :SSTRING].include? val_token.type
12
- notify :warning, {
13
- :message => 'ensure set to present on file resource',
14
- :line => val_token.line,
15
- :column => val_token.column,
16
- :token => val_token,
17
- :resource => resource,
18
- }
4
+ next unless resource[:type].value == 'file'
5
+
6
+ attr = resource[:tokens].select do |t|
7
+ t.type == :NAME &&
8
+ t.value == 'ensure' &&
9
+ t.next_code_token.type == :FARROW
19
10
  end
11
+ next if attr.empty?
12
+
13
+ val_token = attr[0].next_code_token.next_code_token
14
+ next unless val_token.value == 'present'
15
+ next unless %i[NAME STRING SSTRING].include? val_token.type
16
+
17
+ notify :warning, {
18
+ message: 'ensure set to present on file resource',
19
+ line: val_token.line,
20
+ column: val_token.column,
21
+ token: val_token,
22
+ resource: resource,
23
+ }
20
24
  end
21
25
  end
22
26
 
23
27
  def fix(problem)
24
- target_attr = problem[:resource][:tokens].select { |t| t.type == :NAME && \
25
- t.value == 'target' && \
26
- t.next_code_token.type == :FARROW }
27
- if target_attr.empty?
28
- problem[:token].value = 'file'
29
- else
30
- problem[:token].value = 'link'
28
+ target_attr = problem[:resource][:tokens].select do |t|
29
+ t.type == :NAME &&
30
+ t.value == 'target' &&
31
+ t.next_code_token.type == :FARROW
31
32
  end
33
+ problem[:token].value = if target_attr.empty?
34
+ 'file'
35
+ else
36
+ 'link'
37
+ end
32
38
  end
33
39
  end
@@ -1,11 +1,11 @@
1
1
  require 'spec_helper'
2
2
 
3
3
  describe 'file_ensure' do
4
- let (:msg) { 'ensure set to present on file resource' }
4
+ let(:msg) { 'ensure set to present on file resource' }
5
5
 
6
6
  context 'with fix disabled' do
7
7
  context 'correct file resource declarations' do
8
- let (:code) {
8
+ let(:code) do
9
9
  <<-EOS
10
10
  file { '/etc/sudoers':
11
11
  ensure => file,
@@ -20,15 +20,15 @@ describe 'file_ensure' do
20
20
  ensure => $present,
21
21
  }
22
22
  EOS
23
- }
23
+ end
24
24
 
25
- it 'should not detect any problems' do
25
+ it 'does not detect any problems' do
26
26
  expect(problems).to have(0).problems
27
27
  end
28
28
  end
29
29
 
30
30
  context 'wrong file resource declarations' do
31
- let (:code) {
31
+ let(:code) do
32
32
  <<-EOS
33
33
  file { '/etc/sudoers':
34
34
  ensure => present,
@@ -43,13 +43,13 @@ describe 'file_ensure' do
43
43
  ensure => $present,
44
44
  }
45
45
  EOS
46
- }
46
+ end
47
47
 
48
- it 'should detect problems' do
48
+ it 'detects problems' do
49
49
  expect(problems).to have(2).problems
50
50
  end
51
51
 
52
- it 'should create a warning' do
52
+ it 'creates a warning' do
53
53
  expect(problems).to contain_warning(msg).on_line(2).in_column(21)
54
54
  expect(problems).to contain_warning(msg).on_line(6).in_column(21)
55
55
  end
@@ -66,7 +66,7 @@ describe 'file_ensure' do
66
66
  end
67
67
 
68
68
  context 'correct file resource declarations' do
69
- let (:code) {
69
+ let(:code) do
70
70
  <<-EOS
71
71
  file { '/etc/sudoers':
72
72
  ensure => file,
@@ -81,19 +81,19 @@ describe 'file_ensure' do
81
81
  ensure => $present,
82
82
  }
83
83
  EOS
84
- }
84
+ end
85
85
 
86
- it 'should not detect any problems' do
86
+ it 'does not detect any problems' do
87
87
  expect(problems).to have(0).problems
88
88
  end
89
89
 
90
- it 'should not modify the manifest' do
90
+ it 'does not modify the manifest' do
91
91
  expect(manifest).to eq(code)
92
92
  end
93
93
  end
94
94
 
95
95
  context 'wrong file resource declarations' do
96
- let (:code) {
96
+ let(:code) do
97
97
  <<-EOS
98
98
  file { '/etc/sudoers':
99
99
  ensure => present,
@@ -108,20 +108,20 @@ describe 'file_ensure' do
108
108
  ensure => $present,
109
109
  }
110
110
  EOS
111
- }
111
+ end
112
112
 
113
- it 'should detect two problems' do
113
+ it 'detects two problems' do
114
114
  expect(problems).to have(2).problems
115
115
  end
116
116
 
117
- it 'should create a warning' do
117
+ it 'creates a warning' do
118
118
  expect(problems).to contain_fixed(msg).on_line(2).in_column(21)
119
119
  expect(problems).to contain_fixed(msg).on_line(6).in_column(21)
120
120
  end
121
121
 
122
- it 'should fix the ensure parameter' do
122
+ it 'fixes the ensure parameter' do
123
123
  expect(manifest).to eq(
124
- <<-EOS
124
+ <<-EOS,
125
125
  file { '/etc/sudoers':
126
126
  ensure => file,
127
127
  }
data/spec/spec_helper.rb CHANGED
@@ -1,29 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- begin
4
- require 'simplecov'
5
- require 'simplecov-console'
6
- require 'codecov'
7
- rescue LoadError
8
- else
9
- SimpleCov.start do
10
- track_files 'lib/**/*.rb'
11
-
12
- add_filter '/spec'
13
-
14
- enable_coverage :branch
15
-
16
- # do not track vendored files
17
- add_filter '/vendor'
18
- add_filter '/.vendor'
19
- end
20
-
21
- SimpleCov.formatters = [
22
- SimpleCov::Formatter::Console,
23
- SimpleCov::Formatter::Codecov,
24
- ]
25
- end
26
-
27
3
  require 'puppet-lint'
4
+ require 'rspec/collection_matchers'
28
5
 
29
6
  PuppetLint::Plugins.load_spec_helper
metadata CHANGED
@@ -1,119 +1,48 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: puppet-lint-file_ensure-check
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.1.0
4
+ version: 3.0.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Vox Pupuli
8
- autorequire:
9
8
  bindir: bin
10
9
  cert_chain: []
11
- date: 2022-11-29 00:00:00.000000000 Z
10
+ date: 1980-01-02 00:00:00.000000000 Z
12
11
  dependencies:
13
12
  - !ruby/object:Gem::Dependency
14
13
  name: puppet-lint
15
- requirement: !ruby/object:Gem::Requirement
16
- requirements:
17
- - - ">="
18
- - !ruby/object:Gem::Version
19
- version: '1.0'
20
- - - "<"
21
- - !ruby/object:Gem::Version
22
- version: '4'
23
- type: :runtime
24
- prerelease: false
25
- version_requirements: !ruby/object:Gem::Requirement
26
- requirements:
27
- - - ">="
28
- - !ruby/object:Gem::Version
29
- version: '1.0'
30
- - - "<"
31
- - !ruby/object:Gem::Version
32
- version: '4'
33
- - !ruby/object:Gem::Dependency
34
- name: rspec
35
- requirement: !ruby/object:Gem::Requirement
36
- requirements:
37
- - - "~>"
38
- - !ruby/object:Gem::Version
39
- version: '3.0'
40
- type: :development
41
- prerelease: false
42
- version_requirements: !ruby/object:Gem::Requirement
43
- requirements:
44
- - - "~>"
45
- - !ruby/object:Gem::Version
46
- version: '3.0'
47
- - !ruby/object:Gem::Dependency
48
- name: rspec-its
49
- requirement: !ruby/object:Gem::Requirement
50
- requirements:
51
- - - "~>"
52
- - !ruby/object:Gem::Version
53
- version: '1.0'
54
- type: :development
55
- prerelease: false
56
- version_requirements: !ruby/object:Gem::Requirement
57
- requirements:
58
- - - "~>"
59
- - !ruby/object:Gem::Version
60
- version: '1.0'
61
- - !ruby/object:Gem::Dependency
62
- name: rspec-collection_matchers
63
14
  requirement: !ruby/object:Gem::Requirement
64
15
  requirements:
65
16
  - - "~>"
66
17
  - !ruby/object:Gem::Version
67
- version: '1.0'
68
- type: :development
18
+ version: '5.1'
19
+ type: :runtime
69
20
  prerelease: false
70
21
  version_requirements: !ruby/object:Gem::Requirement
71
22
  requirements:
72
23
  - - "~>"
73
24
  - !ruby/object:Gem::Version
74
- version: '1.0'
25
+ version: '5.1'
75
26
  - !ruby/object:Gem::Dependency
76
27
  name: mime-types
77
28
  requirement: !ruby/object:Gem::Requirement
78
29
  requirements:
79
- - - ">="
30
+ - - "~>"
80
31
  - !ruby/object:Gem::Version
81
- version: '0'
82
- type: :development
83
- prerelease: false
84
- version_requirements: !ruby/object:Gem::Requirement
85
- requirements:
32
+ version: '3.4'
86
33
  - - ">="
87
34
  - !ruby/object:Gem::Version
88
- version: '0'
89
- - !ruby/object:Gem::Dependency
90
- name: simplecov
91
- requirement: !ruby/object:Gem::Requirement
92
- requirements:
93
- - - ">="
94
- - !ruby/object:Gem::Version
95
- version: '0'
35
+ version: 3.4.1
96
36
  type: :development
97
37
  prerelease: false
98
38
  version_requirements: !ruby/object:Gem::Requirement
99
39
  requirements:
100
- - - ">="
40
+ - - "~>"
101
41
  - !ruby/object:Gem::Version
102
- version: '0'
103
- - !ruby/object:Gem::Dependency
104
- name: rake
105
- requirement: !ruby/object:Gem::Requirement
106
- requirements:
42
+ version: '3.4'
107
43
  - - ">="
108
44
  - !ruby/object:Gem::Version
109
- version: '0'
110
- type: :development
111
- prerelease: false
112
- version_requirements: !ruby/object:Gem::Requirement
113
- requirements:
114
- - - ">="
115
- - !ruby/object:Gem::Version
116
- version: '0'
45
+ version: 3.4.1
117
46
  description: " A puppet-lint plugin to check the ensure attribute on file resources.\n"
118
47
  email: voxpupuli@groups.io
119
48
  executables: []
@@ -129,7 +58,6 @@ homepage: https://github.com/voxpupuli/puppet-lint-file_ensure-check
129
58
  licenses:
130
59
  - Apache-2.0
131
60
  metadata: {}
132
- post_install_message:
133
61
  rdoc_options: []
134
62
  require_paths:
135
63
  - lib
@@ -137,17 +65,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
137
65
  requirements:
138
66
  - - ">="
139
67
  - !ruby/object:Gem::Version
140
- version: '0'
68
+ version: '3.2'
141
69
  required_rubygems_version: !ruby/object:Gem::Requirement
142
70
  requirements:
143
71
  - - ">="
144
72
  - !ruby/object:Gem::Version
145
73
  version: '0'
146
74
  requirements: []
147
- rubygems_version: 3.2.33
148
- signing_key:
75
+ rubygems_version: 3.6.9
149
76
  specification_version: 4
150
77
  summary: A puppet-lint plugin to check the ensure attribute on file resources.
151
- test_files:
152
- - spec/puppet-lint/plugins/check_file_ensure/check_file_ensure_spec.rb
153
- - spec/spec_helper.rb
78
+ test_files: []