openai/openai-python

Public

mirrored fromhttps://github.com/openai/openai-pythonAvailable

CodeCommitsIssuesPull requestsActionsInsightsSecurity
codex/gate-pypi-publish

Branches

Tags

  • No tags available.
0Branches0Tags
Go to file
Add file
Code

Clone

HTTPS

Download ZIP

tests/api_resources/responses/test_input_tokens.py

142lines · modecode

1# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
3from __future__ import annotations
4
5import os
6from typing import Any, cast
7
8import pytest
9
10from openai import OpenAI, AsyncOpenAI
11from tests.utils import assert_matches_type
12from openai.types.responses import InputTokenCountResponse
13
14base_url = os.environ.get("TEST_API_BASE_URL", "http://127.0.0.1:4010")
15
16
17class TestInputTokens:
18 parametrize = pytest.mark.parametrize("client", [False, True], indirect=True, ids=["loose", "strict"])
19
20 @parametrize
21 def test_method_count(self, client: OpenAI) -> None:
22 input_token = client.responses.input_tokens.count()
23 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
24
25 @parametrize
26 def test_method_count_with_all_params(self, client: OpenAI) -> None:
27 input_token = client.responses.input_tokens.count(
28 conversation="string",
29 input="string",
30 instructions="instructions",
31 model="model",
32 parallel_tool_calls=True,
33 personality="friendly",
34 previous_response_id="resp_123",
35 reasoning={
36 "effort": "none",
37 "generate_summary": "auto",
38 "summary": "auto",
39 },
40 text={
41 "format": {"type": "text"},
42 "verbosity": "low",
43 },
44 tool_choice="none",
45 tools=[
46 {
47 "name": "name",
48 "parameters": {"foo": "bar"},
49 "strict": True,
50 "type": "function",
51 "defer_loading": True,
52 "description": "description",
53 }
54 ],
55 truncation="auto",
56 )
57 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
58
59 @parametrize
60 def test_raw_response_count(self, client: OpenAI) -> None:
61 response = client.responses.input_tokens.with_raw_response.count()
62
63 assert response.is_closed is True
64 assert response.http_request.headers.get("X-Stainless-Lang") == "python"
65 input_token = response.parse()
66 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
67
68 @parametrize
69 def test_streaming_response_count(self, client: OpenAI) -> None:
70 with client.responses.input_tokens.with_streaming_response.count() as response:
71 assert not response.is_closed
72 assert response.http_request.headers.get("X-Stainless-Lang") == "python"
73
74 input_token = response.parse()
75 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
76
77 assert cast(Any, response.is_closed) is True
78
79
80class TestAsyncInputTokens:
81 parametrize = pytest.mark.parametrize(
82 "async_client", [False, True, {"http_client": "aiohttp"}], indirect=True, ids=["loose", "strict", "aiohttp"]
83 )
84
85 @parametrize
86 async def test_method_count(self, async_client: AsyncOpenAI) -> None:
87 input_token = await async_client.responses.input_tokens.count()
88 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
89
90 @parametrize
91 async def test_method_count_with_all_params(self, async_client: AsyncOpenAI) -> None:
92 input_token = await async_client.responses.input_tokens.count(
93 conversation="string",
94 input="string",
95 instructions="instructions",
96 model="model",
97 parallel_tool_calls=True,
98 personality="friendly",
99 previous_response_id="resp_123",
100 reasoning={
101 "effort": "none",
102 "generate_summary": "auto",
103 "summary": "auto",
104 },
105 text={
106 "format": {"type": "text"},
107 "verbosity": "low",
108 },
109 tool_choice="none",
110 tools=[
111 {
112 "name": "name",
113 "parameters": {"foo": "bar"},
114 "strict": True,
115 "type": "function",
116 "defer_loading": True,
117 "description": "description",
118 }
119 ],
120 truncation="auto",
121 )
122 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
123
124 @parametrize
125 async def test_raw_response_count(self, async_client: AsyncOpenAI) -> None:
126 response = await async_client.responses.input_tokens.with_raw_response.count()
127
128 assert response.is_closed is True
129 assert response.http_request.headers.get("X-Stainless-Lang") == "python"
130 input_token = response.parse()
131 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
132
133 @parametrize
134 async def test_streaming_response_count(self, async_client: AsyncOpenAI) -> None:
135 async with async_client.responses.input_tokens.with_streaming_response.count() as response:
136 assert not response.is_closed
137 assert response.http_request.headers.get("X-Stainless-Lang") == "python"
138
139 input_token = await response.parse()
140 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
141
142 assert cast(Any, response.is_closed) is True
143