خطر خطاهای بی‌صدا

شما از ابزارها برای انجام کارها استفاده می‌کنید. اما اگر ابزاری بدون هیچ خطایی، پاسخ اشتباهی برگرداند چه؟ این بسیار خطرناک‌تر از ابزاری است که کرش می‌کند. یک کرش، یک نشانگر است؛ اما یک خطای بی‌صدا، یک جعل است.

من یک باگ در ابزار مرورگر خود پیدا کردم. این ابزار به جای صفحه وب، عبارت "[object Promise]" را برمی‌گرداند. من به دنبال مشکلات مشابه گشتم و ۱۰ ابزار دیگر را با همین باگ پیدا کردم. مشکل یک غلط تایپی نبود، بلکه یک الگو (shape) بود. این الگو در سراسر کد (codebase) کپی شده بود.

این باگ به این دلیل رخ داد که دستور do JavaScript در AppleScript همگام (synchronous) است. این دستور بدون منتظر ماندن برای اتمام کارهای ناهمگام (async)، بلافاصله پاسخ را برمی‌گرداند. این یعنی اگر یک تابع async را به do JavaScript پاس دهید، به جای نتیجه‌ی تابع، یک شیء Promise برمی‌گرداند.

برای رفع این مشکل، حلقه async را به سمت Node منتقل کردم. من از یک تابع کمکی برای بررسی مداوم (poll) وضعیت صفحه استفاده می‌کنم تا زمانی که وضعیت آن تثبیت شود، و سپس نتیجه را می‌خوانم. به این ترتیب، دستور await در سمت Node قرار می‌گیرد و فراخوانی به صفحه، یک عبارت همگام (synchronous) واحد است.

درس این است که حلقه async را در سمتی نگه دارید که می‌تواند await کند، و به جای اینکه از طریق مرز (boundary) منتظر بمانید (await)، وضعیت قابل مشاهده را در آن سمت بررسی (poll) کنید. از پل (bridge) نخواهید که منتظر بماند. بلکه مکرراً از آن بپرسید: «آیا تمام شد؟» و خودتان منتظر بمانید.

اگر در حال ساخت ابزارهای عامل (agent tooling) هستید، مراقب خطاهای بی‌صدا باشید. کد خود را برای پیدا کردن ابزارهایی که "[object Promise]" برمی‌گردانند یا بر اساس وضعیت قدیمی (stale state) عمل می‌کنند، جستجو (grep) کنید. اگر یکی از آن‌ها را پیدا کردید، فقط آن را اصلاح نکنید؛ بلکه موارد مشابه را هم پیدا کنید و آن الگویی را که کپی شده بود، اصلاح کنید.

منبع: https://dev.to/achiya-automation/my-browser-tool-returned-object-promise-as-a-webpage-one-grep-later-10-more-tools-had-the-37p8