当前位置: 首页 > article >正文

claw-code 源码分析:大型移植的测试哲学——如何用 unittest 门禁守住「诚实未完成」的口碑?

涉及源码tests/test_porting_workspace.py、src/setup.py、src/parity_audit.py、src/main.py、src/hooks/__init__.py、src/execution_registry.py对照 Rustrust/crates/compat-harness中「无夹具则早退」的测试写法。1. 门禁长什么样单一 discover 入口移植工作区的官方测试命令写死在WorkspaceSetup里与setup-report的「启动步骤」叙事一致# 12:26:src/setup.pydataclass(frozenTrue)classWorkspaceSetup:python_version:strimplementation:strplatform_name:strtest_command:strpython3 -m unittest discover -s tests -vdefstartup_steps(self)-tuple[str,...]:return(start top-level prefetch side effects,build workspace context,load mirrored command snapshot,load mirrored tool snapshot,prepare parity audit hooks,apply trust-gated deferred init,)tests/下目前只有test_porting_workspace.pyunittest discover会整包执行。哲学上门禁窄而可重复——不依赖 pytest 插件矩阵只用标准库降低「测框架比产品还重」的风险。2. 诚实未完成的核心archive_present条件门禁2.1 Parity有档案才严没档案不装完成run_parity_audit()用ARCHIVE_ROOT.exists()判定是否存在本地 TS 快照目录to_markdown()在缺失时明确声明无法对比# 84:88:src/parity_audit.pydefto_markdown(self)-str:lines[# Parity Audit]ifnotself.archive_present:lines.append(Local archive unavailable; parity audit cannot compare against the original snapshot.)return\n.join(lines)CLI 帮助文案同样写「在可用时」才对比避免暗示「clone 即全量 parity」subparsers.add_parser(parity-audit, helpcompare the Python workspace against the local ignored TypeScript archive when available)单测不把「必须有 archive」当作默认前提而是# 45:51:tests/test_porting_workspace.pydeftest_root_file_coverage_is_complete_when_local_archive_exists(self)-None:auditrun_parity_audit()ifaudit.archive_present:self.assertEqual(audit.root_file_coverage[0],audit.root_file_coverage[1])self.assertGreaterEqual(audit.directory_coverage[0],28)self.assertGreaterEqual(audit.command_entry_ratio[0],150)self.assertGreaterEqual(audit.tool_entry_ratio[0],100)语义无 archive该用例静默通过不伪造 green。有 archive根文件映射必须满覆盖目录/命令/工具条目数不低于约定阈值。这就是「诚实未完成」的 unittest 表达缺少上游对照物时不宣称 parity 已证明有时则收紧到可量化指标。2.2 与「永远 green」的虚假胜利划界若改成「无 archive 也 assert 比例」会把 CI 变成谎言若「有 archive 也不测」则档案形同虚设。当前写法是二态门禁环境具备对照条件时才验收结构覆盖率而不是验收业务等价后者在单测里基本未做。3. 黑盒子进程测「可运行 可观测契约」不测 TS 行为克隆PortingWorkspaceTests大量subprocess.run(..., checkTrue)调python -m src.main subcommand断言退出码 0与 stdout子串标题、关键词、模式串。效果诚实通过表示「CLI 面在当前仓库数据下能跑通」不表示「与原版 Ink/React 一致」。稳定子串契约比像素级 diff 快照更耐重构。覆盖面summary、parity-audit、route、bootstrap、exec、turn-loop、remote/ssh/teleport 模式、command-graph、tool-pool 等移植工作流被串成回归网。示例bootstrap 与 load-session 链# 104:174:tests/test_porting_workspace.pydeftest_bootstrap_cli_runs(self)-None:resultsubprocess.run([sys.executable,-m,src.main,bootstrap,review MCP tool,--limit,5],checkTrue,capture_outputTrue,textTrue,)self.assertIn(Runtime Session,result.stdout)...deftest_load_session_cli_runs(self)-None:fromsrc.runtimeimportPortRuntime sessionPortRuntime().bootstrap_session(review MCP tool,limit5)session_idPath(session.persisted_session_path).stem resultsubprocess.run([sys.executable,-m,src.main,load-session,session_id],checkTrue,capture_outputTrue,textTrue,)self.assertIn(session_id,result.stdout)self.assertIn(messages,result.stdout)口碑含义对外可以说「门禁保证port 脚手架与镜像数据自洽」而不是「已完整复刻产品」。4. 词汇诚实Mirrored、占位包与快照边界4.1 执行层命名ExecutionRegistry使用MirroredCommand/MirroredTool测试断言输出含「Mirrored command」/「Mirrored tool」# 9:24:src/execution_registry.pydataclass(frozenTrue)classMirroredCommand:name:strsource_hint:strdefexecute(self,prompt:str)-str:returnexecute_command(self.name,prompt).message# 123:137:tests/test_porting_workspace.pydeftest_exec_command_and_tool_cli_run(self)-None:...self.assertIn(Mirrored command review,command_result.stdout)self.assertIn(Mirrored tool MCPTool,tool_result.stdout)测试在巩固一种用户可见语义这是镜像/演示执行不是隐式冒充生产行为。4.2 子系统占位hooks包显式为placeholder元数据来自reference_dataJSON并导出PORTING_NOTEPython package placeholder for the archived hooks subsystem. ... PORTING_NOTE fPython placeholder package for {ARCHIVE_NAME} with {MODULE_COUNT} archived module references.单测通过MODULE_COUNT、SAMPLE_FILES等0断言验证「占位与快照挂钩」而非「hooks 已移植」。4.3 快照与清单测「规模与结构」不测语义test_command_and_tool_snapshots_are_nontrivialPORTED_COMMANDS/PORTED_TOOLS数量下限。test_manifest_counts_python_filestotal_python_files 20等粗阈值。test_execution_registry_runsregistry 规模 执行结果字符串包含镜像关键词。这些与reference_data/*.json、archive_surface_snapshot.json共同构成「表面对齐」的可测定义unittest 不把 undefined 的「行为 parity」塞进断言。5. 内联 API 测薄层不变量少量直接调用 Python APIQueryEnginePort.render_summary()、PortRuntime.bootstrap_session()检查结构字段如Prompt:、usage有消耗与 CLI 黑盒互补# 21:25:tests/test_porting_workspace.pydeftest_query_engine_summary_mentions_workspace(self)-None:summaryQueryEnginePort.from_workspace().render_summary()self.assertIn(Python Porting Workspace Summary,summary)self.assertIn(Command surface:,summary)self.assertIn(Tool surface:,summary)哲学内联测适合纯函数/聚合报告有副作用与 argv 的走子进程边界清晰。6. 与 Rust 侧的呼应可选对照compat-harness集成测试在缺少上游 fixture时直接 return与 Python「无 archive 不收紧」同构// 311:316:rust/crates/compat-harness/src/lib.rs#[test]fnextracts_non_empty_manifests_from_upstream_repo(){letpathsfixture_paths();if!has_upstream_fixture(paths){return;}说明「诚实未完成」在整个 monorepo 里是一种可复制的测试习惯缺输入就不宣称成功证明而不是skip刷屏或假失败。7. 小结unittest 如何守住口碑手法守住的承诺明确不承诺的if audit.archive_present条件断言「有快照时根文件映射与规模指标达标」「无快照也完成 TS 对齐」Parity 文案 CLI help「when available」对照物缺失时显式降级静默满分子进程 checkTrue 子串工作流与数据自洽、可演示与上游运行时行为逐行一致Mirrored*与占位包测试用户可见输出不自称为原版hooks/子系统已完整实现快照数量阈值表面命令/工具条目不萎缩每个条目语义已验证discover 标准库低依赖门禁易在任意环境复跑复杂属性测试/模糊测试一句话这套 unittest 把「我们保证什么」写成可执行契约能跑、有镜像词、有档案时结构对齐把「我们还没保证什么」留在条件分支与文档字符串里——这就是大型移植里诚实未完成的口碑工程化。

