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
|
require 'spec_helper'
RSpec.describe(Regexp::Token) do
specify('#offset') do
regexp = /ab?cd/
tokens = RL.lex(regexp)
expect(tokens[1].text).to eq 'b'
expect(tokens[1].offset).to eq [1, 2]
expect(tokens[2].text).to eq '?'
expect(tokens[2].offset).to eq [2, 3]
expect(tokens[3].text).to eq 'cd'
expect(tokens[3].offset).to eq [3, 5]
end
specify('#length') do
regexp = /abc?def/
tokens = RL.lex(regexp)
expect(tokens[0].text).to eq 'ab'
expect(tokens[0].length).to eq 2
expect(tokens[1].text).to eq 'c'
expect(tokens[1].length).to eq 1
expect(tokens[2].text).to eq '?'
expect(tokens[2].length).to eq 1
expect(tokens[3].text).to eq 'def'
expect(tokens[3].length).to eq 3
end
specify('#to_h') do
regexp = /abc?def/
tokens = RL.lex(regexp)
expect(tokens[0].text).to eq 'ab'
expect(tokens[0].to_h).to eq type: :literal, token: :literal, text: 'ab', ts: 0, te: 2, level: 0, set_level: 0, conditional_level: 0
expect(tokens[2].text).to eq '?'
expect(tokens[2].to_h).to eq type: :quantifier, token: :zero_or_one, text: '?', ts: 3, te: 4, level: 0, set_level: 0, conditional_level: 0
end
specify('#next') do
regexp = /a+b?c*d{2,3}/
tokens = RL.lex(regexp)
a = tokens.first
expect(a.text).to eq 'a'
plus = a.next
expect(plus.text).to eq '+'
b = plus.next
expect(b.text).to eq 'b'
interval = tokens.last
expect(interval.text).to eq '{2,3}'
expect(interval.next).to be_nil
end
specify('#previous') do
regexp = /a+b?c*d{2,3}/
tokens = RL.lex(regexp)
interval = tokens.last
expect(interval.text).to eq '{2,3}'
d = interval.previous
expect(d.text).to eq 'd'
star = d.previous
expect(star.text).to eq '*'
c = star.previous
expect(c.text).to eq 'c'
a = tokens.first
expect(a.text).to eq 'a'
expect(a.previous).to be_nil
end
end
|