Chuyển đến nội dung chính

Documentation Index

Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

Luồng QA Matrix chạy Plugin @openclaw/matrix được đóng gói kèm theo trên một homeserver Tuwunel dùng một lần trong Docker, với các tài khoản tạm thời cho driver, SUT và observer cùng các phòng được tạo sẵn. Đây là phạm vi kiểm thử thật theo transport trực tiếp cho Matrix. Đây là công cụ chỉ dành cho maintainer. Các bản phát hành OpenClaw đóng gói cố ý bỏ qua qa-lab, nên openclaw qa chỉ có sẵn từ một bản checkout mã nguồn. Các bản checkout mã nguồn tải runner được đóng gói kèm theo trực tiếp — không cần bước cài đặt Plugin. Để biết ngữ cảnh rộng hơn về framework QA, xem tổng quan QA.

Bắt đầu nhanh

pnpm openclaw qa matrix --profile fast --fail-fast
pnpm openclaw qa matrix thuần chạy --profile all và không dừng ở lỗi đầu tiên. Dùng --profile fast --fail-fast cho gate phát hành; chia nhỏ danh mục bằng --profile transport|media|e2ee-smoke|e2ee-deep|e2ee-cli khi chạy toàn bộ inventory song song.

Luồng này làm gì

  1. Cấp phát một homeserver Tuwunel dùng một lần trong Docker (image mặc định ghcr.io/matrix-construct/tuwunel:v1.5.1, tên máy chủ matrix-qa.test, cổng 28008).
  2. Đăng ký ba người dùng tạm thời — driver (gửi lưu lượng inbound), sut (tài khoản Matrix OpenClaw đang được kiểm thử), observer (ghi nhận lưu lượng bên thứ ba).
  3. Tạo sẵn các phòng cần cho những kịch bản đã chọn (main, threading, media, restart, secondary, allowlist, E2EE, verification DM, v.v.).
  4. Khởi động một OpenClaw Gateway con với Plugin Matrix thật được giới hạn vào tài khoản SUT; qa-channel không được tải trong tiến trình con.
  5. Chạy tuần tự các kịch bản, quan sát sự kiện thông qua các client Matrix driver/observer.
  6. Dỡ bỏ homeserver, ghi các artifact báo cáo và tóm tắt, rồi thoát.

CLI

pnpm openclaw qa matrix [options]

Các cờ thường dùng

CờMặc địnhMô tả
--profile <profile>allHồ sơ kịch bản. Xem Hồ sơ.
--fail-fasttắtDừng sau lần kiểm tra hoặc kịch bản thất bại đầu tiên.
--scenario <id>Chỉ chạy kịch bản này. Có thể lặp lại. Xem Kịch bản.
--output-dir <path><repo>/.artifacts/qa-e2e/matrix-<timestamp>Nơi ghi báo cáo, tóm tắt, sự kiện quan sát được và nhật ký đầu ra. Đường dẫn tương đối được phân giải theo --repo-root.
--repo-root <path>process.cwd()Gốc repository khi gọi từ một thư mục làm việc trung lập.
--sut-account <id>sutID tài khoản Matrix bên trong cấu hình QA Gateway.

Cờ nhà cung cấp

Luồng này dùng transport Matrix thật nhưng nhà cung cấp mô hình có thể cấu hình được:
CờMặc địnhMô tả
--provider-mode <mode>live-frontiermock-openai cho dispatch mock xác định hoặc live-frontier cho các nhà cung cấp frontier trực tiếp. Alias cũ live-openai vẫn hoạt động.
--model <ref>mặc định nhà cung cấpRef provider/model chính.
--alt-model <ref>mặc định nhà cung cấpRef provider/model thay thế khi kịch bản chuyển giữa lúc chạy.
--fasttắtBật chế độ nhanh của nhà cung cấp khi được hỗ trợ.
Matrix QA không chấp nhận --credential-source hoặc --credential-role. Luồng này cấp phát người dùng dùng một lần cục bộ; không có pool thông tin xác thực dùng chung để thuê.

Hồ sơ

