openai/openai-python

Public

mirrored from https://github.com/openai/openai-pythonAvailable

CodeCommitsIssuesPull requestsActionsInsightsSecurity
next

Branches

Tags

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

Clone

HTTPS

Download ZIP

tests/api_resources/responses/test_input_tokens.py

144lines · 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 "context": "auto",
37 "effort": "none",
38 "generate_summary": "auto",
39 "summary": "auto",
40 },
41 text={
42 "format": {"type": "text"},
43 "verbosity": "low",
44 },
45 tool_choice="none",
46 tools=[
47 {
48 "name": "name",
49 "parameters": {"foo": "bar"},
50 "strict": True,
51 "type": "function",
52 "defer_loading": True,
53 "description": "description",
54 }
55 ],
56 truncation="auto",
57 )
58 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
59
60 @parametrize
61 def test_raw_response_count(self, client: OpenAI) -> None:
62 response = client.responses.input_tokens.with_raw_response.count()
63
64 assert response.is_closed is True
65 assert response.http_request.headers.get("X-Stainless-Lang") == "python"
66 input_token = response.parse()
67 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
68
69 @parametrize
70 def test_streaming_response_count(self, client: OpenAI) -> None:
71 with client.responses.input_tokens.with_streaming_response.count() as response:
72 assert not response.is_closed
73 assert response.http_request.headers.get("X-Stainless-Lang") == "python"
74
75 input_token = response.parse()
76 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
77
78 assert cast(Any, response.is_closed) is True
79
80
81class TestAsyncInputTokens:
82 parametrize = pytest.mark.parametrize(
83 "async_client", [False, True, {"http_client": "aiohttp"}], indirect=True, ids=["loose", "strict", "aiohttp"]
84 )
85
86 @parametrize
87 async def test_method_count(self, async_client: AsyncOpenAI) -> None:
88 input_token = await async_client.responses.input_tokens.count()
89 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
90
91 @parametrize
92 async def test_method_count_with_all_params(self, async_client: AsyncOpenAI) -> None:
93 input_token = await async_client.responses.input_tokens.count(
94 conversation="string",
95 input="string",
96 instructions="instructions",
97 model="model",
98 parallel_tool_calls=True,
99 personality="friendly",
100 previous_response_id="resp_123",
101 reasoning={
102 "context": "auto",
103 "effort": "none",
104 "generate_summary": "auto",
105 "summary": "auto",
106 },
107 text={
108 "format": {"type": "text"},
109 "verbosity": "low",
110 },
111 tool_choice="none",
112 tools=[
113 {
114 "name": "name",
115 "parameters": {"foo": "bar"},
116 "strict": True,
117 "type": "function",
118 "defer_loading": True,
119 "description": "description",
120 }
121 ],
122 truncation="auto",
123 )
124 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
125
126 @parametrize
127 async def test_raw_response_count(self, async_client: AsyncOpenAI) -> None:
128 response = await async_client.responses.input_tokens.with_raw_response.count()
129
130 assert response.is_closed is True
131 assert response.http_request.headers.get("X-Stainless-Lang") == "python"
132 input_token = response.parse()
133 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
134
135 @parametrize
136 async def test_streaming_response_count(self, async_client: AsyncOpenAI) -> None:
137 async with async_client.responses.input_tokens.with_streaming_response.count() as response:
138 assert not response.is_closed
139 assert response.http_request.headers.get("X-Stainless-Lang") == "python"
140
141 input_token = await response.parse()
142 assert_matches_type(InputTokenCountResponse, input_token, path=["response"])
143
144 assert cast(Any, response.is_closed) is True
145