

<!DOCTYPE html>

<html lang="en-US">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=Edge">

  <link rel="stylesheet" href="/specflow-help/assets/css/just-the-docs-default.css">

  <link rel="stylesheet" href="/specflow-help/assets/css/just-the-docs-head-nav.css" id="jtd-head-nav-stylesheet">

  <style id="jtd-nav-activation">
  
    .site-nav ul li a {
      background-image: none;
    }

  </style>

  

  
    <script src="/specflow-help/assets/js/vendor/lunr.min.js"></script>
  

  <script src="/specflow-help/assets/js/just-the-docs.js"></script>

  <meta name="viewport" content="width=device-width, initial-scale=1">

  



  <!-- Begin Jekyll SEO tag v2.8.0 -->
<title>Specflow Documentation | Architecture contracts for AI-generated code</title>
<meta name="generator" content="Jekyll v3.10.0" />
<meta property="og:title" content="Specflow Documentation" />
<meta property="og:locale" content="en_US" />
<meta name="description" content="Architecture contracts for AI-generated code" />
<meta property="og:description" content="Architecture contracts for AI-generated code" />
<link rel="canonical" href="https://hulupeep.github.io/specflow-help/assets/css/just-the-docs-head-nav.css" />
<meta property="og:url" content="https://hulupeep.github.io/specflow-help/assets/css/just-the-docs-head-nav.css" />
<meta property="og:site_name" content="Specflow Documentation" />
<meta property="og:type" content="website" />
<meta name="twitter:card" content="summary" />
<meta property="twitter:title" content="Specflow Documentation" />
<script type="application/ld+json">
{"@context":"https://schema.org","@type":"WebPage","description":"Architecture contracts for AI-generated code","headline":"Specflow Documentation","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"https://hulupeep.github.io/specflow-help/assets/images/specflow-logo.png"}},"url":"https://hulupeep.github.io/specflow-help/assets/css/just-the-docs-head-nav.css"}</script>
<!-- End Jekyll SEO tag -->


  

</head>

<body>
  <a class="skip-to-main" href="#main-content">Skip to main content</a>
  <svg xmlns="http://www.w3.org/2000/svg" class="d-none">
  <symbol id="svg-link" viewBox="0 0 24 24">
  <title>Link</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-link">
    <path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path>
  </svg>
</symbol>

  <symbol id="svg-menu" viewBox="0 0 24 24">
  <title>Menu</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-menu">
    <line x1="3" y1="12" x2="21" y2="12"></line><line x1="3" y1="6" x2="21" y2="6"></line><line x1="3" y1="18" x2="21" y2="18"></line>
  </svg>
</symbol>

  <symbol id="svg-arrow-right" viewBox="0 0 24 24">
  <title>Expand</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-chevron-right">
    <polyline points="9 18 15 12 9 6"></polyline>
  </svg>
</symbol>

  <!-- Feather. MIT License: https://github.com/feathericons/feather/blob/master/LICENSE -->
<symbol id="svg-external-link" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-external-link">
  <title id="svg-external-link-title">(external link)</title>
  <path d="M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"></path><polyline points="15 3 21 3 21 9"></polyline><line x1="10" y1="14" x2="21" y2="3"></line>
</symbol>

  
    <symbol id="svg-doc" viewBox="0 0 24 24">
  <title>Document</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-file">
    <path d="M13 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V9z"></path><polyline points="13 2 13 9 20 9"></polyline>
  </svg>
</symbol>

    <symbol id="svg-search" viewBox="0 0 24 24">
  <title>Search</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-search">
    <circle cx="11" cy="11" r="8"></circle><line x1="21" y1="21" x2="16.65" y2="16.65"></line>
  </svg>
</symbol>

  
  
    <!-- Bootstrap Icons. MIT License: https://github.com/twbs/icons/blob/main/LICENSE.md -->
<symbol id="svg-copy" viewBox="0 0 16 16">
  <title>Copy</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-clipboard" viewBox="0 0 16 16">
    <path d="M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1h1a1 1 0 0 1 1 1V14a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3.5a1 1 0 0 1 1-1h1v-1z"/>
    <path d="M9.5 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3zm-3-1A1.5 1.5 0 0 0 5 1.5v1A1.5 1.5 0 0 0 6.5 4h3A1.5 1.5 0 0 0 11 2.5v-1A1.5 1.5 0 0 0 9.5 0h-3z"/>
  </svg>
</symbol>
<symbol id="svg-copied" viewBox="0 0 16 16">
  <title>Copied</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-clipboard-check-fill" viewBox="0 0 16 16">
    <path d="M6.5 0A1.5 1.5 0 0 0 5 1.5v1A1.5 1.5 0 0 0 6.5 4h3A1.5 1.5 0 0 0 11 2.5v-1A1.5 1.5 0 0 0 9.5 0h-3Zm3 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3Z"/>
    <path d="M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1A2.5 2.5 0 0 1 9.5 5h-3A2.5 2.5 0 0 1 4 2.5v-1Zm6.854 7.354-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 0 1 .708-.708L7.5 10.793l2.646-2.647a.5.5 0 0 1 .708.708Z"/>
  </svg>
</symbol>

  
</svg>

  
    <header class="side-bar">
  <div class="site-header">
    <a href="/specflow-help/" class="site-title lh-tight">
  <div class="site-logo" role="img" aria-label="Specflow Documentation"></div>

</a>
    <button id="menu-button" class="site-button btn-reset" aria-label="Menu" aria-expanded="false">
      <svg viewBox="0 0 24 24" class="icon" aria-hidden="true"><use xlink:href="#svg-menu"></use></svg>
    </button>
  </div>

  <nav aria-label="Main" id="site-nav" class="site-nav">
  
  
    <ul class="nav-list"><li class="nav-list-item"><a href="/specflow-help/" class="nav-list-link">Home</a></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Getting Started submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/specflow-help/getting-started/" class="nav-list-link">Getting Started</a><ul class="nav-list"><li class="nav-list-item"><a href="/specflow-help/getting-started/install/" class="nav-list-link">Installation</a></li><li class="nav-list-item"><a href="/specflow-help/getting-started/skill-file/" class="nav-list-link">SKILL.md (Single File)</a></li><li class="nav-list-item"><a href="/specflow-help/getting-started/verify-setup/" class="nav-list-link">Verify It's Working</a></li><li class="nav-list-item"><a href="/specflow-help/getting-started/working-with-specflow/" class="nav-list-link">Working With Specflow</a></li><li class="nav-list-item"><a href="/specflow-help/getting-started/first-wave/" class="nav-list-link">Your First Wave</a></li><li class="nav-list-item"><a href="/specflow-help/getting-started/understanding-output/" class="nav-list-link">Understanding Output</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Core Concepts submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/specflow-help/core-concepts/" class="nav-list-link">Core Concepts</a><ul class="nav-list"><li class="nav-list-item"><a href="/specflow-help/core-concepts/contracts/" class="nav-list-link">What Are Contracts?</a></li><li class="nav-list-item"><a href="/specflow-help/core-concepts/agents/" class="nav-list-link">How Agents Work</a></li><li class="nav-list-item"><a href="/specflow-help/core-concepts/contract-graph/" class="nav-list-link">Contract Graph</a></li><li class="nav-list-item"><a href="/specflow-help/core-concepts/journeys/" class="nav-list-link">What Are Journeys?</a></li><li class="nav-list-item"><a href="/specflow-help/core-concepts/security-accessibility/" class="nav-list-link">Security & Accessibility Gates</a></li><li class="nav-list-item"><a href="/specflow-help/core-concepts/team-workflows/" class="nav-list-link">Team Workflows</a></li><li class="nav-list-item"><a href="/specflow-help/core-concepts/production-readiness/" class="nav-list-link">Production Readiness Gates</a></li><li class="nav-list-item"><a href="/specflow-help/core-concepts/test-integrity/" class="nav-list-link">Test Integrity Gates</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Agent System submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/specflow-help/agent-system/" class="nav-list-link">Agent System</a><ul class="nav-list"><li class="nav-list-item"><a href="/specflow-help/agent-system/waves-controller/" class="nav-list-link">waves-controller</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agent-reference/" class="nav-list-link">Agent Reference</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agent-teams/" class="nav-list-link">Agent Teams</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/dpao/" class="nav-list-link">DPAO Methodology</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/customizing/" class="nav-list-link">Customizing Agents</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/model-routing/" class="nav-list-link">Model Routing</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/board-auditor.html" class="nav-list-link">Board Auditor</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/contract-generator.html" class="nav-list-link">Contract Generator</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/contract-test-generator.html" class="nav-list-link">Contract Test Generator</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/contract-validator.html" class="nav-list-link">Contract Validator</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/dependency-mapper.html" class="nav-list-link">Dependency Mapper</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/e2e-test-auditor.html" class="nav-list-link">E2E Test Auditor</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/edge-function-builder.html" class="nav-list-link">Edge Function Builder</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/frontend-builder.html" class="nav-list-link">Frontend Builder</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/journey-enforcer.html" class="nav-list-link">Journey Enforcer</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/journey-tester.html" class="nav-list-link">Journey Tester</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/migration-builder.html" class="nav-list-link">Migration Builder</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/playwright-from-specflow.html" class="nav-list-link">Playwright from Specflow</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/specflow-uplifter.html" class="nav-list-link">Specflow Uplifter</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/specflow-writer.html" class="nav-list-link">Specflow Writer</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/sprint-executor.html" class="nav-list-link">Sprint Executor</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/test-runner.html" class="nav-list-link">Test Runner</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/ticket-closer.html" class="nav-list-link">Ticket Closer</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Background submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/specflow-help/background/" class="nav-list-link">Background</a><ul class="nav-list"><li class="nav-list-item"><a href="/specflow-help/background/origins/" class="nav-list-link">Origins & Academic Foundation</a></li><li class="nav-list-item"><a href="/specflow-help/background/why-now/" class="nav-list-link">Why Now?</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Advanced submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/specflow-help/advanced/" class="nav-list-link">Advanced</a><ul class="nav-list"><li class="nav-list-item"><a href="/specflow-help/advanced/manual-contracts/" class="nav-list-link">Writing Contracts Manually</a></li><li class="nav-list-item"><a href="/specflow-help/advanced/journey-testing/" class="nav-list-link">Journey Testing Guide</a></li><li class="nav-list-item"><a href="/specflow-help/advanced/journey-verification-hooks.html" class="nav-list-link">Journey Verification Hooks</a></li><li class="nav-list-item"><a href="/specflow-help/advanced/self-healing/" class="nav-list-link">Self-Healing Fix Loops</a></li><li class="nav-list-item"><a href="/specflow-help/advanced/ci-integration.html" class="nav-list-link">CI/CD Integration</a></li><li class="nav-list-item"><a href="/specflow-help/advanced/learning-system/" class="nav-list-link">Post-Mortem Learning System</a></li><li class="nav-list-item"><a href="/specflow-help/advanced/ci-feedback/" class="nav-list-link">CI Feedback Loop</a></li><li class="nav-list-item"><a href="/specflow-help/advanced/drift-prevention/" class="nav-list-link">Drift Prevention</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Reference submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/specflow-help/reference/" class="nav-list-link">Reference</a><ul class="nav-list"><li class="nav-list-item"><a href="/specflow-help/reference/contract-schema/" class="nav-list-link">Contract Schema</a></li><li class="nav-list-item"><a href="/specflow-help/reference/csv-journey-schema/" class="nav-list-link">CSV Journey Schema</a></li></ul></li><li class="nav-list-item"><a href="/specflow-help/about/" class="nav-list-link">About</a></li><li class="nav-list-item"><a href="/specflow-help/acknowledgments/" class="nav-list-link">Acknowledgments</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/PROTOCOL.html" class="nav-list-link">Agent Communication Protocol</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/team-names.html" class="nav-list-link">Agent Team Names</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/waves-controller.html" class="nav-list-link">Agent: waves-controller</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/" class="nav-list-link">Specflow Agent Library</a></li><li class="nav-list-item"><a href="/specflow-help/POSITIONING.html" class="nav-list-link">SpecFlow Positioning Guide</a></li><li class="nav-list-item"><a href="/specflow-help/agent-system/agents/WORKFLOW.html" class="nav-list-link">Specflow Workflow</a></li></ul>
  
</nav>


<div class="d-md-block d-none site-footer">
  
  
    This site uses <a href="https://github.com/just-the-docs/just-the-docs">Just the Docs</a>, a documentation theme for Jekyll.
  
  </div>
</header>

  
  <div class="main" id="top">
    <div id="main-header" class="main-header">
  
    

<div class="search" role="search">
  <div class="search-input-wrap">
    <input type="text" id="search-input" class="search-input" tabindex="0" placeholder="Search Specflow Documentation" autocomplete="off">
    <label for="search-input" class="search-label">
      <span class="sr-only">Search Specflow Documentation</span>
      <svg viewBox="0 0 24 24" class="search-icon" aria-hidden="true"><use xlink:href="#svg-search"></use></svg>
    </label>
  </div>
  <div id="search-results" class="search-results"></div>
</div>

  
  
  
    <nav aria-label="Auxiliary" class="aux-nav">
  <ul class="aux-nav-list">
    
      <li class="aux-nav-list-item">
        <a href="https://github.com/Hulupeep/Specflow" class="site-button"
          
        >
          GitHub
        </a>
      </li>
    
  </ul>
</nav>

  
</div>

    <div class="main-content-wrap">
      
      <div id="main-content" class="main-content">
        <main>
          
            

          

          
            
          
        </main>
        
<hr>
<footer>
  

  <p class="text-small mb-0">Copyright &copy; 2025 Specflow. Built with <a href="https://jekyllrb.com/">Jekyll</a> and <a href="https://just-the-docs.com/">Just the Docs</a>.</p>

  <div class="d-md-none mt-4 fs-2">
    
    
      This site uses <a href="https://github.com/just-the-docs/just-the-docs">Just the Docs</a>, a documentation theme for Jekyll.
    
  </div>
</footer>

      </div>
    </div>
    
      
<button id="search-button" class="search-button btn-reset" aria-label="Focus on search">
  <svg viewBox="0 0 24 24" class="icon" aria-hidden="true"><use xlink:href="#svg-search"></use></svg>
</button>


<div class="search-overlay"></div>

    
  </div>

  
    





<script type="module">
  
  import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@10.6.1/dist/mermaid.esm.min.mjs';
  

  var config = {}
;
  mermaid.initialize(config);
  mermaid.run({
    querySelector: '.language-mermaid',
  });
</script>



  
</body>
</html>

