File: grammar_ref_test.py

package info (click to toggle)
sqlfluff 3.5.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 34,000 kB
  • sloc: python: 106,131; sql: 34,188; makefile: 52; sh: 8
file content (79 lines) | stat: -rw-r--r-- 2,728 bytes parent folder | download | duplicates (2)
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
"""Test the Ref grammar.

NOTE: All of these tests depend somewhat on the KeywordSegment working as planned.
"""

import pytest

from sqlfluff.core.dialects import Dialect
from sqlfluff.core.parser.context import ParseContext
from sqlfluff.core.parser.grammar import Ref
from sqlfluff.core.parser.lexer import RegexLexer
from sqlfluff.core.parser.match_result import MatchResult
from sqlfluff.core.parser.parsers import StringParser
from sqlfluff.core.parser.segments import CodeSegment, WhitespaceSegment


@pytest.fixture(scope="function")
def test_dialect():
    """A stripped back test dialect for testing."""
    test_dialect = Dialect("test", root_segment_name="FileSegment")
    test_dialect.set_lexer_matchers(
        [
            RegexLexer("whitespace", r"[^\S\r\n]+", WhitespaceSegment),
            RegexLexer(
                "code", r"[0-9a-zA-Z_]+", CodeSegment, segment_kwargs={"type": "code"}
            ),
        ]
    )
    test_dialect.add(FooSegment=StringParser("foo", CodeSegment, type="foo"))
    # Return the expanded copy.
    return test_dialect.expand()


def test__parser__grammar__ref_eq():
    """Test equality of Ref Grammars."""
    r1 = Ref("foo")
    r2 = Ref("foo")
    assert r1 is not r2
    assert r1 == r2
    check_list = [1, 2, r2, 3]
    # Check we can find it in lists
    assert r1 in check_list
    # Check we can get it's position
    assert check_list.index(r1) == 2
    # Check we can remove it from a list
    check_list.remove(r1)
    assert r1 not in check_list


def test__parser__grammar__ref_repr():
    """Test the __repr__ method of Ref."""
    assert repr(Ref("foo")) == "<Ref: 'foo'>"
    assert repr(Ref("bar", optional=True)) == "<Ref: 'bar' [opt]>"


def test__parser__grammar_ref_match(generate_test_segments, test_dialect):
    """Test the Ref grammar match method."""
    foo_ref = Ref("FooSegment")
    test_segments = generate_test_segments(["bar", "foo", "bar"])
    ctx = ParseContext(dialect=test_dialect)

    match = foo_ref.match(test_segments, 1, ctx)

    assert match == MatchResult(
        matched_slice=slice(1, 2),
        matched_class=CodeSegment,
        segment_kwargs={"instance_types": ("foo",)},
    )


def test__parser__grammar_ref_exclude(generate_test_segments, fresh_ansi_dialect):
    """Test the Ref grammar exclude option with the match method."""
    identifier = Ref("NakedIdentifierSegment", exclude=Ref.keyword("ABS"))
    test_segments = generate_test_segments(["ABS", "ABSOLUTE"])
    ctx = ParseContext(dialect=fresh_ansi_dialect)
    # Assert ABS does not match, due to the exclude
    assert not identifier.match(test_segments, 0, ctx)
    # Assert ABSOLUTE does match
    assert identifier.match(test_segments, 1, ctx)