File: parser_spec.rb

package info (click to toggle)
puppet-agent 7.23.0-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 19,092 kB
  • sloc: ruby: 245,074; sh: 456; makefile: 38; xml: 33
file content (211 lines) | stat: -rw-r--r-- 7,296 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
require 'spec_helper'
require 'puppet/pops'

describe Puppet::Pops::Parser::Parser do
  it "should instantiate a parser" do
    parser = Puppet::Pops::Parser::Parser.new()
    expect(parser.class).to eq(Puppet::Pops::Parser::Parser)
  end

  it "should parse a code string and return a model" do
    parser = Puppet::Pops::Parser::Parser.new()
    model = parser.parse_string("$a = 10").model
    expect(model.class).to eq(Puppet::Pops::Model::Program)
    expect(model.body.class).to eq(Puppet::Pops::Model::AssignmentExpression)
  end

  it "should accept empty input and return a model" do
    parser = Puppet::Pops::Parser::Parser.new()
    model = parser.parse_string("").model
    expect(model.class).to eq(Puppet::Pops::Model::Program)
    expect(model.body.class).to eq(Puppet::Pops::Model::Nop)
  end

  it "should accept empty input containing only comments and report location at end of input" do
    parser = Puppet::Pops::Parser::Parser.new()
    model = parser.parse_string("# comment\n").model
    expect(model.class).to eq(Puppet::Pops::Model::Program)
    expect(model.body.class).to eq(Puppet::Pops::Model::Nop)
    expect(model.body.offset).to eq(10)
    expect(model.body.length).to eq(0)
  end

  it "should give single resource expressions the correct offset inside an if/else statement" do
    parser = Puppet::Pops::Parser::Parser.new()
    model = parser.parse_string(<<-EOF).model
class firewall {
  if(true) {
    service { 'if service':
      ensure    => stopped
    }
  } else {
    service { 'else service':
      ensure    => running
    }
  }
}
    EOF

    then_service = model.body.body.statements[0].then_expr
    expect(then_service.class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(then_service.offset).to eq(34)

    else_service = model.body.body.statements[0].else_expr
    expect(else_service.class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(else_service.offset).to eq(106)
  end

  it "should give block expressions and their contained resources the correct offset inside an if/else statement" do
    parser = Puppet::Pops::Parser::Parser.new()
    model = parser.parse_string(<<-EOF).model
class firewall {
  if(true) {
    service { 'if service 1':
      ensure    => running
    }

    service { 'if service 2':
      ensure    => stopped
    }
  } else {
    service { 'else service 1':
      ensure    => running
    }

    service { 'else service 2':
      ensure    => stopped
    }
  }
}
    EOF

    if_expr = model.body.body.statements[0]
    block_expr = model.body.body.statements[0].then_expr
    expect(if_expr.class).to eq(Puppet::Pops::Model::IfExpression)
    expect(if_expr.offset).to eq(19)
    expect(block_expr.class).to eq(Puppet::Pops::Model::BlockExpression)
    expect(block_expr.offset).to eq(28)
    expect(block_expr.statements[0].class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(block_expr.statements[0].offset).to eq(34)
    expect(block_expr.statements[1].class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(block_expr.statements[1].offset).to eq(98)

    block_expr = model.body.body.statements[0].else_expr
    expect(block_expr.class).to eq(Puppet::Pops::Model::BlockExpression)
    expect(block_expr.offset).to eq(166)
    expect(block_expr.statements[0].class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(block_expr.statements[0].offset).to eq(172)
    expect(block_expr.statements[1].class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(block_expr.statements[1].offset).to eq(238)
  end

  it "should give single resource expressions the correct offset inside an unless/else statement" do
    parser = Puppet::Pops::Parser::Parser.new()
    model = parser.parse_string(<<-EOF).model
class firewall {
  unless(true) {
    service { 'if service':
      ensure    => stopped
    }
  } else {
    service { 'else service':
      ensure    => running
    }
  }
}
    EOF

    then_service = model.body.body.statements[0].then_expr
    expect(then_service.class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(then_service.offset).to eq(38)

    else_service = model.body.body.statements[0].else_expr
    expect(else_service.class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(else_service.offset).to eq(110)
  end

  it "should give block expressions and their contained resources the correct offset inside an unless/else statement" do
    parser = Puppet::Pops::Parser::Parser.new()
    model = parser.parse_string(<<-EOF).model
class firewall {
  unless(true) {
    service { 'if service 1':
      ensure    => running
    }

    service { 'if service 2':
      ensure    => stopped
    }
  } else {
    service { 'else service 1':
      ensure    => running
    }

    service { 'else service 2':
      ensure    => stopped
    }
  }
}
    EOF

    if_expr = model.body.body.statements[0]
    block_expr = model.body.body.statements[0].then_expr
    expect(if_expr.class).to eq(Puppet::Pops::Model::UnlessExpression)
    expect(if_expr.offset).to eq(19)
    expect(block_expr.class).to eq(Puppet::Pops::Model::BlockExpression)
    expect(block_expr.offset).to eq(32)
    expect(block_expr.statements[0].class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(block_expr.statements[0].offset).to eq(38)
    expect(block_expr.statements[1].class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(block_expr.statements[1].offset).to eq(102)

    block_expr = model.body.body.statements[0].else_expr
    expect(block_expr.class).to eq(Puppet::Pops::Model::BlockExpression)
    expect(block_expr.offset).to eq(170)
    expect(block_expr.statements[0].class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(block_expr.statements[0].offset).to eq(176)
    expect(block_expr.statements[1].class).to eq(Puppet::Pops::Model::ResourceExpression)
    expect(block_expr.statements[1].offset).to eq(242)
  end

  it "multi byte characters in a comment are counted as individual bytes" do
    parser = Puppet::Pops::Parser::Parser.new()
    model = parser.parse_string("# \u{0400}comment\n").model
    expect(model.class).to eq(Puppet::Pops::Model::Program)
    expect(model.body.class).to eq(Puppet::Pops::Model::Nop)
    expect(model.body.offset).to eq(12)
    expect(model.body.length).to eq(0)
  end

  it "should raise an error with position information when error is raised from within parser" do
    parser = Puppet::Pops::Parser::Parser.new()
    the_error = nil
    begin
      parser.parse_string("File [1] { }", 'fakefile.pp')
    rescue Puppet::ParseError => e
      the_error = e
    end
    expect(the_error).to be_a(Puppet::ParseError)
    expect(the_error.file).to eq('fakefile.pp')
    expect(the_error.line).to eq(1)
    expect(the_error.pos).to eq(6)
  end

  it "should raise an error with position information when error is raised on token" do
    parser = Puppet::Pops::Parser::Parser.new()
    the_error = nil
    begin
      parser.parse_string(<<-EOF, 'fakefile.pp')
class whoops($a,$b,$c) {
  $d = "oh noes",  "b"
}
      EOF
    rescue Puppet::ParseError => e
      the_error = e
    end
    expect(the_error).to be_a(Puppet::ParseError)
    expect(the_error.file).to eq('fakefile.pp')
    expect(the_error.line).to eq(2)
    expect(the_error.pos).to eq(17)
  end
end