<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Admin Test</title>
    <description>The latest articles on DEV Community by Admin Test (@admin_spoctest_e7b4c923a).</description>
    <link>https://dev.to/admin_spoctest_e7b4c923a</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.us-east-2.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F4009081%2Fea6d411a-73b5-47ba-990e-523963afd165.png</url>
      <title>DEV Community: Admin Test</title>
      <link>https://dev.to/admin_spoctest_e7b4c923a</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/admin_spoctest_e7b4c923a"/>
    <language>en</language>
    <item>
      <title>How I Fixed OpenAI Assistants API Timeout Errors in Production</title>
      <dc:creator>Admin Test</dc:creator>
      <pubDate>Tue, 30 Jun 2026 06:55:08 +0000</pubDate>
      <link>https://dev.to/admin_spoctest_e7b4c923a/how-i-fixed-openai-assistants-api-timeout-errors-in-production-4dpi</link>
      <guid>https://dev.to/admin_spoctest_e7b4c923a/how-i-fixed-openai-assistants-api-timeout-errors-in-production-4dpi</guid>
      <description>&lt;p&gt;It was during a live client demo.&lt;/p&gt;

&lt;p&gt;The AI was mid-session. The user was answering questions. &lt;br&gt;
Everything was going perfectly.&lt;/p&gt;

&lt;p&gt;Then — this:&lt;/p&gt;

&lt;p&gt;"Sorry, there was an error processing your request. Please try again."&lt;/p&gt;

&lt;p&gt;The client looked at us. My manager looked at me. I looked at my laptop &lt;br&gt;
and wanted to disappear.&lt;/p&gt;


&lt;h2&gt;
  
  
  The Investigation
&lt;/h2&gt;

&lt;p&gt;First thing I checked: OpenAI dashboard. No failed runs. Nothing.&lt;/p&gt;

&lt;p&gt;I checked our server logs. There it was:&lt;/p&gt;

&lt;p&gt;&lt;code&gt;run_timeout&lt;/code&gt; — after exactly 60 seconds&lt;/p&gt;

&lt;p&gt;But here's the thing — the run wasn't failing. It was just slow. &lt;br&gt;
OpenAI was still processing. Our backend gave up at 60s. &lt;br&gt;
OpenAI finished at 87s.&lt;/p&gt;

&lt;p&gt;We quit too early.&lt;/p&gt;


&lt;h2&gt;
  
  
  Why Does This Happen?
&lt;/h2&gt;

&lt;p&gt;The longer a session gets, the more history OpenAI has to process. &lt;br&gt;
Early in a session: 3–5 seconds.&lt;br&gt;
Mid-session (10+ messages): 30–50 seconds.&lt;br&gt;
Long sessions: 60–90+ seconds.&lt;/p&gt;

&lt;p&gt;Our hardcoded limit of 60 seconds wasn't matching reality.&lt;/p&gt;


&lt;h2&gt;
  
  
  The Fix
&lt;/h2&gt;

&lt;p&gt;Step 1: Made the timeout configurable via environment variable.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;  # .env
  OPENAI_RUN_TIMEOUT_MS=150000
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Step 2: Updated the polling loop to use it.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;TIMEOUT_MS&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;parseInt&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;process&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;env&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;OPENAI_RUN_TIMEOUT_MS&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;||&lt;/span&gt; &lt;span class="mi"&gt;150000&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;TERMINAL&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;completed&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;failed&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;cancelled&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;expired&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;requires_action&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;];&lt;/span&gt;

  &lt;span class="k"&gt;while &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="o"&gt;!&lt;/span&gt;&lt;span class="nx"&gt;TERMINAL&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;includes&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;runStatus&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;status&lt;/span&gt;&lt;span class="p"&gt;))&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;if &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nb"&gt;Date&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;now&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt; &lt;span class="nx"&gt;startTime&lt;/span&gt; &lt;span class="o"&gt;&amp;gt;=&lt;/span&gt; &lt;span class="nx"&gt;TIMEOUT_MS&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="k"&gt;throw&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Error&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;run_timeout&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
    &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Promise&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;r&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="nf"&gt;setTimeout&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;r&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;1000&lt;/span&gt;&lt;span class="p"&gt;));&lt;/span&gt;
    &lt;span class="nx"&gt;runStatus&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="nx"&gt;openai&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;beta&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;threads&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;runs&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;retrieve&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;threadId&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;run&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;id&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Step 3: Deployed. No more errors.&lt;/p&gt;




&lt;h2&gt;
  
  
  Lessons Learned
&lt;/h2&gt;

&lt;ol&gt;
&lt;li&gt;Always handle ALL 5 terminal states — not just "completed"&lt;/li&gt;
&lt;li&gt;Never hardcode timeouts for AI workloads — they vary by session length&lt;/li&gt;
&lt;li&gt;Your error logs and OpenAI dashboard together tell the full story&lt;/li&gt;
&lt;/ol&gt;




&lt;h2&gt;
  
  
  What's Next
&lt;/h2&gt;

&lt;p&gt;I'm exploring &lt;code&gt;runs.stream()&lt;/code&gt; — streaming responses in real time, &lt;br&gt;
no polling, no timeouts. Will write a follow-up once it's in production.&lt;/p&gt;




&lt;p&gt;Have you hit this before? How did you handle it?&lt;br&gt;
Drop it in the comments.&lt;/p&gt;

</description>
      <category>openai</category>
      <category>node</category>
      <category>javascript</category>
      <category>api</category>
    </item>
  </channel>
</rss>
