247 lines
5.7 KiB
Python
247 lines
5.7 KiB
Python
from advent.parser.parser import P
|
|
import pytest
|
|
|
|
|
|
def test_one_letter():
|
|
parser = P.is_char('!')
|
|
input = '!'
|
|
expected = '!'
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_one_letter_longer():
|
|
parser = P.is_char('!')
|
|
input = '!!'
|
|
expected = '!'
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_one_string():
|
|
parser = P.string('123')
|
|
input = '12345'
|
|
expected = '123'
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_eof():
|
|
parser = P.eof()
|
|
input = ''
|
|
result = parser.parse(input).get()
|
|
assert result == ()
|
|
|
|
input = '!'
|
|
with pytest.raises(Exception):
|
|
parser.parse(input).get()
|
|
|
|
|
|
def test_integer():
|
|
parser = P.signed()
|
|
input = '123456'
|
|
expected = 123456
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_signed_integer():
|
|
parser = P.signed()
|
|
input = '-123456'
|
|
expected = -123456
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_starting_zero():
|
|
parser = P.unsigned()
|
|
input = '0a'
|
|
expected = 0
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
input2 = '01'
|
|
result2 = parser.parse(input2)
|
|
assert result2.is_fail()
|
|
|
|
|
|
def test_between():
|
|
parser = P.signed().between(P.is_char('<'), P.is_char('>'))
|
|
input = '<-123456>'
|
|
expected = -123456
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_sep_by():
|
|
parser = P.signed().sep_by(P.is_char(','))
|
|
input = '1,1,2,3,5,8,13'
|
|
expected = [1, 1, 2, 3, 5, 8, 13]
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_trim():
|
|
parser = P.signed().trim()
|
|
input = '1'
|
|
expected = 1
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_sep_by_trim():
|
|
parser = P.signed().sep_by(P.is_char(',').trim()).trim()
|
|
input = ' 1 , 1 , 2 , 3 , 5 , 8 , 13!'
|
|
expected = [1, 1, 2, 3, 5, 8, 13]
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_choice2():
|
|
parser = P.choice(P.is_char('a'), P.unsigned(), P.string('hallo'))
|
|
input = '1'
|
|
expected = 1
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
input = 'hallo'
|
|
expected = 'hallo'
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_seq():
|
|
input = '1234'
|
|
parser = P.seq(P.one_char(), P.one_char(), P.one_char(), P.one_char())
|
|
expected = ('1', '2', '3', '4')
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_seq_seq():
|
|
input = '1,2,3,4'
|
|
digit = P.char_func(lambda c: c.isdigit(), )
|
|
parser = P.sep_seq(digit, digit, digit, digit, sep=P.is_char(','))
|
|
|
|
expected = ('1', '2', '3', '4')
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
|
|
def test_not():
|
|
input = 'a'
|
|
parser = P.snd(P.no_match(P.is_char('!')), P.is_char('a'))
|
|
expected = 'a'
|
|
result = parser.parse(input).get()
|
|
assert result == expected
|
|
|
|
input2 = '!'
|
|
result2 = parser.parse(input2)
|
|
assert result2.is_fail()
|
|
|
|
|
|
def test_multi():
|
|
input = 'aa'
|
|
parser = P.is_char('a').many()
|
|
expected = [['a', 'a'], ['a'], []]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_either():
|
|
input = 'aab'
|
|
parser = P.either(
|
|
P.seq(
|
|
P.is_char('a').many(), P.string('b')), P.seq(
|
|
P.string('a'), P.string('ab')))
|
|
expected = [(['a', 'a'], 'b'), ('a', 'ab')]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_seq_eof():
|
|
input = 'aa'
|
|
parser = P.seq(P.is_char('a').many(), P.eof())
|
|
expected = [(['a', 'a'], ())]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_optional():
|
|
input = '12'
|
|
parser = P.seq(P.is_char('1').optional(), P.unsigned())
|
|
expected = [('1', 2), (None, 12), (None, 1)]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_choice():
|
|
input = '1'
|
|
parser = P.choice(P.is_char('1'), P.is_char('b'), P.unsigned())
|
|
expected = ['1', 1]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_times_exact():
|
|
input = 'aaa'
|
|
parser = P.is_char('a').times(exact=2)
|
|
expected = [['a', 'a']]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_times_min():
|
|
input = 'aaa'
|
|
parser = P.is_char('a').times(min=2)
|
|
expected = [['a', 'a', 'a'], ['a', 'a']]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_times_max():
|
|
input = 'aaa'
|
|
parser = P.is_char('a').times(max=2)
|
|
expected = [['a', 'a'], ['a'], []]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_some_lazy():
|
|
input = 'aa'
|
|
parser = P.is_char('a').some_lazy()
|
|
expected = [['a'], ['a', 'a']]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_many_lazy():
|
|
input = 'aa'
|
|
parser = P.is_char('a').many_lazy()
|
|
expected = [[], ['a'], ['a', 'a']]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_times_lazy_exact():
|
|
input = 'aaa'
|
|
parser = P.is_char('a').times_lazy(exact=2)
|
|
expected = [['a', 'a']]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_times_lazy_min():
|
|
input = 'aaa'
|
|
parser = P.is_char('a').times_lazy(min=2)
|
|
expected = [['a', 'a'], ['a', 'a', 'a']]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|
|
|
|
|
|
def test_times_lazy_max():
|
|
input = 'aaa'
|
|
parser = P.is_char('a').times_lazy(max=2)
|
|
expected = [[], ['a'], ['a', 'a']]
|
|
result = list(parser.parse_multi(input))
|
|
assert result == expected
|