相关文章:

claw-code 源码分析:大型移植的测试哲学——如何用 unittest 门禁守住「诚实未完成」的口碑?

涉及源码:tests/test_porting_workspace.py、src/setup.py、src/parity_audit.py、src/main.py、src/hooks/__init__.py、src/execution_registry.py;对照 Rust rust/crates/compat-harness 中「无夹具则早退」的测试写法。1. 门禁长什么样:单…...

内容访问工具高效解决方案:开源Bypass Paywalls Clean实用指南

内容访问工具高效解决方案:开源Bypass Paywalls Clean实用指南 在信息获取日益受限的数字时代,专业内容常被付费墙阻隔,影响研究效率与知识获取。本文将系统介绍一款开源内容访问工具的技术原理与实践方法,帮助用户在合规前提下优…...

制造业设计团队文档管理选型实战

制造业设计团队文档管理选型实战 某中型机械制造企业,研发团队47人,日常需要管理CAD图纸、BOM表、工艺文件、技术规范等超过120万份文件。过去三年,这支团队换了两次文档管理系统,第二套系统上线8个月后被迫重建——原因是设计部门…...

万字拆解 LLM 运行机制:Token、上下文与采样参数影

springboot自动配置 自动配置了大量组件,配置信息可以在application.properties文件中修改。 当添加了特定的Starter POM后,springboot会根据类路径上的jar包来自动配置bean(比如:springboot发现类路径上的MyBatis相关类&#xff…...

ESPS USB MSC 调试全过程记录岸

背景 在软件开发的漫长旅途中,"构建"这个词往往让人又爱又恨。爱的是,一键点击,代码变成产品,那是程序员最迷人的时刻;恨的是,维护那一堆乱糟糟的构建脚本,简直是噩梦。 在很多项目中…...

FireRedASR Pro学习笔记整理实战:录音转文字,复习效率翻倍

FireRedASR Pro学习笔记整理实战:录音转文字,复习效率翻倍 1. 为什么你需要这个语音转文字工具 作为一名经常需要听课、参加会议的学习者和职场人士,我一直在寻找能够提升笔记效率的工具。直到遇到FireRedASR Pro,这个基于工业级…...

GLM-. 全面支持与 Gemini CLI 集成:HagiCode 的多模型进化之路腾

1. 流图:数据的河流 如果把传统的堆叠面积图想象成一块块整齐堆叠的积木,那么流图就像一条蜿蜒流淌的河流,河道的宽窄变化自然流畅,波峰波谷过渡平滑。 它特别适合展示多个类别数据随时间的变化趋势,尤其是当你想强调整…...

显微图像拼接的三大困境与MIST的突破性解决方案

显微图像拼接的三大困境与MIST的突破性解决方案 【免费下载链接】MIST Microscopy Image Stitching Tool 项目地址: https://gitcode.com/gh_mirrors/mist3/MIST 你是否曾经面对数百张高分辨率显微图像,却苦于找不到一个既快速又精准的拼接工具?当…...

C99新特性:变长数组(VLA)

文章目录C99新特性:变长数组(VLA) 🚀什么是变长数组? 🤔为什么需要变长数组? 💡VLA的基本语法和用法 📝在函数内部使用VLAVLA作为函数参数多维VLAVLA的工作原理和内存分配…...

linux指令的介绍(2)

此次核心介绍新的指令1.rm 删文件2.man查指令使用3.cp 拷贝文件内容4.cat 打印文件内容5.mv 剪切内容6.less 一页一页的打印文件内容7.date 查时间1.rm删文件rmdir:只能删空目录ubuntuVM-0-2-ubuntu:~/lesson3$ ll total 12 drwxrwxr-x 3 ubuntu ubuntu 4096 Mar 2…...

C++的动态内存管理(new/delete的用法,malloc和new的区别,内存的具体分布)

C的动态内存管理允许程序在运行是根据需要分配内存和释放内存,主要通过new和delete运算符来完成。与静态内存分配相比,动态内存分配更具有灵活性,但它需要手动管理来避免内存泄漏。一C/C中内存的具体分布先来了解一下内存的几个区域&#xff…...

【OpenClaw企业级智能体实战】第27篇:Skill生态运营——企业私有Skill商店的搭建与审核机制

摘要:2026年ClawHavoc供应链攻击事件曝光超1200个恶意Skill渗透公共技能市场,工信部明确要求企业审慎使用第三方技能包并严格审查代码。本文基于真实安全事件与行业实践,完整讲解企业私有Skill商店从0到1搭建方案,覆盖小团队极简GitLab私有仓库、中大型企业Nacos 3.2私有Re…...

边缘计算语音识别实战:ARM平台深度部署方案与嵌入式AI部署指南

边缘计算语音识别实战:ARM平台深度部署方案与嵌入式AI部署指南 【免费下载链接】sherpa-onnx Speech-to-text, text-to-speech, speaker diarization, speech enhancement, source separation, and VAD using next-gen Kaldi with onnxruntime without Internet con…...

IDA Pro 9.3sp1 发布,主要针对 V850 反编译器的改进与问题修复

IDA Pro 9.3sp1 (macOS, Linux, Windows) - 强大的反汇编程序、反编译器和多功能调试器 A powerful disassembler, decompiler and a versatile debugger. In one tool. 请访问原文链接:https://sysin.org/blog/ida-pro/ 查看最新版。原创作品,转载请保…...

【42】软考软件设计师——设计模式代码实战|单例/工厂/策略/观察者 真实业务案例精讲

摘要:本文是《软件设计师50讲通关|从零基础到工程师职称》专栏第42篇,属于模块五:算法与代码实战强化第四篇,聚焦软考上午选择题与下午代码填空题四大高频设计模式:单例模式(双重检查锁)、工厂模式、策略模式、观察者模式。全文超4800字,搭配Mermaid类图/时序图清晰展…...

CLIP ViT-H-14快速部署:Docker镜像替代方案与本地Python服务对比

CLIP ViT-H-14快速部署:Docker镜像替代方案与本地Python服务对比 想快速搭建一个能看懂图片的AI服务吗?比如,你想让电脑自动给照片打标签、找相似图片,或者做个以图搜图的功能。今天要聊的CLIP ViT-H-14模型,就是干这…...

js内建对象

JavaScript 对象 在 JavaScript中,几乎所有的事物都是对象、在 JavaScript 中,对象是非常重要的,当你理解了对象,就可以了解 JavaScript 。 一维数组: 第一种:使用new关键字和Array()构造函数 a、 va…...

FastAPI子应用挂载:别再让root_path坑你一夜案

Julia(julialang.org)由Stefan Karpinski、Jeff Bezanson等在2009年创建,目标是融合Python的易用性、C的高性能、R的统计能力、Matlab的科学计算生态。 其核心设计哲学是: 高性能:编译型语言(JIT&#xff0…...

用OpenSearch实现电商语义搜索

想象一下,一位顾客搜索"适合团队通话的经济型无线耳机"。传统的关键词搜索返回零结果,因为您的商品标题中并不包含所有这些确切词汇。但借助由生成式 AI 嵌入模型驱动的语义搜索,OpenSearch 能够理解用户意图——并将您最好的带降噪…...

用Claude Agent SDK构建CLI工具

我已经向我的团队说了几个月,Claude Code包装器将成为2026年的Cursor。在花了大量时间深入研究Claude Agent SDK后,是的,在像其他人一样仔细研究了泄露的源代码之后,我比以往任何时候都更加确信。转变是真实的:不再是来…...

Audio Slicer音频分割工具:用智能静音检测告别手动剪辑烦恼

Audio Slicer音频分割工具:用智能静音检测告别手动剪辑烦恼 【免费下载链接】audio-slicer A simple GUI application that slices audio with silence detection 项目地址: https://gitcode.com/gh_mirrors/aud/audio-slicer 你是否曾为处理长音频文件而烦恼…...

SpringMVC 请求保姆级教程:路径映射、参数传递、JSON 交互、日期处理一网打尽(Spring系列12)

摘要:SpringMVC 作为 Java Web 开发中最主流的 MVC 框架,核心职责就是接收请求、处理数据、响应结果,这也是 SpringMVC 学习的重中之重。本文将从环境搭建、请求映射、参数传递(普通 / POJO / 数组 / 集合 / JSON / 日期&#xff…...

AI原生软件技术债爆发前夜:92%的GenAI项目在V1.5版本后陷入交付瘫痪,你中招了吗?

第一章:AI原生软件技术债的本质与临界征兆 2026奇点智能技术大会(https://ml-summit.org) AI原生软件的技术债并非传统工程债务的简单延伸,而是由模型-代码耦合失衡、数据契约隐式化、推理路径不可观测等结构性缺陷共同催生的“认知性负债”。当开发团队…...

AI agent开发笔记

AI模型强大程度:google CC > Microsoft copilot 1.在该路径下添加,AI生成规则文档:copilot-instructions.md...

LibreDWG:免费开源的DWG文件转换终极解决方案

LibreDWG:免费开源的DWG文件转换终极解决方案 【免费下载链接】libredwg Official mirror of libredwg. With CI hooks and nightly releases. PRs ok 项目地址: https://gitcode.com/gh_mirrors/li/libredwg 你是否经常遇到CAD设计文件格式不兼容的问题&…...

C++一维数组完全指南

一、什么是一维数组?用来一次性存储多个相同类型的数据内存中连续存放有统一的名字,用 ** 下标(索引)** 区分每个元素下标从 0 开始(非常重要)二、定义与初始化(四种常用方式)// 1. …...

BabelDOC终极指南:如何在企业环境中构建离线文档翻译解决方案

BabelDOC终极指南:如何在企业环境中构建离线文档翻译解决方案 【免费下载链接】BabelDOC Yet Another Document Translator 项目地址: https://gitcode.com/GitHub_Trending/ba/BabelDOC BabelDOC是一款专业的企业级文档翻译工具,专注于PDF科学论…...

#50_基尔霍夫两大定律

50_基尔霍夫两大定律 50_基尔霍夫两大定律0. 引言0.1 基尔霍夫定律的历史背景0.2 基尔霍夫定律在电路分析中的地位0.3 两大定律的适用条件1. 基本概念1.1 电路的基本术语a. 支路b. 节点c. 回路d. 网孔1.2 电流的参考方向1.3 电压的参考极性2. 基尔霍夫电流定律(KCL&…...

2025年代码托管平台深度评测:Gitee如何领跑DevOps时代

在数字化转型加速的2025年,代码托管平台已成为软件开发的基础设施。随着DevOps理念的深度渗透和CI/CD实践的广泛普及,开发者对代码托管平台的需求已经从简单的版本控制升级为全生命周期管理。在这一背景下,Gitee凭借其本地化优势和创新功能设…...

ISE 14.7在Win10虚拟机里卡死闪退?一个输入法设置帮你搞定(附完整安装避坑指南)

ISE 14.7虚拟机环境配置全攻略:从输入法陷阱到FPGA开发实战 刚接触FPGA开发的新手们,是否曾在虚拟机里安装ISE时遭遇过输入项目名称就闪退的崩溃瞬间?这个问题困扰过无数开发者,而解决方案往往藏在不显眼的系统设置里。本文将带你…...