<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Tiziano Basile</title>
    <description>The latest articles on DEV Community by Tiziano Basile (@basteez).</description>
    <link>https://dev.to/basteez</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F77918%2Ffed72e92-c80b-4055-b7de-883ae35abb91.png</url>
      <title>DEV Community: Tiziano Basile</title>
      <link>https://dev.to/basteez</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/basteez"/>
    <language>en</language>
    <item>
      <title>BMAD in action: building TODOdoro</title>
      <dc:creator>Tiziano Basile</dc:creator>
      <pubDate>Mon, 20 Apr 2026 06:51:18 +0000</pubDate>
      <link>https://dev.to/basteez/bmad-in-action-building-tododoro-4kop</link>
      <guid>https://dev.to/basteez/bmad-in-action-building-tododoro-4kop</guid>
      <description>&lt;p&gt;This is the final post in my series about the BMAD Method. In &lt;a href="https://dev.to/basteez/dont-be-mad-bmad-instead-3d4i"&gt;Part 1&lt;/a&gt;, I explained why I was skeptical of AI tools and how BMAD changed my mind. In &lt;a href="https://dev.to/basteez/bmad-meet-the-crew-13f8"&gt;Part 2&lt;/a&gt;, I introduced the agents and how they work together.&lt;/p&gt;

&lt;p&gt;Now I want to show you what BMAD looks like in practice.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://github.com/basteez/TODOdoro" rel="noopener noreferrer"&gt;TODOdoro&lt;/a&gt; is a productivity app I built using BMAD. It combines todo management with the Pomodoro technique, but (as you'll see) it became something more interesting than that description suggests. The project is open source, still a work in progress, and all the BMAD artifacts are available in the repository if you want to explore them yourself.&lt;/p&gt;

&lt;p&gt;Let me walk you through the journey from initial idea to working code.&lt;/p&gt;

&lt;h2&gt;
  
  
  The starting point
&lt;/h2&gt;

&lt;p&gt;I wanted to build a Pomodoro timer integrated with a todo app. Simple enough, right? Track tasks, run timers, see how many focused sessions each task required.&lt;/p&gt;

&lt;p&gt;That was the prompt I brought to the brainstorming session. It wasn't wrong, but it wasn't interesting either.&lt;/p&gt;

&lt;h2&gt;
  
  
  Brainstorming: where the magic happened
&lt;/h2&gt;

&lt;p&gt;I started with Mary (the Business Analyst) running a brainstorming session (&lt;code&gt;/bmad-agent-analyst&lt;/code&gt;, then selecting the brainstorming capability, or directly with &lt;code&gt;/bmad-brainstorming&lt;/code&gt;). The conversation began with practical questions: What tech stack? What features? How should the UX work?&lt;/p&gt;

&lt;p&gt;But Mary kept pushing deeper. She asked about the philosophy behind the tool. Why does tracking Pomodoros matter? What problem am I actually solving?&lt;/p&gt;

&lt;p&gt;The breakthrough came when the conversation shifted from features to first principles:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"A todo is not a reminder. It is a declaration of personal ownership. A Pomodoro is not a timer. It is a container for presence."&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;That reframing changed everything. Suddenly I wasn't building a todo app with timers. I was building a mirror that reflects where your attention actually went.&lt;/p&gt;

&lt;p&gt;This is what I meant in Part 1 about agents asking the questions you should be asking yourself. I walked into the session with a feature list. I walked out with a philosophy.&lt;/p&gt;

&lt;h3&gt;
  
  
  Key insights from brainstorming
&lt;/h3&gt;

&lt;p&gt;Several ideas emerged that shaped the entire product:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Session-first model.&lt;/strong&gt; Traditional apps put tasks first and time second. TODOdoro inverts this: the Pomodoro session is the primary entity. Todos are optional labels that sessions can belong to. You focus first, then reflect on what it meant.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Two kinds of letting go.&lt;/strong&gt; Most apps have a single "complete" action. But there's a difference between "this served its purpose" and "this was never truly mine." TODOdoro's Release Ritual makes you choose, because the distinction matters.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Spatial priority.&lt;/strong&gt; Instead of priority fields (P1, P2, P3) or due dates, position on a canvas represents importance. Drag something to the center when it matters. No metadata to maintain, just visual intention.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The Devotion Record.&lt;/strong&gt; Not a Pomodoro counter, but a timeline showing when and how much presence you invested. "11 Pomodoros across 9 days" tells a different story than "11 Pomodoros."&lt;/p&gt;

&lt;p&gt;The session generated 18 feature ideas, 9 architectural decisions, and 25+ edge cases to consider. All from a conversation that started with "I want a Pomodoro app."&lt;/p&gt;

&lt;h2&gt;
  
  
  From philosophy to product brief
&lt;/h2&gt;

&lt;p&gt;After brainstorming, I worked with John (Product Manager) to create a product brief (&lt;code&gt;/bmad-product-brief&lt;/code&gt;). This document captured:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Target users.&lt;/strong&gt; Two personas emerged:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Marco, the "tool-fatigued maker" who's exhausted by productivity overhead and wants honest visibility without guilt&lt;/li&gt;
&lt;li&gt;Sofia, the "invisible worker" whose research and writing produces slow, non-linear progress that traditional apps can't acknowledge&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Core vision.&lt;/strong&gt; Your time and attention are acts of devotion, not units of output. The app is a personal mirror, not a task manager.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Design philosophy.&lt;/strong&gt; Radical respect for user autonomy. No streaks, no scores, no notifications. Settings contain only timer durations and theme options. A hard cap of 100 canvas cards prevents infinite accumulation.&lt;/p&gt;

&lt;p&gt;This brief became the foundation everything else built on. When questions arose later (should we add due dates? what about subtasks?), the brief provided clear answers: no, because they violate the philosophy.&lt;/p&gt;

&lt;h2&gt;
  
  
  The PRD: philosophy becomes spec
&lt;/h2&gt;

&lt;p&gt;Working with John again (&lt;code&gt;/bmad-create-prd&lt;/code&gt;), I translated the product brief into a formal Product Requirements Document. This is where things got concrete.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Problem statement.&lt;/strong&gt; "You don't plan to focus. You focus, then reflect on what it meant."&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Success metrics.&lt;/strong&gt; Not vanity numbers, but signals of genuine value:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;The user returns on Day 8 without notifications (the canvas feels personally owned)&lt;/li&gt;
&lt;li&gt;Canvas contains 10 or fewer curated cards&lt;/li&gt;
&lt;li&gt;Devotion Records span weeks on single intentions&lt;/li&gt;
&lt;li&gt;User describes the app with a personal "why," not a feature summary&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Anti-metrics.&lt;/strong&gt; Signs the philosophy isn't landing:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;"Missing a due date field"&lt;/li&gt;
&lt;li&gt;"Need subtasks"&lt;/li&gt;
&lt;li&gt;Session spam under 60 seconds&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;User journeys.&lt;/strong&gt; Concrete scenarios showing how Marco and Sofia would experience the product. Not wireframes, but narratives that capture intent.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Functional requirements.&lt;/strong&gt; 31 specific requirements, each traceable to the philosophy. For example:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;FR9: Release Ritual asks explicit question distinguishing purpose-completion from ownership rejection&lt;/li&gt;
&lt;li&gt;FR21-23: Devotion Record displays all sessions as a timeline across dates&lt;/li&gt;
&lt;li&gt;FR27-31: All state stored locally, offline-first, with schema versioning&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The PRD also established philosophical guardrails as non-negotiable requirements:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No accounts, login, or server-side user data&lt;/li&gt;
&lt;li&gt;No due dates, priority fields, or subtasks&lt;/li&gt;
&lt;li&gt;No streaks, scores, or gamification&lt;/li&gt;
&lt;li&gt;Canvas hard cap of 100 cards (never configurable)&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;This is what spec-driven development looks like. Every decision is written down, justified, and traceable.&lt;/p&gt;

&lt;h2&gt;
  
  
  Architecture: Winston weighs in
