hy/tests/lexer/test_list_lexing.py

45 lines
968 B
Python
Raw Normal View History

2012-12-15 18:20:15 -05:00
from hy.lex.tokenize import tokenize
def test_list_lex():
2012-12-15 18:24:40 -05:00
"""test basic lexing of lists"""
2012-12-15 18:20:15 -05:00
fn = tokenize("(fn [1 2 3 4])")[0]
assert fn == [
"fn", ["1", "2", "3", "4"]
]
2012-12-15 18:24:06 -05:00
def test_list_recurse():
2012-12-15 18:24:40 -05:00
""" test we can recurse lists """
2012-12-15 18:24:06 -05:00
fn = tokenize("(fn [1 2 3 4 [5 6 7]])")[0]
assert fn == [
"fn", ["1", "2", "3", "4", ["5", "6", "7"]]
]
def test_double_rainbow():
2012-12-15 18:24:40 -05:00
""" DOUBLE LISTS """
2012-12-15 18:24:06 -05:00
fn = tokenize("(fn [1 2 3 4] [5 6 7])")[0]
assert fn == [
"fn", ["1", "2", "3", "4"], ["5", "6", "7"]
]
2012-12-15 18:38:34 -05:00
def test_string_in_list():
""" String in list """
fn = tokenize('(fn [1 2 "three four" 5])')[0]
assert fn == [
"fn", ["1", "2", "three four", "5"]
]
def test_list_recurse_with_comment():
""" test we can recurse lists """
fn = tokenize("""
(fn [1 ; this is a test
2 3 4 [5 6 7]])
""")[0]
assert fn == [
"fn", ["1", "2", "3", "4", ["5", "6", "7"]]
]