conftest.py 4.36 KB
Newer Older
1
# SPDX-License-Identifier: Apache-2.0
2
# SPDX-FileCopyrightText: Copyright contributors to the vLLM project
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

import pytest


@pytest.fixture
def sample_prompts():
    return [
        "Hello, my name is",
        "The president of the United States is",
        "The capital of France is",
        "The future of AI is",
    ]


@pytest.fixture
def sample_token_ids():
    return [
        [0],
        [0, 1],
        [0, 2, 1],
        [0, 3, 1, 2],
    ]


@pytest.fixture
def sample_regex():
29
30
31
32
    return (
        r"((25[0-5]|(2[0-4]|1\d|[1-9]|)\d)\.){3}"
        r"(25[0-5]|(2[0-4]|1\d|[1-9]|)\d)"
    )
33
34


35
# Note: Ensure this only uses attributes compatible with xgrammar
36
37
38
39
40
@pytest.fixture
def sample_json_schema():
    return {
        "type": "object",
        "properties": {
41
42
            "name": {"type": "string"},
            "age": {"type": "integer"},
43
44
45
46
            "skills": {
                "type": "array",
                "items": {
                    "type": "string",
47
                },
48
            },
49
50
            "grade": {
                "type": "string",
51
                "pattern": "^[A-D]$",  # Regex pattern
52
53
54
            },
            "email": {
                "type": "string",
55
                "pattern": "^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$",
56
            },
57
58
59
60
61
            "work_history": {
                "type": "array",
                "items": {
                    "type": "object",
                    "properties": {
62
                        "company": {"type": "string"},
63
                        "duration": {
64
65
66
                            "type": "number",
                            "minimum": 0.0,
                            "maximum": 100.0,  # Numeric range
67
                        },
68
                        "position": {"type": "string"},
69
                    },
70
                    "required": ["company", "duration", "position"],
71
                    "additionalProperties": False,
72
73
                },
                "minItems": 0,
74
75
                "maxItems": 3,
            },
76
        },
77
78
        "required": ["name", "age", "skills", "grade", "email", "work_history"],
        "additionalProperties": False,
79
80
        "minProperties": 1,
        "maxProperties": 10,
81
82
83
    }


84
# A schema unsupported by xgrammar
85
@pytest.fixture
86
def unsupported_json_schema():
87
88
89
90
91
    return {
        "type": "object",
        "properties": {
            "score": {
                "type": "integer",
92
                "multipleOf": 5,  # Numeric multiple
93
94
95
            },
            "tags": {
                "type": "array",
96
97
                "items": {"type": "string", "minLength": 10, "maxLength": 20},
            },
98
        },
99
        "required": ["score", "tags"],
100
        "additionalProperties": False,
101
102
103
        "patternProperties": {
            "^score$": {"type": "integer"},
        },
104
105
106
107
108
109
    }


@pytest.fixture
def sample_definition_json_schema():
    return {
110
111
112
113
114
        "$defs": {
            "Step": {
                "properties": {
                    "explanation": {"title": "Explanation", "type": "string"},
                    "output": {"title": "Output", "type": "string"},
115
                },
116
117
118
                "required": ["explanation", "output"],
                "title": "Step",
                "type": "object",
119
120
            }
        },
121
122
123
124
125
        "properties": {
            "steps": {
                "items": {"$ref": "#/$defs/Step"},
                "title": "Steps",
                "type": "array",
126
            },
127
            "final_answer": {"title": "Final Answer", "type": "string"},
128
        },
129
130
131
132
        "required": ["steps", "final_answer"],
        "title": "MathReasoning",
        "type": "object",
        "additionalProperties": False,
133
134
135
136
    }


@pytest.fixture
137
def sample_structured_outputs_choices():
138
    return [
139
140
141
142
143
144
145
146
147
148
        "Python",
        "Java",
        "JavaScript",
        "C++",
        "C#",
        "PHP",
        "TypeScript",
        "Ruby",
        "Swift",
        "Kotlin",
149
150
151
152
    ]


@pytest.fixture
153
154
155
156
157
158
159
160
161
162
163
164
165
def sample_sql_ebnf():
    return """
root ::= select_statement
select_statement ::= "SELECT" column "from" table "where" condition
column ::= "col_1" | "col_2"
table ::= "table_1" | "table_2"
condition ::= column "=" number
number ::= "1" | "2"
"""


@pytest.fixture
def sample_sql_lark():
166
    return """
167
168
169
170
171
172
start: select_statement
select_statement: "SELECT" column "from" table "where" condition
column: "col_1" | "col_2"
table: "table_1" | "table_2"
condition: column "=" number
number: "1" | "2"
173
"""