&lt;/h2&gt;

&lt;p&gt;With requirements defined, I brought Winston (the Architect) into the conversation (&lt;code&gt;/bmad-create-architecture&lt;/code&gt;). His job was to translate the PRD into technical decisions.&lt;/p&gt;

&lt;p&gt;Key architectural choices:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Event sourcing.&lt;/strong&gt; Instead of storing current state, store all events that led to that state. This makes the Devotion Record trivial to implement (just replay session events) and enables powerful recovery from corruption.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Local-first with SQLite.&lt;/strong&gt; No accounts, no cloud. Data lives in the browser using SQLite compiled to WebAssembly (via SQLocal). The user owns their data completely.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Monorepo with strict boundaries.&lt;/strong&gt; A &lt;code&gt;@tododoro/domain&lt;/code&gt; package contains all business logic with zero external dependencies and 100% test coverage as a CI requirement. The domain is the philosophy encoded in TypeScript.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Repair pipeline.&lt;/strong&gt; If the app crashes mid-session, the repair pipeline detects orphaned events and fixes them automatically. The app always opens coherently regardless of what went wrong.&lt;/p&gt;

&lt;p&gt;Winston's pragmatism showed here. He pushed back on complexity where it wasn't needed, advocated for boring technology choices, and kept asking "what actually ships?"&lt;/p&gt;

&lt;h2&gt;
  
  
  Breaking it down: epics and stories
&lt;/h2&gt;

&lt;p&gt;Bob (Scrum Master) took the architecture and PRD and broke them into implementable chunks (&lt;code&gt;/bmad-create-epics-and-stories&lt;/code&gt;). Seven epics emerged:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;Project Foundation &amp;amp; Domain Core&lt;/strong&gt; - Monorepo structure, event types, aggregates, 100% test coverage gate&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;The Constellation Canvas&lt;/strong&gt; - Spatial todo interface, drag positioning, pan/zoom, keyboard navigation&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;The Pomodoro Session Loop&lt;/strong&gt; - Timer, session durability, resume/auto-complete on crash, exploration sessions&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;The Devotion Record&lt;/strong&gt; - Session history visualization, persistence across renames&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Todo Lifecycle &amp;amp; The Shelf&lt;/strong&gt; - Sealing, release ritual, eulogy for high-investment items, archive&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Production Storage &amp;amp; Data Durability&lt;/strong&gt; - SQLite migration, atomic writes, corruption tolerance, snapshots&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Settings &amp;amp; Personalisation&lt;/strong&gt; - Timer durations, themes, reduced-motion support&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;The sequencing mattered. Epic 1 had to complete with 100% domain coverage before any UI work began. This enforced the philosophy: get the core logic right first, then build the interface on a solid foundation.&lt;/p&gt;

&lt;p&gt;Each epic broke down into stories with clear acceptance criteria. Before implementation, Bob prepared the sprint plan (&lt;code&gt;/bmad-sprint-planning&lt;/code&gt;) and created detailed story files (&lt;code&gt;/bmad-create-story&lt;/code&gt;). By the time Amelia (Developer) started coding, she knew exactly what to build.&lt;/p&gt;

&lt;h2&gt;
  
  
  Implementation: where specs pay off
&lt;/h2&gt;

&lt;p&gt;This is where the earlier work paid dividends. Let me explain how the actual story workflow operates.&lt;/p&gt;

&lt;h3&gt;
  
  
  Preparing a story
&lt;/h3&gt;

&lt;p&gt;Before implementation begins, you run &lt;code&gt;/bmad-create-story&lt;/code&gt;. This doesn't just copy text from the epics file. It creates a comprehensive story document by:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Loading all your artifacts (PRD, architecture, UX specs, previous stories)&lt;/li&gt;
&lt;li&gt;Extracting everything relevant to this specific story&lt;/li&gt;
&lt;li&gt;Analyzing previous story files for patterns and learnings&lt;/li&gt;
&lt;li&gt;Checking git history for recent changes that might affect implementation&lt;/li&gt;
&lt;li&gt;Researching latest library versions if needed&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;The output is a story file that contains:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;User story statement&lt;/strong&gt; (As a... I want... so that...)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Acceptance criteria&lt;/strong&gt; in BDD format (Given/When/Then)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Tasks and subtasks&lt;/strong&gt; in exact implementation order&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Dev Notes&lt;/strong&gt; with architecture requirements, file locations, testing patterns&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Previous story intelligence&lt;/strong&gt; (what worked, what didn't, code patterns established)&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The goal is to give the developer agent everything it needs without having to search through other documents.&lt;/p&gt;

&lt;h3&gt;
  
  
  Refining stories with Party Mode
&lt;/h3&gt;

&lt;p&gt;Before handing a story to the developer, I run &lt;code&gt;/bmad-party-mode&lt;/code&gt; to refine it. I typically bring in Winston (Architect) and Quinn (QA) to review the story file together.&lt;/p&gt;

&lt;p&gt;They catch things the story creation missed:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Winston might notice an architectural constraint that needs explicit mention&lt;/li&gt;
&lt;li&gt;Quinn asks about edge cases that should be acceptance criteria&lt;/li&gt;
&lt;li&gt;Both push back if tasks are too vague or too large&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;This refinement step adds maybe 10 minutes per story, but it prevents hours of rework during implementation. The story that reaches Amelia has already survived cross-functional scrutiny.&lt;/p&gt;

&lt;h3&gt;
  
  
  Working the story
&lt;/h3&gt;

&lt;p&gt;When you run &lt;code&gt;/bmad-dev-story&lt;/code&gt;, Amelia (the Developer agent) follows a strict process:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Find and load the story.&lt;/strong&gt; She reads the complete story file and identifies the first incomplete task.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Mark in-progress.&lt;/strong&gt; The sprint status updates so you know what's being worked on.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Execute tasks in exact order.&lt;/strong&gt; This is critical: the tasks are sequenced deliberately, and she follows them as written. No skipping ahead, no reordering.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;Red-green-refactor for each task:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Write failing tests first (red)&lt;/li&gt;
&lt;li&gt;Implement minimal code to make tests pass (green)&lt;/li&gt;
&lt;li&gt;Refactor while keeping tests green&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Mark complete only when done.&lt;/strong&gt; A task checkbox only gets checked when tests actually exist and pass. No lying, no "I'll add tests later."&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Update the story file.&lt;/strong&gt; Each completed task gets logged with what was implemented, what files changed, and any decisions made.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;&lt;strong&gt;Continue until all tasks are done&lt;/strong&gt; or a blocking issue requires human input.&lt;/p&gt;&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Here's what a real task looked like:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Task: Session completion and devotion dots&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Acceptance criteria:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;When timer reaches zero, emit SessionCompleted event with actual duration&lt;/li&gt;
&lt;li&gt;Update Devotion Record projection with new session&lt;/li&gt;
&lt;li&gt;Display 6px amber dot on the todo card for each recorded Pomodoro&lt;/li&gt;
&lt;li&gt;Session under 60 seconds: abandon silently, no dot&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Amelia read this, wrote tests for each criterion, implemented until tests passed, then marked the task complete. The story file recorded exactly what happened.&lt;/p&gt;

&lt;h3&gt;
  
  
  Why this matters
&lt;/h3&gt;

&lt;p&gt;The strict process prevents the chaos I've seen in other AI coding workflows:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;No guessing.&lt;/strong&gt; The story file tells her exactly what to build.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;No skipping tests.&lt;/strong&gt; Red-green-refactor is enforced, not suggested.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;No mystery implementations.&lt;/strong&gt; The story file documents what was done.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;No "works on my machine."&lt;/strong&gt; Tests must pass before tasks complete.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;When Amelia finished a story, I could review the story file and see exactly what happened. The gap between "what I asked for" and "what I got" was minimal because the spec had done its job.&lt;/p&gt;

&lt;h3&gt;
  
  
  Code review after every story
&lt;/h3&gt;

&lt;p&gt;After each story implementation, I run &lt;code&gt;/bmad-code-review&lt;/code&gt;. This isn't optional for me, it's part of the workflow.&lt;/p&gt;

&lt;p&gt;The code review runs multiple analysis passes:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Looking for bugs and logic errors&lt;/li&gt;
&lt;li&gt;Checking edge cases that might have been missed&lt;/li&gt;
&lt;li&gt;Verifying the implementation matches the acceptance criteria&lt;/li&gt;
&lt;li&gt;Flagging code quality issues&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;If the review finds problems, they get added as follow-up tasks in the story file. Amelia addresses them before the story is marked complete.&lt;/p&gt;

&lt;p&gt;One tip from the BMAD documentation: run the code review with a different LLM than the one that implemented the story. Fresh eyes catch more issues.&lt;/p&gt;

&lt;p&gt;The implementation phase moved fast because the thinking had already been done.&lt;/p&gt;

&lt;h2&gt;
  
  
  What surprised me
&lt;/h2&gt;

&lt;p&gt;A few things I didn't expect:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The brainstorming session was the most valuable part.&lt;/strong&gt; I thought the dev work would be the main event. In hindsight, the conversation that turned "Pomodoro app" into "devotion mirror" was where the real value was created. Everything else was execution.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Specs prevented scope creep.&lt;/strong&gt; When I had ideas mid-implementation ("what if we added..."), the specs gave me a clear answer: does this serve the philosophy? Usually the answer was no, and I moved on instead of getting distracted.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The agents caught blind spots.&lt;/strong&gt; In Party Mode (&lt;code&gt;/bmad-party-mode&lt;/code&gt;), I had Winston and Quinn review the architecture together. Quinn immediately asked about timer accuracy across browser backgrounding (a real problem I hadn't considered). That became a specific requirement before any code was written.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Writing specs is thinking.&lt;/strong&gt; I used to view documentation as overhead. Now I see it as the actual work. The code is just the last step.&lt;/p&gt;

