Install
openclaw skills install swiftverifyApple Design Award 标准的 Swift/SwiftUI 项目验证技能。执行编译、架构、设计系统、无障碍、国际化、性能、原生集成七层检查,生成综合报告。
openclaw skills install swiftverify核心任务: 确保代码达到 Apple Design Award 评审标准 (执行
./tools/quality_gate.sh full)。 执行频率: 每次 Feature 完成后、PR 合并前、发布前必须执行。
├── scripts/
│ ├── run_all.sh # 入口脚本
│ ├── check_build.sh # Step 1: 编译
│ ├── check_architecture.sh # Step 2: 架构
│ ├── check_design_tokens.sh # Step 3: 设计
│ ├── check_a11y.sh # Step 4: 无障碍
│ ├── check_i18n.sh # Step 5: 国际化
│ ├── check_performance.sh # Step 6: 性能
│ ├── check_native.sh # Step 7: 原生
│ └── check_tests.sh # Step 8: 测试
## 技能拓扑图 (Topology)
```mermaid
graph TD
User[用户 / CI] -->|调用| RunAll[run_all.sh]
subgraph "Verification Steps"
RunAll --> Build[1. Build & Lint]
RunAll --> Arch[2. Architecture]
RunAll --> Tokens[3. Design Tokens]
RunAll --> A11y[4. Accessibility]
RunAll --> I18n[5. i18n]
RunAll --> Perf[6. Performance]
RunAll --> Native[7. Native Integration]
RunAll --> Tests[8. Unit Tests]
end
subgraph "Dependencies"
Build --> Xcode[xcodebuild]
Build --> SwiftLint[swiftlint]
Tests --> XCTest[XCTest]
Arch --> Grep[grep/awk]
end
subgraph "Rules"
RunAll -.-|quality_gate.sh| Tools[Project Tools]
end
│ ├── check_build.sh # Step 1: 编译检查 │ ├── check_architecture.sh # Step 2: 架构漂移检测 │ ├── check_design_tokens.sh # Step 3: 设计系统合规 │ ├── check_a11y.sh # Step 4: 无障碍检查 │ ├── check_i18n.sh # Step 5: 国际化检查 │ ├── check_performance.sh # Step 6: 性能基准 (需手动) │ ├── check_native.sh # Step 7: 原生集成检查 │ └── run_all.sh # 一键执行全部检查 ├── templates/ │ └── verification_report.md # 报告模板 └── resources/ └── ada_checklist.md # Apple Design Award 检查清单
---
## 1. 执行流程 (Execution Protocol)
### 快速验证 (Quick Check)
```bash
./agent/skills/swiftverify/scripts/run_all.sh
按顺序执行以下检查,任一失败则阻断:
| Step | 脚本 | 验证内容 | 阻断级别 |
|---|---|---|---|
| 1 | check_build.sh | 编译通过 + SwiftLint | 🔴 HARD |
| 2 | check_architecture.sh | MVVM+ 分层 + 依赖方向 | 🔴 HARD |
| 3 | check_design_tokens.sh | Token 使用率 100% | 🟡 SOFT |
| 4 | check_a11y.sh | 无障碍标签覆盖 | 🟡 SOFT |
| 5 | check_i18n.sh | 字符串本地化 100% | 🟡 SOFT |
| 6 | check_performance.sh | 性能基准 (手动) | 🟢 INFO |
| 7 | check_native.sh | 原生集成验证 | 🟢 INFO |
| 8 | check_tests.sh | Unit Tests (XCTest) | 🟡 SOFT |
swiftverify 整合了完整的无障碍检查指南。详见 resources/accessibility-checklist.md。
自动检查项:
执行检查:
./scripts/check_a11y.sh
文件: scripts/check_build.sh
| 检查项 | 标准 | 状态 |
|---|---|---|
| xcodebuild 编译 | EXIT 0 | HARD |
| SwiftLint | 0 Error | HARD |
| 生命周期激活 | 所有 Service 启动 | HARD |
文件: scripts/check_architecture.sh
| 检查项 | 验证规则 | 状态 |
|---|---|---|
| View 层隔离 | Views/ 不 import SwiftData | HARD |
| Model 层隔离 | Models/ 不 import SwiftUI | HARD |
| Sendable 符合 | 所有 Model 实现 Sendable | HARD |
| GCD 禁用 | 无 DispatchQueue | HARD |
文件: scripts/check_design_tokens.sh
| 检查项 | 验证规则 | 状态 |
|---|---|---|
| 硬编码颜色 | 无 Color(#...) 或 .red 等 | SOFT |
| 硬编码数值 | 无 .padding(16) 等 | SOFT |
| 标准圆角 | 使用 DesignTokens.CornerRadius | SOFT |
| 标准间距 | 使用 DesignTokens.Spacing | SOFT |
文件: scripts/check_a11y.sh
| 检查项 | 验证规则 | 状态 |
|---|---|---|
| accessibilityLabel | 所有 Button/Image 有标签 | SOFT |
| 触控区域 | 交互元素 ≥ 44x44 pt | SOFT |
| 动态字体 | 无 .font(.system(size:)) | SOFT |
文件: scripts/check_i18n.sh
| 检查项 | 验证规则 | 状态 |
|---|---|---|
| 字符串本地化 | 使用 String(localized:) | SOFT |
| 无硬编码中文 | Text("中文") 需替换 | SOFT |
文件: scripts/check_performance.sh
| 检查项 | 工具 | 标准 |
|---|---|---|
| 启动时间 | Instruments | < 400ms |
| 内存泄漏 | Instruments Leaks | 0 |
| 主线程阻塞 | Main Thread Checker | 0 |
⚠️ 性能检查需要手动运行 Instruments
文件: scripts/check_native.sh
| 检查项 | 验证规则 | 状态 |
|---|---|---|
| AppIntent 存在 | Intents/ 目录非空 | INFO |
| Shortcuts 注册 | AppShortcutsProvider 存在 | INFO |
文件: scripts/check_tests.sh
| 检查项 | 验证规则 | 状态 |
|---|---|---|
| Unit Tests | 如果存在测试 Target,必须全部通过 | SOFT |
| Code Coverage | (可选) 输出覆盖率报告 | INFO |
执行完成后,在 specs/verification_report.md 生成报告:
# 验证报告 - [日期]
## 总体状态: ✅ PASS / ❌ FAIL
| 检查维度 | 状态 | 违规数 |
|----------|------|--------|
| 编译检查 | ✅ | 0 |
| 架构一致性 | ✅ | 0 |
| 设计系统 | ⚠️ | 3 |
| 无障碍 | ⚠️ | 5 |
| 国际化 | ✅ | 0 |
| 性能 | ⏳ | - |
| 原生集成 | ✅ | 0 |
| 单元测试 | ✅ | 0 |
## 违规详情
...
对于 SOFT 级别的违规,提供自动修复建议:
| 违规类型 | 自动修复方法 |
|---|---|
| 硬编码字符串 | 替换为 String(localized: "key") |
| 硬编码数值 | 替换为 DesignTokens.Spacing.xxx |
| 缺少 a11y 标签 | 添加 .accessibilityLabel() |
# GitHub Actions 示例
- name: SwiftVerify
run: |
chmod +x .agent/skills/swiftverify/scripts/run_all.sh
.agent/skills/swiftverify/scripts/run_all.sh