Hồ sơ được chọn quyết định những kịch bản nào sẽ chạy.
Hồ sơDùng cho
all (mặc định)Toàn bộ danh mục. Chậm nhưng bao quát.
fastTập con gate phát hành kiểm tra hợp đồng transport trực tiếp: canary, chặn theo mention, chặn allowlist, hình dạng reply, tiếp tục sau restart, follow-up thread, cô lập thread, quan sát reaction và phân phối metadata phê duyệt exec.
transportCác kịch bản ở cấp transport về threading, DM, room, autojoin, mention/allowlist, phê duyệt và reaction.
mediaPhạm vi attachment hình ảnh, âm thanh, video, PDF, EPUB.
e2ee-smokePhạm vi E2EE tối thiểu — reply được mã hóa cơ bản, follow-up thread, bootstrap thành công.
e2ee-deepCác kịch bản E2EE bao quát về mất trạng thái, backup, key và khôi phục.
e2ee-cliCác kịch bản CLI openclaw matrix encryption setupverify * được điều khiển qua QA harness.
Ánh xạ chính xác nằm trong extensions/qa-matrix/src/runners/contract/scenario-catalog.ts.

Kịch bản

Danh sách ID kịch bản đầy đủ là union MatrixQaScenarioId trong extensions/qa-matrix/src/runners/contract/scenario-catalog.ts:15. Các danh mục gồm:
  • threading — matrix-thread-*, matrix-subagent-thread-spawn
  • cấp cao nhất / DM / room — matrix-top-level-reply-shape, matrix-room-*, matrix-dm-*
  • streaming và tiến trình công cụ — matrix-room-partial-streaming-preview, matrix-room-quiet-streaming-preview, matrix-room-tool-progress-*, matrix-room-block-streaming
  • media — matrix-media-type-coverage, matrix-room-image-understanding-attachment, matrix-attachment-only-ignored, matrix-unsupported-media-safe
  • định tuyến — matrix-room-autojoin-invite, matrix-secondary-room-*
  • reactions — matrix-reaction-*
  • phê duyệt — matrix-approval-* (metadata exec/Plugin, fallback chia chunk, reaction từ chối, thread và định tuyến target: "both")
  • restart và phát lại — matrix-restart-*, matrix-stale-sync-replay-dedupe, matrix-room-membership-loss, matrix-homeserver-restart-resume, matrix-initial-catchup-then-incremental
  • chặn theo mention, bot-to-bot và allowlist — matrix-mention-*, matrix-allowbots-*, matrix-allowlist-*, matrix-multi-actor-ordering, matrix-inbound-edit-*, matrix-mxid-prefixed-command-block, matrix-observer-allowlist-override
  • E2EE — matrix-e2ee-* (reply cơ bản, follow-up thread, bootstrap, vòng đời recovery key, các biến thể mất trạng thái, hành vi backup máy chủ, vệ sinh thiết bị, xác minh SAS / QR / DM, restart, biên tập artifact)
  • CLI E2EE — matrix-e2ee-cli-* (thiết lập mã hóa, thiết lập idempotent, lỗi bootstrap, vòng đời recovery-key, nhiều tài khoản, vòng lặp gateway-reply, tự xác minh)
Truyền --scenario <id> (có thể lặp lại) để chạy một tập được chọn thủ công; kết hợp với --profile all để bỏ qua giới hạn theo hồ sơ.

Biến môi trường

BiếnMặc địnhTác dụng
OPENCLAW_QA_MATRIX_TIMEOUT_MS1800000 (30 phút)Giới hạn trên cứng cho toàn bộ lượt chạy.
OPENCLAW_QA_MATRIX_CANARY_TIMEOUT_MS45000Giới hạn cho phản hồi canary ban đầu. CI phát hành tăng giá trị này trên các runner dùng chung để một lượt Gateway đầu tiên chậm không gây lỗi trước khi phạm vi kịch bản bắt đầu.
OPENCLAW_QA_MATRIX_NO_REPLY_WINDOW_MS8000Khoảng lặng cho các xác nhận phủ định không có phản hồi. Được kẹp ở mức thời gian chờ của lượt chạy.
OPENCLAW_QA_MATRIX_CLEANUP_TIMEOUT_MS90000Giới hạn cho việc dọn dẹp Docker. Các bề mặt lỗi bao gồm lệnh khôi phục docker compose ... down --remove-orphans.
OPENCLAW_QA_MATRIX_TUWUNEL_IMAGEghcr.io/matrix-construct/tuwunel:v1.5.1Ghi đè ảnh homeserver khi xác thực với một phiên bản Tuwunel khác.
OPENCLAW_QA_MATRIX_PROGRESSbật0 tắt các dòng tiến trình [matrix-qa] ... trên stderr. 1 buộc bật chúng.
OPENCLAW_QA_MATRIX_CAPTURE_CONTENTđã che1 giữ lại nội dung thư và formatted_body trong matrix-qa-observed-events.json. Mặc định che nội dung để giữ an toàn cho artifact CI.
OPENCLAW_QA_MATRIX_DISABLE_FORCE_EXITtắt1 bỏ qua process.exit xác định sau khi ghi artifact. Mặc định buộc thoát vì các handle crypto native của matrix-js-sdk có thể giữ event loop sống sau khi artifact hoàn tất.
OPENCLAW_RUN_NODE_OUTPUT_LOGchưa đặtKhi được đặt bởi một trình khởi chạy bên ngoài (ví dụ scripts/run-node.mjs), Matrix QA dùng lại đường dẫn log đó thay vì tự khởi động tee riêng.

