Diagnostics

Node + tsx bị sập

Sự cố sập Node + tsx "__name is not a function"

Tóm tắt

Chạy OpenClaw qua Node với tsx bị lỗi khi khởi động với:

[openclaw] Failed to start CLI: TypeError: __name is not a function
    at createSubsystemLogger (.../src/logging/subsystem.ts:203:25)
    at .../src/agents/auth-profiles/constants.ts:25:20

Sự cố này bắt đầu sau khi chuyển các script phát triển từ Bun sang tsx (commit 2871657e, 2026-01-06). Cùng đường dẫn runtime này từng hoạt động với Bun.

Môi trường

  • Node: v25.x (quan sát được trên v25.3.0)
  • tsx: 4.21.0
  • Hệ điều hành: macOS (khả năng cao cũng tái hiện được trên các nền tảng khác chạy Node 25)

Tái hiện lỗi (chỉ dùng Node)

# in repo root
node --version
pnpm install
node --import tsx src/entry.ts status

Tái hiện lỗi tối thiểu trong kho mã

node --import tsx scripts/repro/tsx-name-repro.ts

Kiểm tra phiên bản Node

  • Node 25.3.0: lỗi
  • Node 22.22.0 (Homebrew node@22): lỗi
  • Node 24: chưa được cài đặt ở đây; cần xác minh

Ghi chú / giả thuyết

  • tsx dùng esbuild để biến đổi TS/ESM. keepNames của esbuild phát ra helper __name và bọc các định nghĩa hàm bằng __name(...).
  • Sự cố sập cho thấy __name tồn tại nhưng không phải là hàm tại runtime, ngụ ý rằng helper bị thiếu hoặc bị ghi đè cho module này trong đường dẫn loader của Node 25.
  • Các vấn đề tương tự liên quan đến helper __name đã được báo cáo trong những trình tiêu thụ esbuild khác khi helper bị thiếu hoặc bị viết lại.

Lịch sử hồi quy

  • 2871657e (2026-01-06): các script đã đổi từ Bun sang tsx để biến Bun thành tùy chọn.
  • Trước đó (đường dẫn Bun), openclaw statusgateway:watch hoạt động.

Cách khắc phục tạm thời

  • Dùng Bun cho các script phát triển (hoàn nguyên tạm thời hiện tại).

  • Dùng tsgo để kiểm tra kiểu của kho mã, rồi chạy đầu ra đã build:

    pnpm tsgo
    node openclaw.mjs status
    
  • Ghi chú lịch sử: tsc từng được dùng ở đây trong lúc gỡ lỗi vấn đề Node/tsx này, nhưng các lane kiểm tra kiểu của kho mã hiện dùng tsgo.

  • Tắt keepNames của esbuild trong TS loader nếu có thể (ngăn chèn helper __name); tsx hiện chưa cung cấp tùy chọn này.

  • Kiểm thử Node LTS (22/24) với tsx để xem vấn đề có đặc thù với Node 25 hay không.

Tham khảo

Các bước tiếp theo

  • Tái hiện trên Node 22/24 để xác nhận hồi quy của Node 25.
  • Kiểm thử tsx nightly hoặc ghim về phiên bản cũ hơn nếu có hồi quy đã biết.
  • Nếu tái hiện trên Node LTS, gửi một tái hiện lỗi tối thiểu lên upstream kèm stack trace __name.

Liên quan