&lt;h2&gt;
  
  
  What didn't work perfectly
&lt;/h2&gt;

&lt;p&gt;BMAD isn't magic. A few rough edges:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The upfront investment feels slow.&lt;/strong&gt; When you're eager to code, spending hours on specs feels like procrastination. You have to trust the process. The payoff comes later, but it does come.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Some agent suggestions needed filtering.&lt;/strong&gt; The agents occasionally proposed features that conflicted with the philosophy I'd established. I had to stay vigilant and push back. The human is still the decision-maker.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The artifacts need maintenance.&lt;/strong&gt; When requirements changed mid-project, I had to update multiple documents. The chain of traceability is powerful but requires discipline.&lt;/p&gt;

&lt;h2&gt;
  
  
  The result
&lt;/h2&gt;

&lt;p&gt;TODOdoro exists. It's &lt;a href="https://github.com/basteez/TODOdoro" rel="noopener noreferrer"&gt;open source on GitHub&lt;/a&gt;, still a work in progress, and includes all the BMAD artifacts in the &lt;code&gt;_bmad-output&lt;/code&gt; folder if you want to see exactly what I've described.&lt;/p&gt;

&lt;p&gt;More importantly, it's something I actually use. The philosophy landed because I took the time to articulate it before writing code.&lt;/p&gt;

&lt;p&gt;That's the BMAD promise: not faster code, but better thinking. The code follows.&lt;/p&gt;

&lt;h2&gt;
  
  
  Try it yourself
&lt;/h2&gt;

&lt;p&gt;If this series has made you curious, here's how to start:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Install BMAD: &lt;code&gt;npx bmad-method install&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;Start with &lt;code&gt;/bmad-agent-pm&lt;/code&gt; and describe your idea&lt;/li&gt;
&lt;li&gt;Let John ask you uncomfortable questions&lt;/li&gt;
&lt;li&gt;See where it leads&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;You don't need a big project. Try it on something small. A software config. A CLI tool. Something you want to reproduce.&lt;/p&gt;

&lt;p&gt;The process will feel strange at first. You'll want to skip ahead. Don't.&lt;/p&gt;

&lt;p&gt;The thinking is the work. The code is just the last step.&lt;/p&gt;




&lt;p&gt;&lt;strong&gt;Resources:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="https://docs.bmad-method.org/" rel="noopener noreferrer"&gt;BMAD Method documentation&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://github.com/bmad-code-org/BMAD-METHOD" rel="noopener noreferrer"&gt;BMAD on GitHub&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://github.com/basteez/TODOdoro" rel="noopener noreferrer"&gt;TODOdoro on GitHub&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

</description>
      <category>ai</category>
      <category>productivity</category>
      <category>bmad</category>
      <category>specdrivendevelopment</category>
    </item>
    <item>
      <title>BMAD: meet the crew</title>
      <dc:creator>Tiziano Basile</dc:creator>
      <pubDate>Mon, 20 Apr 2026 06:00:00 +0000</pubDate>
      <link>https://dev.to/basteez/bmad-meet-the-crew-13f8</link>
      <guid>https://dev.to/basteez/bmad-meet-the-crew-13f8</guid>
      <description>&lt;p&gt;In the &lt;a href="https://dev.to/basteez/dont-be-mad-bmad-instead-3d4i"&gt;previous post&lt;/a&gt;, I talked about why I was skeptical of AI coding tools and how BMAD changed my perspective. The short version: it forces you to think before you code, and it keeps you in the driver's seat.&lt;/p&gt;

&lt;p&gt;But I glossed over the most distinctive part of the framework: the agents.&lt;/p&gt;

&lt;p&gt;BMAD isn't one AI assistant. It's a team of specialized personas, each with a distinct role, communication style, and area of expertise. When you work with BMAD, you're not just prompting a generic model. You're having conversations with characters who push back, ask questions, and hold you accountable to their domain.&lt;/p&gt;

&lt;p&gt;It sounds gimmicky. It's not.&lt;/p&gt;

&lt;h2&gt;
  
  
  Why personas matter
&lt;/h2&gt;

&lt;p&gt;The obvious answer is specialization. A product manager thinks differently than an architect. A QA engineer asks different questions than a UX designer. By splitting these roles into separate agents, BMAD ensures that each phase of development gets the attention it deserves.&lt;/p&gt;

&lt;p&gt;But there's a subtler benefit: context switching becomes intentional.&lt;/p&gt;

&lt;p&gt;When you invoke the Product Manager, you're not just asking for PRD help. You're stepping into a conversation about user needs, market positioning, and what problem you're actually solving. When you switch to the Architect, the entire frame shifts to technical constraints, scalability, and system design.&lt;/p&gt;

&lt;p&gt;This forced perspective-taking is surprisingly valuable. It's easy to skip straight to implementation when you're working alone. The agents won't let you. Each one guards their domain, and you have to satisfy them before moving forward.&lt;/p&gt;

&lt;h2&gt;
  
  
  Meet the crew
&lt;/h2&gt;

&lt;p&gt;BMAD's core team consists of nine agents. Each has a name, a personality, and a specific set of capabilities. Here's who you'll be working with:&lt;/p&gt;

&lt;h3&gt;
  
  
  John (Product Manager)
&lt;/h3&gt;

&lt;p&gt;John is a relentless questioner. His job is to figure out what you're actually building and why. He'll push you on user needs, challenge your assumptions, and refuse to let you start until you can articulate the problem clearly.&lt;/p&gt;

&lt;p&gt;His style is direct and data-sharp. He cuts through fluff to find what actually matters. If you come to him with a vague idea, expect to leave with a focused problem statement.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;What he does:&lt;/strong&gt; PRD creation, requirements discovery, epic and story generation, implementation readiness checks.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Command:&lt;/strong&gt; &lt;code&gt;/bmad-agent-pm&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;When to call him:&lt;/strong&gt; At the very beginning, when you have an idea but haven't defined what "done" looks like.&lt;/p&gt;

&lt;h3&gt;
  
  
  Mary (Business Analyst)
&lt;/h3&gt;

