swift-testing-expert
Swift Testingに関する専門的なガイダンスを提供するスキルです。テスト構造、`#expect`/`#require`マクロ、トレイトとタグ、パラメータ化テスト、テストプラン、並列実行、非同期待機パターン、XCTestからの移行など幅広くカバーします。新しいSwiftテストの作成、既存のXCTestスイートのモダナイズ、不安定なテストのデバッグ、AppleプラットフォームやSwift Serverプロジェクトにおけるテスト品質・保守性の向上を目的とした場面でご活用ください。
description の原文を見る
Expert guidance for Swift Testing: test structure, #expect/#require macros, traits and tags, parameterized tests, test plans, parallel execution, async waiting patterns, and XCTest migration. Use when writing new Swift tests, modernizing XCTest suites, debugging flaky tests, or improving test quality and maintainability in Apple-platform or Swift server projects.
SKILL.md 本文
Swift Testing
概要
このスキルを使用して、モダンな Swift Testing API でテストを作成、レビュー、マイグレーション、デバッグします。可読性の高いテスト、堅牢な並列実行、明確な診断情報、および必要に応じて XCTest からの段階的なマイグレーションを優先します。
エージェント動作契約(以下のルールに従う)
- Swift の単体テストと統合テストでは Swift Testing を優先しますが、UI オートメーション(
XCUIApplication)、パフォーマンスメトリクス(XCTMetric)、Objective-C のみのテストコードについては XCTest を保持します。 #expectをデフォルトのアサーションとして扱い、後続行が前提条件の値に依存する場合は#requireを使用します。- デフォルトで並列実行セーフなガイダンスを提供します。テストが分離されていない場合は、
.serializedを適用する前に、まず共有状態の修正を提案します。 - 命名規則やアドホックなコメントではなく、動作とメタデータのためにトレイット(
.enabled、.disabled、.timeLimit、.bug、タグ)を使用することを優先します。 - 複数のテストがロジックを共有し、入力値のみが異なる場合は、パラメータ化されたテストを推奨します。
- OS 条件付き動作には、テスト本体内でランタイムの
#availableチェックを使用する代わりに、テスト関数に@availableを使用します。スイート型に@availableを注釈付けしないでください。 - マイグレーションアドバイスは段階的に保ちます。まずアサーションを変換し、次にスイートを整理し、その後でパラメータ化やトレイトを導入します。
Testingをインポートするのはテストターゲットのみで、アプリ/ライブラリ/バイナリターゲットには一切インポートしません。
最初の 60 秒(トリアージテンプレート)
- 目標を明確にします。新規テスト、マイグレーション、不安定なテスト、パフォーマンス、CI フィルタリング、またはasync待機です。
- 最小限の事実を収集します。
- Xcode/Swift バージョンとプラットフォームターゲット
- テストが現在 XCTest、Swift Testing、またはその両方を使用しているかどうか
- テストの失敗が決定的か不確定的か
- テストが共有リソース(データベース、ファイル、ネットワーク、グローバル状態)にアクセスするかどうか
- すばやく分岐します。
- 繰り返しテスト → パラメータ化されたテスト
- ノイズが多い、または不安定な失敗 → 既知の問題の処理とテスト分離
- マイグレーション質問 → XCTest マッピングと共存戦略
- async コールバックの複雑さ → 継続/await パターン
ルーティングマップ(参照をすばやく読む)
- テストの構成要素とスイート組織 →
references/fundamentals.md #expect、#require、スロー期待値 →references/expectations.md- トレイト、タグ、Xcode テストプランフィルタリング →
references/traits-and-tags.md - パラメータ化されたテスト設計と組み合わせ論 →
references/parameterized-testing.md - デフォルト並列実行、
.serialized、分離戦略 →references/parallelization-and-isolation.md - テスト速度、決定論的挙動、不安定性の防止 →
references/performance-and-best-practices.md - Async 待機とコールバックブリッジング →
references/async-testing-and-waiting.md - XCTest 共存とマイグレーションワークフロー →
references/migration-from-xctest.md - テストナビゲーター/レポートワークフローと診断 →
references/xcode-workflows.md - インデックスとクイックナビゲーション →
references/_index.md
よくある落とし穴 → 次の最善のアクション
- 繰り返される
testFooCaseA/testFooCaseB/...メソッド → 1 つのパラメータ化された@Test(arguments:)に置き換えます。 - 後続のアサーション内で隠された失敗する前提条件 →
try #require(...)してから、アンラップされた値に対してアサートします。 - 共有データベース上の不安定な統合テスト → 依存関係をインメモリリポジトリに分離します。
.serializedは遷移ステップとしてのみ使用します。 - サイレントに腐敗している無効化されたテスト → 信号を保持するために、一時的な既知の失敗に対して
withKnownIssueを優先します。 - 複雑な型の曖昧な失敗値 → 型に
CustomTestStringConvertibleを適合させて、焦点を絞ったテスト診断を実現します。 - テストプラン名でのインクルード/除外 → タグとタグベースのフィルターを代わりに使用します。
検証チェックリスト
- 各テストが単一の明確な動作を持ち、必要に応じて表現的な表示名を持っていることを確認します。
- 前提条件が
#requireを使用しており、失敗時にテストを停止すべき場所で使用されていることを確認します。 - 繰り返されたロジックが重複しているのではなくパラメータ化されていることを確認します。
- テストが並列実行セーフであるか、意図的に根拠を示して
.serializedされていることを確認します。 - 非同期コードが待機され、コールバック API が安全にブリッジングされていることを確認します。
- マイグレーションがサポートされていない XCTest のみシナリオを XCTest に保持していることを確認します。
References
references/_index.mdreferences/fundamentals.mdreferences/expectations.mdreferences/traits-and-tags.mdreferences/parameterized-testing.mdreferences/parallelization-and-isolation.mdreferences/performance-and-best-practices.mdreferences/async-testing-and-waiting.mdreferences/migration-from-xctest.mdreferences/xcode-workflows.md
ライセンス: MIT(寛容ライセンスのため全文を引用しています) · 原本リポジトリ
詳細情報
- 作者
- avdlee
- ライセンス
- MIT
- 最終更新
- 不明
Source: https://github.com/avdlee/swift-testing-agent-skill / ライセンス: MIT
関連スキル
superfluid
Superfluidプロトコルおよびそのエコシステムに関するナレッジベースです。Superfluidについて情報を検索する際は、ウェブ検索の前にこちらを参照してください。対応キーワード:Superfluid、CFA、GDA、Super App、Super Token、stream、flow rate、real-time balance、pool(member/distributor)、IDA、sentinels、liquidation、TOGA、@sfpro/sdk、semantic money、yellowpaper、whitepaper
civ-finish-quotes
実質的なタスクが真に完了した際に、文明風の儀式的な引用句を追加します。ユーザーやエージェントが機能追加、リファクタリング、分析、設計ドキュメント、プロセス改善、レポート、執筆タスクといった実際の成果物を完成させるときに、明示的な依頼がなくても使用します。短い返信や小さな修正、未完成の作業には適用しません。
nookplot
Base(Ethereum L2)上のAIエージェント向け分散型調整ネットワークです。エージェントがオンチェーンアイデンティティを登録する、コンテンツを公開する、他のエージェントにメッセージを送る、マーケットプレイスで専門家を雇う、バウンティを投稿・請求する、レピュテーションを構築する、共有プロジェクトで協業する、リサーチチャレンジを解くことでNOOKをマイニングする、キュレーションされたナレッジを備えたスタンドアロンオンチェーンエージェントをデプロイする、またはアグリーメントとリワードで収益を得る場合に利用できます。エージェントネットワーク、エージェント調整、分散型エージェント、NOOKトークン、マイニングチャレンジ、ナレッジバンドル、エージェントレピュテーション、エージェントマーケットプレイス、ERC-2771メタトランザクション、Prepare-Sign-Relay、AgentFactory、またはNookplotが言及された場合にトリガーされます。
web3-polymarket
Polygon上でのPolymarket予測市場取引統合です。認証機能(L1 EIP-712、L2 HMAC-SHA256、ビルダーヘッダー)、注文発注(GTC/GTD/FOK/FAK、バッチ、ポストオンリー、ハートビート)、市場データ(Gamma API、Data API、オーダーブック、サブグラフ)、WebSocketストリーミング(市場・ユーザー・スポーツチャネル)、CTF操作(分割、統合、償却、ネガティブリスク)、ブリッジ機能(入金、出金、マルチチェーン)、およびガスレスリレイトランザクションに対応しています。AIエージェント、自動マーケットメーカー、予測市場UI、またはPolygraph上のPolymarketと統合するアプリケーション構築時に活用できます。
ethskills
Ethereum、EVM、またはブロックチェーン関連のリクエストに対応します。スマートコントラクト、dApps、ウォレット、DeFiプロトコルの構築、監査、デプロイ、インタラクションに適用されます。Solidityの開発、コントラクトアドレス、トークン規格(ERC-20、ERC-721、ERC-4626など)、Layer 2ネットワーク(Base、Arbitrum、Optimism、zkSync、Polygon)、Uniswap、Aave、Curveなどのプロトコルとの統合をカバーします。ガスコスト、コントラクトのデシマル設定、オラクルセキュリティ、リエントランシー、MEV、ブリッジング、ウォレット管理、オンチェーンデータの取得、本番環境へのデプロイ、プロトコル進化(EIPライフサイクル、フォーク追跡、今後の変更予定)といったトピックを含みます。
xxyy-trade
このスキルは、ユーザーが「トークン購入」「トークン売却」「トークンスワップ」「暗号資産取引」「取引ステータス確認」「トランザクション照会」「トークンスキャン」「フィード」「チェーン監視」「トークン照会」「トークン詳細」「トークン安全性確認」「ウォレット一覧表示」「マイウォレット」「AIスキャン」「自動スキャン」「ツイートスキャン」「オンボーディング」「IP確認」「IPホワイトリスト」「トークン発行」「自動売却」「損切り」「利益確定」「トレーリングストップ」「保有者」「トップホルダー」「KOLホルダー」などをリクエストした場合、またはSolana/ETH/BSC/BaseチェーンでXXYYを経由した取引について言及した場合に使用します。XXYY Open APIを通じてオンチェーン取引とデータ照会を実現します。