Artifact đầu ra

Được ghi vào --output-dir:
  • matrix-qa-report.md — báo cáo giao thức Markdown (những gì đã đạt, thất bại, bị bỏ qua và lý do).
  • matrix-qa-summary.json — tóm tắt có cấu trúc phù hợp cho việc phân tích CI và dashboard.
  • matrix-qa-observed-events.json — các sự kiện Matrix đã quan sát từ client driver và observer. Nội dung được che trừ khi OPENCLAW_QA_MATRIX_CAPTURE_CONTENT=1; metadata phê duyệt được tóm tắt bằng các trường an toàn đã chọn và bản xem trước lệnh bị cắt ngắn.
  • matrix-qa-output.log — stdout/stderr kết hợp từ lượt chạy. Nếu OPENCLAW_RUN_NODE_OUTPUT_LOG được đặt, log của trình khởi chạy bên ngoài sẽ được dùng lại thay thế.
Thư mục đầu ra mặc định là <repo>/.artifacts/qa-e2e/matrix-<timestamp> để các lượt chạy liên tiếp không ghi đè lên nhau.

Mẹo phân loại

  • Lượt chạy bị treo gần cuối: các handle crypto native của matrix-js-sdk có thể sống lâu hơn harness. Mặc định buộc process.exit sạch sau khi ghi artifact; nếu bạn đã bỏ đặt OPENCLAW_QA_MATRIX_DISABLE_FORCE_EXIT=1, hãy dự kiến tiến trình sẽ còn tồn tại một lúc.
  • Lỗi dọn dẹp: tìm lệnh khôi phục được in ra (một lệnh gọi docker compose ... down --remove-orphans) và chạy thủ công để giải phóng cổng homeserver.
  • Các khoảng thời gian xác nhận phủ định không ổn định trong CI: giảm OPENCLAW_QA_MATRIX_NO_REPLY_WINDOW_MS (mặc định 8 giây) khi CI nhanh; tăng giá trị này trên các runner dùng chung chậm.
  • Cần nội dung đã che cho báo cáo lỗi: chạy lại với OPENCLAW_QA_MATRIX_CAPTURE_CONTENT=1 và đính kèm matrix-qa-observed-events.json. Xem artifact kết quả là nhạy cảm.
  • Phiên bản Tuwunel khác: trỏ OPENCLAW_QA_MATRIX_TUWUNEL_IMAGE tới phiên bản đang được kiểm thử. Lane chỉ kiểm tra ảnh mặc định đã ghim.

Hợp đồng truyền tải trực tiếp

Matrix là một trong ba lane truyền tải trực tiếp (Matrix, Telegram, Discord) chia sẻ một danh sách kiểm tra hợp đồng duy nhất được định nghĩa trong Tổng quan QA → Phạm vi truyền tải trực tiếp. qa-channel vẫn là bộ synthetic rộng và được chủ ý không đưa vào ma trận đó.

Liên quan

  • Tổng quan QA — toàn bộ stack QA và hợp đồng truyền tải trực tiếp
  • QA Channel — adapter kênh synthetic cho các kịch bản dựa trên repo
  • Kiểm thử — chạy kiểm thử và thêm phạm vi QA
  • Matrix — Plugin kênh đang được kiểm thử