&lt;p&gt;Mary treats every business challenge like a treasure hunt. She's the one who digs into market research, competitive analysis, and domain expertise. Where John focuses on what to build, Mary focuses on the landscape you're building in.&lt;/p&gt;

&lt;p&gt;Her communication style is energetic and discovery-oriented. She gets excited when patterns emerge and uses frameworks (Porter's Five Forces, SWOT) naturally without making it feel academic.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;What she does:&lt;/strong&gt; Market research, competitive analysis, domain deep-dives, requirements elicitation.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Command:&lt;/strong&gt; &lt;code&gt;/bmad-agent-analyst&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;When to call her:&lt;/strong&gt; When you need to understand the space before committing to a direction.&lt;/p&gt;

&lt;h3&gt;
  
  
  Winston (Architect)
&lt;/h3&gt;

&lt;p&gt;Winston is the calm pragmatist. He balances "what could be" with "what should be," grounding every recommendation in real-world trade-offs. His expertise covers distributed systems, cloud infrastructure, and API design.&lt;/p&gt;

&lt;p&gt;He speaks in measured tones, always connecting technical decisions to business value. He'll advocate for boring technology over shiny new frameworks, because boring ships.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;What he does:&lt;/strong&gt; Technical architecture decisions, system design, scalability planning.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Command:&lt;/strong&gt; &lt;code&gt;/bmad-agent-architect&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;When to call him:&lt;/strong&gt; After the requirements are clear, when you need to decide how the pieces fit together.&lt;/p&gt;

&lt;h3&gt;
  
  
  Sally (UX Designer)
&lt;/h3&gt;

&lt;p&gt;Sally is an empathetic advocate who paints pictures with words. She tells user stories that make you feel the problem, not just understand it. Her focus is on genuine user needs, and she balances creativity with attention to edge cases.&lt;/p&gt;

&lt;p&gt;Her approach is simple: start simple, evolve through feedback. Every design decision should serve a real person.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;What she does:&lt;/strong&gt; UX planning, interaction design, experience strategy.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Command:&lt;/strong&gt; &lt;code&gt;/bmad-agent-ux-designer&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;When to call her:&lt;/strong&gt; When you need to think through how users will actually interact with what you're building.&lt;/p&gt;

&lt;h3&gt;
  
  
  Bob (Scrum Master)
&lt;/h3&gt;

&lt;p&gt;Bob is crisp and checklist-driven. Every word has a purpose, every requirement crystal clear. He has zero tolerance for ambiguity, which makes him invaluable for turning vague plans into actionable work.&lt;/p&gt;

&lt;p&gt;He's also a servant leader who genuinely enjoys discussing agile process and theory. If you want to debate sprint structures or story formats, he's your guy.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;What he does:&lt;/strong&gt; Sprint planning, story preparation, retrospectives, course correction when things go sideways.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Command:&lt;/strong&gt; &lt;code&gt;/bmad-agent-sm&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;When to call him:&lt;/strong&gt; When requirements are defined and you need to break them into implementable chunks.&lt;/p&gt;

&lt;h3&gt;
  
  
  Amelia (Developer)
&lt;/h3&gt;

&lt;p&gt;Amelia is ultra-precise. She speaks in file paths and acceptance criteria IDs. No fluff, all precision. Her job is to execute approved stories with strict adherence to the specs you've created.&lt;/p&gt;

&lt;p&gt;She's test-driven to the core. Every task gets tests before it's marked complete, and she won't proceed with failing tests. If you've done the specification work properly, Amelia turns it into working code without surprises.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;What she does:&lt;/strong&gt; Story implementation, code review, test-driven development.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Command:&lt;/strong&gt; &lt;code&gt;/bmad-agent-dev&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;When to call her:&lt;/strong&gt; When the spec is ready and it's time to write code.&lt;/p&gt;

&lt;h3&gt;
  
  
  Quinn (QA Engineer)
&lt;/h3&gt;

&lt;p&gt;Quinn is pragmatic and straightforward. Her philosophy is "ship it and iterate," focusing on getting test coverage fast without overthinking. She generates tests for existing features using standard framework patterns.&lt;/p&gt;

&lt;p&gt;She's the counterbalance to perfectionism. Coverage first, optimization later.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;What she does:&lt;/strong&gt; API and E2E test generation, test automation.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Command:&lt;/strong&gt; &lt;code&gt;/bmad-agent-qa&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;When to call her:&lt;/strong&gt; After implementation, when you need to verify that what you built actually works.&lt;/p&gt;

&lt;h3&gt;
  
  
  Paige (Tech Writer)
&lt;/h3&gt;

&lt;p&gt;Paige is a patient educator who explains complex concepts like teaching a friend. She transforms technical details into accessible, structured documentation, using analogies that make the complex simple.&lt;/p&gt;

&lt;p&gt;She's a master of clarity. Every word serves a purpose, and diagrams often speak louder than paragraphs.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;What she does:&lt;/strong&gt; Documentation, technical explanations, Mermaid diagrams, document validation.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Command:&lt;/strong&gt; &lt;code&gt;/bmad-agent-tech-writer&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;When to call her:&lt;/strong&gt; When you need to explain what you've built (to users, to teammates, or to your future self).&lt;/p&gt;

&lt;h3&gt;
  
  
  Barry (Quick Flow Solo Dev)
&lt;/h3&gt;

&lt;p&gt;Barry is the speedrunner. He handles "Quick Flow" (smaller tasks that don't need the full ceremony), moving from tech spec to implementation with ruthless efficiency.&lt;/p&gt;

&lt;p&gt;His style is direct and implementation-focused. Minimum bureaucracy, maximum results. If you have a well-defined small task, Barry gets it done.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;What he does:&lt;/strong&gt; Rapid spec-to-implementation for smaller tasks, code review.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Command:&lt;/strong&gt; &lt;code&gt;/bmad-agent-quick-flow-solo-dev&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;When to call him:&lt;/strong&gt; For bug fixes, small features, or tasks where the full workflow would be overkill.&lt;/p&gt;

&lt;h2&gt;
  
  
  The workflow: how agents hand off
&lt;/h2&gt;

&lt;p&gt;The agents aren't meant to be used in isolation. They form a pipeline:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;John&lt;/strong&gt; (PM) clarifies what you're building and creates the PRD&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Mary&lt;/strong&gt; (Analyst) provides market and domain context if needed&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Winston&lt;/strong&gt; (Architect) designs the technical approach&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Sally&lt;/strong&gt; (UX) plans the user experience&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Bob&lt;/strong&gt; (SM) breaks everything into stories and plans sprints&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Amelia&lt;/strong&gt; (Dev) implements the stories&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Quinn&lt;/strong&gt; (QA) verifies the implementation&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Paige&lt;/strong&gt; (Tech Writer) documents the result&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;You don't always need every step. A small bug fix might go straight to Barry. A well-understood feature might skip Mary's research phase. But for anything substantial, the handoffs matter.&lt;/p&gt;

&lt;p&gt;Each agent produces artifacts that the next agent consumes. John's PRD feeds Winston's architecture. Winston's architecture feeds Bob's stories. Bob's stories feed Amelia's implementation. The chain ensures that nothing gets lost in translation.&lt;/p&gt;

&lt;h2&gt;
  
  
  Party Mode: when agents collaborate
&lt;/h2&gt;

&lt;p&gt;Sometimes you need multiple perspectives at once. That's where Party Mode comes in.&lt;/p&gt;

&lt;p&gt;Party Mode (&lt;code&gt;/bmad-party-mode&lt;/code&gt;) lets you have a conversation with several agents simultaneously. You might be discussing a technical decision and want both Winston (Architect) and Quinn (QA) to weigh in. Or you're reviewing a PRD and want John, Sally, and Bob to debate the trade-offs.&lt;/p&gt;

&lt;p&gt;The agents stay in character, each bringing their own priorities and concerns. Winston might argue for a simpler architecture while Sally pushes for a richer user experience. Bob might point out that the current scope won't fit in a sprint. You moderate, listen to the perspectives, and make the call.&lt;/p&gt;

&lt;p&gt;It sounds like a gimmick. In practice, it's one of the most useful features for surfacing blind spots. Different roles genuinely do see different risks, and hearing them argue (politely) helps you make better decisions.&lt;/p&gt;

&lt;p&gt;Party Mode is particularly useful for refining artifacts you've already created. Got a PRD that feels incomplete? Throw it into a party with the PM, Architect, and UX Designer. They'll poke holes from their respective angles, and you'll walk away with a tighter spec. Same goes for architecture documents, story breakdowns, or anything else that benefits from cross-functional scrutiny. Refinement is where Party Mode really shines.&lt;/p&gt;

&lt;h2&gt;
  
  
  Choosing your path
&lt;/h2&gt;

&lt;p&gt;BMAD is flexible about how much ceremony you need:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Full workflow:&lt;/strong&gt; For new products or major features, start with John, work through the entire pipeline, and produce comprehensive specs before implementation. This is the safest path for anything complex.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Quick Flow:&lt;/strong&gt; For smaller tasks (bug fixes, minor features, well-understood changes), call Barry and move fast. He'll still push you to clarify intent and think through edge cases, but without the full artifact chain.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Mix and match:&lt;/strong&gt; Need architecture help but already have requirements? Call Winston directly. Want to validate a PRD you wrote yourself? John can review it. The agents are tools, not a rigid process.&lt;/p&gt;

&lt;p&gt;The key insight is that the structure exists to help you think, not to slow you down. Use as much as you need. Skip what doesn't serve you.&lt;/p&gt;

&lt;h2&gt;
  
  
  What's next
&lt;/h2&gt;

&lt;p&gt;In the final post of this series, I'll walk through a real project I built with BMAD: &lt;a href="https://github.com/basteez/TODOdoro" rel="noopener noreferrer"&gt;TODOdoro&lt;/a&gt;, a productivity app that combines todo management with the Pomodoro technique.&lt;/p&gt;

&lt;p&gt;I'll show how the process actually looked in practice: what questions John asked, what architecture Winston proposed, how the stories got structured, and where the agents surprised me (for better and worse).&lt;/p&gt;

&lt;p&gt;If you want to see BMAD in action rather than just described, that's the post for you.&lt;/p&gt;




&lt;p&gt;&lt;strong&gt;Resources:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="https://docs.bmad-method.org/" rel="noopener noreferrer"&gt;BMAD Method documentation&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://github.com/bmad-code-org/BMAD-METHOD" rel="noopener noreferrer"&gt;BMAD on GitHub&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://dev.to/basteez/dont-be-mad-bmad-instead-3d4i"&gt;Part 1: Don't be mad, BMAD instead&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

</description>
      <category>specdrivendevelopment</category>
      <category>bmad</category>
      <category>sdd</category>
      <category>ai</category>
    </item>
    <item>
      <title>Crossposting without the copy-paste: a GitHub Action from Hugo to dev.to</title>
      <dc:creator>Tiziano Basile</dc:creator>
      <pubDate>Sat, 18 Apr 2026 13:21:57 +0000</pubDate>
      <link>https://dev.to/basteez/crossposting-without-the-copy-paste-a-github-action-from-hugo-to-devto-52go</link>
      <guid>https://dev.to/basteez/crossposting-without-the-copy-paste-a-github-action-from-hugo-to-devto-52go</guid>
      <description>&lt;p&gt;My blog runs on Hugo. I also recently discovered I can cross-post to &lt;a href="https://dev.to"&gt;dev.to&lt;/a&gt;, because that's where a lot of the conversation actually happens. For a while, my workflow was the obvious one: write the post, publish it here, open dev.to, paste it in, fix the frontmatter, fix the links, hit publish.&lt;/p&gt;

&lt;p&gt;It worked. I also stopped doing it after the second post.&lt;/p&gt;

&lt;p&gt;Copy-paste friction is the kind of chore that silently kills a publishing habit. So I did what most developers do when a task becomes repetitive: I automated it. And then I kept refining the automation until it was worth giving away.&lt;/p&gt;

&lt;p&gt;The result is &lt;a href="https://github.com/basteez/hugo-to-devto-action" rel="noopener noreferrer"&gt;&lt;code&gt;basteez/hugo-to-devto-action&lt;/code&gt;&lt;/a&gt;, now &lt;a href="https://github.com/marketplace/actions/hugo-to-dev-to-crosspost" rel="noopener noreferrer"&gt;published on the GitHub Marketplace&lt;/a&gt;.&lt;/p&gt;

&lt;h2&gt;
  
  
  What it does
&lt;/h2&gt;

&lt;p&gt;It's a composite GitHub Action. On every push to your blog repo, it looks at what changed in the push range, finds new Hugo posts under your &lt;code&gt;content/post&lt;/code&gt; directory, and creates a corresponding &lt;strong&gt;draft&lt;/strong&gt; on dev.to for each one that is marked &lt;code&gt;draft: false&lt;/code&gt; locally.&lt;/p&gt;

&lt;p&gt;Key behaviours, chosen deliberately:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Drafts, not published posts.&lt;/strong&gt; The action never hits publish on dev.to for you. It mirrors content, but you stay in control of when it goes live on the other platform. This is intentional: dev.to has its own audience, its own timing, and its own editorial choices (cover image, tags, canonical URL). I want a starting point there&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Dedup by title.&lt;/strong&gt; Before creating a draft, the action queries your dev.to account and skips anything whose title already exists. That means you can safely re-run on any push without ending up with duplicates, and editing a post on dev.to directly doesn't get overwritten.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Push-range aware.&lt;/strong&gt; It uses &lt;code&gt;git diff&lt;/code&gt; across &lt;code&gt;github.event.before..github.event.after&lt;/code&gt; to find what actually changed, rather than scanning the whole repo every time. New posts get mirrored; edits to old posts don't trigger spurious drafts.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Stateless.&lt;/strong&gt; There is no database, no cache, no state file in your repo. dev.to is the source of truth for "does this already exist?" If you ever want to start fresh, you can.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Using it
&lt;/h2&gt;

&lt;p&gt;The minimum viable workflow is about fifteen lines:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight yaml"&gt;&lt;code&gt;&lt;span class="na"&gt;name&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;Crosspost to dev.to&lt;/span&gt;

&lt;span class="na"&gt;on&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;push&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
    &lt;span class="na"&gt;branches&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="pi"&gt;[&lt;/span&gt;&lt;span class="nv"&gt;main&lt;/span&gt;&lt;span class="pi"&gt;]&lt;/span&gt;

&lt;span class="na"&gt;permissions&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;contents&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;read&lt;/span&gt;

&lt;span class="na"&gt;jobs&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;crosspost&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
    &lt;span class="na"&gt;runs-on&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;ubuntu-latest&lt;/span&gt;
    &lt;span class="na"&gt;steps&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="na"&gt;uses&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;actions/checkout@v4&lt;/span&gt;
        &lt;span class="na"&gt;with&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
          &lt;span class="na"&gt;fetch-depth&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="m"&gt;0&lt;/span&gt;
      &lt;span class="pi"&gt;-&lt;/span&gt; &lt;span class="na"&gt;uses&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;basteez/hugo-to-devto-action@v1&lt;/span&gt;
        &lt;span class="na"&gt;with&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
          &lt;span class="na"&gt;devto-api-key&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;${{ secrets.DEVTO_API_KEY }}&lt;/span&gt;
          &lt;span class="na"&gt;before&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;${{ github.event.before }}&lt;/span&gt;
          &lt;span class="na"&gt;after&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;${{ github.event.after }}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Two things to watch for:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;&lt;code&gt;fetch-depth: 0&lt;/code&gt; is not optional.&lt;/strong&gt; The default shallow checkout doesn't contain the &lt;code&gt;before&lt;/code&gt; SHA of a real push, so &lt;code&gt;git diff&lt;/code&gt; has nothing to compare against. If you leave this out, the action will fail quickly and loudly. That failure mode is well understood; don't go hunting for a mysterious bug.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;&lt;code&gt;DEVTO_API_KEY&lt;/code&gt; lives in repo secrets.&lt;/strong&gt; Grab a Personal API Key from dev.to (Settings → Extensions → DEV Community API Keys) and add it as &lt;code&gt;DEVTO_API_KEY&lt;/code&gt; under your repo's secrets. The action forwards it into the child process; it's never logged.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;If your posts live somewhere other than &lt;code&gt;content/post&lt;/code&gt;, pass &lt;code&gt;post-dir:&lt;/code&gt; with the path. If you want to see what would happen without actually creating drafts, pass &lt;code&gt;dry-run: 'true'&lt;/code&gt;. That's the whole surface area.&lt;/p&gt;

&lt;h2&gt;
  
  
  A word on versioning
&lt;/h2&gt;

&lt;p&gt;I went with the GitHub convention of three pin styles:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;code&gt;@v1&lt;/code&gt; — a moving tag that tracks the latest non-breaking release. Bug fixes and additive features land automatically. This is what most people want.&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;@v1.x.y&lt;/code&gt; — a full semver pin if you need an immutable reference.&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;@&amp;lt;commit-sha&amp;gt;&lt;/code&gt; — a 40-character SHA for organisations that mandate commit-level pinning.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The &lt;code&gt;v1&lt;/code&gt; tag will &lt;strong&gt;never&lt;/strong&gt; be force-updated to a breaking release. Breaking changes bump to &lt;code&gt;@v2&lt;/code&gt;. That way, the convenient default is also the safe default.&lt;/p&gt;

&lt;h2&gt;
  
  
  Why bother extracting it
&lt;/h2&gt;

&lt;p&gt;This started life as a script in this blog's own repo. It worked fine there. Extracting it into a standalone action was more work than copy-pasting a script into other Hugo repos would have been.&lt;/p&gt;

&lt;p&gt;I did it anyway, for three reasons.&lt;/p&gt;

&lt;p&gt;First, &lt;strong&gt;separation of concerns.&lt;/strong&gt; The crosspost logic has nothing to do with my blog content. Keeping them in the same repo was mixing "what I publish" with "how I publish it," and every time I touched one, I had to reason about the other.&lt;/p&gt;

&lt;p&gt;Second, &lt;strong&gt;reuse.&lt;/strong&gt; I'm not the only person running a Hugo blog who'd like to mirror to dev.to. If the tool exists in a shareable form, other people can use it without forking my blog.&lt;/p&gt;

&lt;p&gt;Third, and this is the part I didn't expect, &lt;strong&gt;extraction forces clarity.&lt;/strong&gt; When code is hiding inside your own repo, you get to take a lot of context for granted. The directory layout, the branching model, the workflow triggers, the assumptions about what's already installed. Turning it into a public action meant writing all of that down as explicit inputs, documented defaults, and failure modes. The code ended up smaller and sharper.&lt;/p&gt;

&lt;p&gt;That last point keeps showing up in my work, and I think it's worth naming: the act of making something reusable is often more valuable for the original project than for anyone who'll reuse it.&lt;/p&gt;

&lt;h2&gt;
  
  
  What's next
&lt;/h2&gt;

&lt;p&gt;A few directions I'm considering, in rough priority order:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Optional publish mode, for people who genuinely do want one-click mirroring.&lt;/li&gt;
&lt;li&gt;Better handling of images and relative links, which is currently the biggest rough edge.&lt;/li&gt;
&lt;li&gt;Support for other destinations (Hashnode, Medium), though I'd rather keep this action focused and spin up siblings than turn it into a universal crossposter.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;If any of this is useful to you, grab it from the &lt;a href="https://github.com/marketplace/actions/hugo-to-dev-to-crosspost" rel="noopener noreferrer"&gt;Marketplace&lt;/a&gt; or reference it directly as &lt;code&gt;basteez/hugo-to-devto-action@v1&lt;/code&gt;. Bug reports and PRs are welcome on &lt;a href="https://github.com/basteez/hugo-to-devto-action" rel="noopener noreferrer"&gt;GitHub&lt;/a&gt;.&lt;/p&gt;

&lt;p&gt;And if this post shows up on my dev.to profile before I get around to publishing it there, you'll know the action works.&lt;/p&gt;

</description>
      <category>githubactions</category>
      <category>hugo</category>
      <category>devto</category>
    </item>
    <item>
      <title>How to Use SonarQube and SonarScanner Locally to Level Up Your Code Quality</title>
      <dc:creator>Tiziano Basile</dc:creator>
      <pubDate>Fri, 17 Apr 2026 17:35:03 +0000</pubDate>
      <link>https://dev.to/basteez/how-to-use-sonarqube-and-sonarscanner-locally-to-level-up-your-code-quality-4087</link>
      <guid>https://dev.to/basteez/how-to-use-sonarqube-and-sonarscanner-locally-to-level-up-your-code-quality-4087</guid>
      <description>&lt;p&gt;Code quality tools can make a huge difference in improving your coding skills by helping you identify code smells, bugs, and potential vulnerabilities. &lt;/p&gt;

&lt;p&gt;In this guide, we’ll explore how to set up &lt;strong&gt;SonarQube&lt;/strong&gt; and &lt;strong&gt;SonarScanner&lt;/strong&gt; locally. This allows you to analyze your code for potential improvements right on your machine.&lt;/p&gt;

&lt;h2&gt;
  
  
  Step 1: Setting Up SonarQube with Docker
&lt;/h2&gt;

&lt;p&gt;First, ensure you have Docker installed. With Docker, getting SonarQube up and running is straightforward:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;Pull the SonarQube image&lt;/strong&gt;:&lt;/p&gt;

&lt;p&gt;&lt;code&gt;docker pull sonarqube&lt;/code&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;Run SonarQube&lt;/strong&gt;:&lt;/p&gt;

&lt;p&gt;&lt;code&gt;docker run -d --name sonarqube -p 9000:9000 -p 9092:9092 sonarqube&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;This command runs SonarQube in the background, mapping port &lt;code&gt;9000&lt;/code&gt; (for the SonarQube web interface) and &lt;code&gt;9092&lt;/code&gt; (optional).&lt;/p&gt;
&lt;/li&gt;
&lt;/ol&gt;

&lt;h2&gt;
  
  
  Step 2: Accessing SonarQube
&lt;/h2&gt;

&lt;p&gt;With SonarQube running, open your browser and go to &lt;a href="http://localhost:9000" rel="noopener noreferrer"&gt;http://localhost:9000&lt;/a&gt;. Enter the default credentials:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Username&lt;/strong&gt;: &lt;code&gt;admin&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Password&lt;/strong&gt;: &lt;code&gt;admin&lt;/code&gt;
&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Once logged in, you will be prompted to change the default password.&lt;/p&gt;

&lt;h2&gt;
  
  
  Step 3: Generate an Authentication Token
&lt;/h2&gt;

&lt;p&gt;To allow SonarScanner to connect to SonarQube, you need to create an authentication token.&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Click the &lt;strong&gt;A&lt;/strong&gt; icon in the top-right corner and select &lt;strong&gt;My Account&lt;/strong&gt;.&lt;/li&gt;
&lt;li&gt;Navigate to the &lt;strong&gt;Security&lt;/strong&gt; tab and click &lt;strong&gt;Generate a token&lt;/strong&gt;.&lt;/li&gt;
&lt;li&gt;Name your token (it can be user-specific or global) and save it somewhere secure, as it will only be displayed once.&lt;/li&gt;
&lt;/ol&gt;

&lt;h2&gt;
  
  
  Step 4: Configure &lt;code&gt;sonar-project.properties&lt;/code&gt;
&lt;/h2&gt;

&lt;p&gt;Next, set up a configuration file to define key project properties SonarQube will use to analyze your code. In the root directory of your project, create a file named &lt;code&gt;sonar-project.properties&lt;/code&gt; and add the following content:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight yaml"&gt;&lt;code&gt;&lt;span class="s"&gt;sonar.projectKey=my:project&lt;/span&gt; &lt;span class="c1"&gt;# Must be unique &lt;/span&gt;
&lt;span class="s"&gt;sonar.projectName=my project name&lt;/span&gt; 
&lt;span class="s"&gt;sonar.projectVersion=1.0 sonar.sources=src/main/java&lt;/span&gt; &lt;span class="c1"&gt;# Adjust based on your source directory &lt;/span&gt;
&lt;span class="s"&gt;sonar.java.binaries=target/classes&lt;/span&gt;  &lt;span class="c1"&gt;# Adjust based on your compiled classes &lt;/span&gt;
&lt;span class="s"&gt;sonar.tests=src/test/java&lt;/span&gt; &lt;span class="c1"&gt;# Adjust based on your test directory&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;This configuration file tells SonarQube about the structure and setup of your project.&lt;/p&gt;

&lt;h2&gt;
  
  
  Step 5: Run SonarScanner
&lt;/h2&gt;

&lt;p&gt;With everything set up, it’s time to analyze your project. Open a terminal at the root of your project and execute the following command:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;mvn clean &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="o"&gt;&amp;amp;&amp;amp;&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
mvn dependency:copy-dependencies &lt;span class="o"&gt;&amp;amp;&amp;amp;&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
docker run &lt;span class="se"&gt;\&lt;/span&gt;
    &lt;span class="nt"&gt;--rm&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
    &lt;span class="nt"&gt;--network&lt;/span&gt; host &lt;span class="se"&gt;\&lt;/span&gt;
    &lt;span class="nt"&gt;-e&lt;/span&gt; &lt;span class="nv"&gt;SONAR_HOST_URL&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"http://{YOUR LOCAL IP}:9000"&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
    &lt;span class="nt"&gt;-e&lt;/span&gt; &lt;span class="nv"&gt;SONAR_TOKEN&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="s2"&gt;"{YOUR SONARQUBE TOKEN}"&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
    &lt;span class="nt"&gt;-v&lt;/span&gt; &lt;span class="s2"&gt;"&lt;/span&gt;&lt;span class="si"&gt;$(&lt;/span&gt;&lt;span class="nb"&gt;pwd&lt;/span&gt;&lt;span class="si"&gt;)&lt;/span&gt;&lt;span class="s2"&gt;:/usr/src"&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
    sonarsource/sonar-scanner-cli

&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;This command does the following:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Cleans and builds your project using Maven (&lt;code&gt;mvn clean install&lt;/code&gt;).&lt;/li&gt;
&lt;li&gt;Copies dependencies needed for analysis.&lt;/li&gt;
&lt;li&gt;Runs SonarScanner in a Docker container and connects it to your local SonarQube instance.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Replace &lt;code&gt;{YOUR LOCAL IP}&lt;/code&gt; with your machine’s local IP address and &lt;code&gt;{YOUR SONARQUBE TOKEN}&lt;/code&gt; with the token you generated in Step 4.&lt;/p&gt;

&lt;h2&gt;
  
  
  Step 6: Review the Analysis Results in SonarQube
&lt;/h2&gt;

&lt;p&gt;Once SonarScanner completes its run, return to &lt;a href="http://localhost:9000" rel="noopener noreferrer"&gt;http://localhost:9000&lt;/a&gt; and navigate to your project dashboard. Here, you’ll see a detailed report on:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Code smells&lt;/strong&gt;: Areas of the codebase that could benefit from refactoring.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Bugs&lt;/strong&gt;: Logical errors or anomalies in the code.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Vulnerabilities&lt;/strong&gt;: Security-related issues.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Conclusion
&lt;/h2&gt;

&lt;p&gt;Setting up SonarQube and SonarScanner locally allows you to take your code quality analysis into your own hands. Regularly reviewing these reports can help you develop better habits, improve your understanding of code quality principles, and ultimately level up your coding skills.&lt;/p&gt;

</description>
      <category>devops</category>
      <category>docker</category>
      <category>sonarqube</category>
    </item>
    <item>
      <title>Don't be mad, BMAD instead</title>
      <dc:creator>Tiziano Basile</dc:creator>
      <pubDate>Fri, 17 Apr 2026 10:06:47 +0000</pubDate>
      <link>https://dev.to/basteez/dont-be-mad-bmad-instead-3d4i</link>
      <guid>https://dev.to/basteez/dont-be-mad-bmad-instead-3d4i</guid>
      <description>&lt;p&gt;A few weeks ago I wrote about the tension I felt using AI coding tools, the fear that by outsourcing the friction, I was also outsourcing my competence. That piece ended with a question: are you extending yourself, or outsourcing yourself?&lt;/p&gt;

&lt;p&gt;I didn't have a clean answer then. I still don't have a universal one. But I found something that changed how I think about the problem.&lt;/p&gt;

&lt;h2&gt;
  
  
  The grave I thought I was digging
&lt;/h2&gt;

&lt;p&gt;When a colleague first mentioned BMAD, my reaction was skepticism dressed as caution. Another AI framework. Another promise that the machine will handle it. My concern wasn't that it wouldn't work, it was that it would work too well, and I'd wake up one day having forgotten how to build things myself.&lt;/p&gt;

&lt;p&gt;That fear isn't irrational. I've seen what happens when you reach for autocomplete before you've finished the thought. You produce, but you don't learn. The output looks fine, but the map never forms. You become dependent on a system you can't fully reason about, and every time you hit a similar problem, you prompt again instead of drawing from understanding.&lt;/p&gt;

&lt;p&gt;So when someone told me "try this method where AI agents play different roles," I heard: more ways to stop thinking. More automation. More distance between me and the craft I'd spent years developing.&lt;/p&gt;

&lt;p&gt;I was wrong. But it took some hands-on experimentation to see why.&lt;/p&gt;

&lt;h2&gt;
  
  
  The problem with vibe coding
&lt;/h2&gt;

&lt;p&gt;Before I explain what BMAD does differently, let me describe what it's pushing against.&lt;/p&gt;

&lt;p&gt;There's a pattern that's become disturbingly common, often celebrated even, that I'll call "vibe coding." It goes like this: you have a rough idea of what you want to build. You open your editor, write a prompt, and let the AI generate something. If it looks mostly right, you keep it. If it doesn't work, you prompt again with a correction. You iterate like this, adjusting and regenerating, until the output seems functional.&lt;/p&gt;

&lt;p&gt;I've always hated this approach. It treats software development like a slot machine: pull the lever, see what comes out, try again if you don't like it.&lt;/p&gt;

&lt;p&gt;But here's what's actually happening: you're making decisions without articulating them. You're accepting code without fully understanding it. You're building something that works (maybe) without building a mental model of why it works. The AI is filling in gaps you never consciously identified, which means you can't evaluate whether it filled them correctly.&lt;/p&gt;

&lt;p&gt;Vibe coding optimizes for output. It feels efficient in the moment. But it produces fragile results, because no one (not you, not the AI) ever defined what "correct" actually means. When something breaks later, you're debugging a system you never fully understood in the first place.&lt;/p&gt;

&lt;p&gt;This isn't a problem with AI. It's a problem with how we use it. And it's the problem that spec-driven development solves.&lt;/p&gt;

&lt;h2&gt;
  
  
  What spec-driven development actually means
&lt;/h2&gt;

&lt;p&gt;If you haven't encountered the term before, spec-driven development is exactly what it sounds like: you write the specification before you write the code.&lt;/p&gt;

&lt;p&gt;That might seem obvious. "Of course you should know what you're building before you build it." But there's a difference between having a vague idea in your head and having a written document that defines requirements, constraints, acceptance criteria, and architectural decisions.&lt;/p&gt;

&lt;p&gt;The spec isn't just documentation. It's a thinking tool. The act of writing it forces you to confront questions you might otherwise skip: What exactly is this feature supposed to do? What happens at the edges? How does this component interact with that one? What does "done" look like?&lt;/p&gt;

&lt;p&gt;When you answer these questions upfront, implementation becomes a translation exercise. You're not discovering the requirements as you code. You're executing a plan you've already validated. The code follows from decisions you consciously made, not from guesses the AI filled in for you.&lt;/p&gt;

&lt;p&gt;This is the opposite of vibe coding. Instead of iterating toward something that seems to work, you define what "working" means first, then build to that definition.&lt;/p&gt;

&lt;p&gt;The challenge, of course, is that writing good specs is hard. It requires discipline, experience, and (honestly) a fair amount of tedium. Which is exactly where BMAD comes in.&lt;/p&gt;

&lt;h2&gt;
  
  
  What BMAD actually is
&lt;/h2&gt;

&lt;p&gt;BMAD stands for "Build More Architect Dreams." It's an open-source framework that uses AI agents to guide you through a structured development process, from initial idea through implementation.&lt;/p&gt;

&lt;p&gt;But here's the crucial part: BMAD doesn't generate code and call it done. It forces you through the specification process first.&lt;/p&gt;

&lt;p&gt;The framework includes multiple specialized agents, each with a distinct role:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;A &lt;strong&gt;Product Manager&lt;/strong&gt; who helps you clarify what you're building and why&lt;/li&gt;
&lt;li&gt;A &lt;strong&gt;Business Analyst&lt;/strong&gt; who digs into requirements and edge cases&lt;/li&gt;
&lt;li&gt;An &lt;strong&gt;Architect&lt;/strong&gt; who designs how components will fit together&lt;/li&gt;
&lt;li&gt;A &lt;strong&gt;Developer&lt;/strong&gt; who implements based on the specs you've created&lt;/li&gt;
&lt;li&gt;A &lt;strong&gt;QA Engineer&lt;/strong&gt; who defines how you'll verify the implementation works&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Each agent asks questions. Each one pushes you to articulate something specific before you move forward. You can't skip to the code, because the developer agent won't have what it needs until the earlier stages are complete.&lt;/p&gt;

&lt;p&gt;This structure is the key insight. The AI isn't doing the thinking for you. It's holding you accountable to a process that requires thinking. The agents are collaborators, not replacements. They augment your capability to do the specification work, but the decisions remain yours.&lt;/p&gt;

&lt;h2&gt;
  
  
  Why this feels different
&lt;/h2&gt;

&lt;p&gt;Most AI coding tools are optimized for a simple interaction: you prompt, you get code. The faster and more accurate that loop, the better the tool seems.&lt;/p&gt;

&lt;p&gt;BMAD optimizes for something else: the quality of your thinking before code exists.&lt;/p&gt;

&lt;p&gt;When I started experimenting with it, I chose deliberately small tasks. An Emacs configuration I'd been putting off. A bug I wanted to reproduce in isolation before fixing. Low stakes, easy to abandon if it felt like hype.&lt;/p&gt;

&lt;p&gt;What surprised me wasn't the speed. It was the structure.&lt;/p&gt;

&lt;p&gt;Working with the Product Manager agent, I had to articulate what I actually wanted (not just "fix this bug," but what specific behavior should change, and why, and how I'd know it was fixed). Working with the Architect, I had to think about how my change would interact with existing code. Working with the QA persona, I had to define acceptance criteria before implementation.&lt;/p&gt;

&lt;p&gt;By the time I reached the Developer agent, I wasn't prompting and hoping. I was handing over a spec that I understood, because I'd helped build it. The implementation felt like execution, not experimentation.&lt;/p&gt;

&lt;p&gt;And here's what I didn't expect: that constraint is liberating. The process felt slower at first (more steps, more questions, more writing). But I wasn't backtracking. I wasn't debugging code I didn't understand. I wasn't prompting the same thing five different ways hoping for a better result.&lt;/p&gt;

&lt;p&gt;The spec had done its job. The thinking was front-loaded, where it belongs.&lt;/p&gt;

&lt;h2&gt;
  
  
  Orchestrator, not passenger
&lt;/h2&gt;

&lt;p&gt;The shift I described in my earlier post, from active thinker to passive prompter, doesn't happen with BMAD. It can't. The method requires you to validate, decide, and course-correct at every stage.&lt;/p&gt;

&lt;p&gt;The AI handles the grunt work: generating document templates, suggesting architectural patterns, writing implementation code that follows the spec. But you're still the one reviewing, adjusting, and approving. You're still the one who understands why the system is designed the way it is.&lt;/p&gt;

&lt;p&gt;That's the answer I was looking for. Not "don't use AI," but "use it in a way that keeps you in the driver's seat."&lt;/p&gt;

&lt;p&gt;I delegate the dirty work. I orchestrate. I stay in the loop.&lt;/p&gt;

&lt;p&gt;The mental model I keep coming back to is this: BMAD turns AI into a team of junior collaborators who are fast and capable, but who need direction. You're the senior engineer. You set the vision, define the constraints, and make the judgment calls. They execute, and they execute well, but only because you've told them what "well" means.&lt;/p&gt;

&lt;p&gt;That's extending yourself. That's the version of AI assistance I was hoping existed.&lt;/p&gt;

&lt;h2&gt;
  
  
  The dopamine is real (and so is the fun)
&lt;/h2&gt;

&lt;p&gt;I should mention something else: this process is genuinely enjoyable.&lt;/p&gt;

&lt;p&gt;There's a particular satisfaction in watching a well-defined spec turn into working code without surprises. The gap between "what I wanted" and "what I got" shrinks dramatically when you've done the specification work upfront.&lt;/p&gt;

&lt;p&gt;And (I didn't expect this) role-playing with the different personas is fun. Switching from the PM mindset to the Architect mindset to the Developer mindset keeps the work varied. You're not just grinding through one mode of thinking. You're shifting perspectives, which keeps you engaged.&lt;/p&gt;

&lt;p&gt;BMAD even has something called "Party Mode" where multiple agents can participate in a single conversation, debating approaches and surfacing trade-offs. It sounds gimmicky until you try it. Having the Architect and QA agents push back on each other while you moderate is surprisingly useful for finding blind spots.&lt;/p&gt;

&lt;h2&gt;
  
  
  What's next
&lt;/h2&gt;

&lt;p&gt;This is the first in a series of three posts.&lt;/p&gt;

&lt;p&gt;In the next one, I'll go deeper on the agents themselves: who they are, what each one does, how they hand off work to each other, and how you can customize the process for your own workflow.&lt;/p&gt;

&lt;p&gt;In the third post, I'll walk through a real project I built using BMAD: a productivity app called &lt;a href="https://github.com/basteez/TODOdoro" rel="noopener noreferrer"&gt;TODOdoro&lt;/a&gt;. It combines todo management with the Pomodoro technique, and I'll show how the method helped me go from a philosophical idea ("a mirror, not a manager") to a working application with a clear architecture.&lt;/p&gt;

&lt;p&gt;If you've felt the same tension I did, excited by AI's potential but worried about what you might lose, this might be worth following. BMAD isn't the only answer, but it's an answer. And for me, it's been the difference between feeling like AI is happening to me and feeling like I'm using it deliberately.&lt;/p&gt;

&lt;p&gt;The tools are getting more powerful every month. The question isn't whether to use them. It's whether you'll use them in a way that makes you better, or in a way that quietly makes you less than you were.&lt;/p&gt;

&lt;p&gt;I know which one I'm choosing.&lt;/p&gt;




&lt;p&gt;&lt;strong&gt;Resources:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="https://docs.bmad-method.org/" rel="noopener noreferrer"&gt;BMAD Method documentation&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://github.com/bmad-code-org/BMAD-METHOD" rel="noopener noreferrer"&gt;BMAD on GitHub&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

</description>
      <category>specdrivendevelopment</category>
      <category>sdd</category>
      <category>bmad</category>
      <category>ai</category>
    </item>
  </channel>
</rss>
