mirror of
https://github.com/openai/codex.git
synced 2026-04-28 16:45:54 +00:00
Update the repo-run examples that still hardcoded gpt-5 so they use the same gpt-5.4 path already succeeding elsewhere in this runtime. This fixes the quickstart, lifecycle, multimodal, parity, CLI, retry, and kitchen-sink examples that were failing with the runtime-side tool_search compatibility error under gpt-5. Validation: - ran all 25 sdk/python example scripts locally - no examples reported failed turns after the model update - remaining empty-item outputs are limited to 02_turn_run and 03_turn_stream_events for follow-up investigation Co-authored-by: Codex <noreply@openai.com>
45 lines
1.3 KiB
Python
45 lines
1.3 KiB
Python
import sys
|
|
from pathlib import Path
|
|
|
|
_EXAMPLES_ROOT = Path(__file__).resolve().parents[1]
|
|
if str(_EXAMPLES_ROOT) not in sys.path:
|
|
sys.path.insert(0, str(_EXAMPLES_ROOT))
|
|
|
|
from _bootstrap import ensure_local_sdk_src, runtime_config
|
|
|
|
ensure_local_sdk_src()
|
|
|
|
import asyncio
|
|
|
|
from codex_app_server import AsyncCodex, TextInput
|
|
|
|
|
|
async def main() -> None:
|
|
async with AsyncCodex(config=runtime_config()) as codex:
|
|
thread = await codex.thread_start(model="gpt-5.4", config={"model_reasoning_effort": "high"})
|
|
turn = await thread.turn(TextInput("Count from 1 to 200 with commas, then one summary sentence."))
|
|
|
|
# Best effort controls: models can finish quickly, so races are expected.
|
|
try:
|
|
_ = await turn.steer(TextInput("Keep it brief and stop after 20 numbers."))
|
|
print("steer: sent")
|
|
except Exception as exc:
|
|
print("steer: skipped", type(exc).__name__)
|
|
|
|
try:
|
|
_ = await turn.interrupt()
|
|
print("interrupt: sent")
|
|
except Exception as exc:
|
|
print("interrupt: skipped", type(exc).__name__)
|
|
|
|
event_count = 0
|
|
async for event in turn.stream():
|
|
event_count += 1
|
|
print(event.method, event.payload)
|
|
|
|
print("events.count:", event_count)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
asyncio.run(main())
|