refactor: Remove error returns from ui.* functions#1980
Conversation
* feat: Add experimental feature transparency and version tracking Add transparency about feature maturity by introducing an <Experimental /> badge component and <FirstReleased /> version component for documentation. Create an "Experimental Features" policy page explaining what experimental means, graduation criteria, and how to provide feedback. Mark 11 experimental features across the documentation. 🤖 Generated with Claude Code Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com> * docs: Clarify experimental features may have unimplemented functionality Update the experimental features policy to accurately reflect that: - Features may not be fully functional yet - Documented functionality may not yet be implemented - Full functionality is guaranteed when experimental annotation is removed 🤖 Generated with Claude Code Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com> * docs: Clarify experimental features are intended to graduate to stable Experimental features are on the path to stability, not abandonment. Removal would only occur in extreme circumstances. 🤖 Generated with Claude Code Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com> * feat: Add comprehensive experimental feature visibility across surfaces - Add ui.Experimental() toast function for CLI notifications - Add experimental_warnings config option (default: true) - Add experimental badge to roadmap milestones and featured cards - Add ExperimentalFeaturesList component for /experimental page - Add experimental tag support in changelog timeline - Move experimental-features.mdx to /experimental with dynamic content - Add "Experimental Features" link to roadmap page - Mark experimental features in roadmap.js with experimental: true - Use subtle gray color for experimental notifications 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * feat: Log debug message when experimental warnings disabled When experimental_warnings is set to false, still log a debug message indicating that an experimental feature is being used. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * feat: Add EXPERIMENTAL badge to CLI help output - Add reusable ui.Badge() function for styled terminal badges - Show EXPERIMENTAL badge at top of experimental command --help - Show EXPERIMENTAL badge next to experimental subcommands in parent help - Skip badge on subcommands when parent is already experimental (avoid repetition) - Mark list affected subcommand as experimental - Group experimental features by initiative on website - Add "Help Us Prioritize" CTA section to experimental features page - Add sentinel errors for experimental command handling 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Improve Experimental badge WCAG AA accessibility - Use darker orange shades for light theme text (#d97706, #b45309) to meet WCAG AA 4.5:1 contrast requirement for small text - Add focus-visible styles for keyboard navigation accessibility - Dark theme already meets contrast requirements 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Mark toolchain command as experimental to match roadmap The roadmap marks toolchain as experimental but the command provider returned false for IsExperimental(). Now aligned with roadmap. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * feat: Mark terraform backend command as experimental Per roadmap, automatic backend provisioning is experimental. Added annotation to terraform backend subcommand. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address CodeRabbit review feedback - Add color support check to Badge method for graceful degradation - Update experimental features docs table with all experimental commands - Fix ChangelogTimeline tagExperimental contrast for WCAG AA compliance 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * feat: Mark terraform workdir command as experimental Mark the terraform workdir command as experimental to match the roadmap configuration. Also add workdir management to the experimental features documentation table. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Regenerate snapshots for experimental setting Update golden snapshots to include the new `experimental: warn` setting in describe config output. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Add blog post and roadmap entry for experimental feature controls Add blog post announcing the experimental feature flag (`settings.experimental`) that provides granular control over experimental features with CLI badges, configurable modes (warn, silence, disable, error), and environment variable support. Add milestone to Developer Experience roadmap tracking this feature. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * refactor: Use theme colors for experimental badge Replace hardcoded hex colors (#FF9800, #000000) with theme-aware colors from the color scheme. This ensures the experimental badge respects the user's terminal theme settings. Changes: - Add ExperimentalBadgeBg and ExperimentalBadgeFg to ColorScheme - Add ExperimentalBadge lipgloss.Style to StyleSet - Update FormatExperimentalBadge() to use theme styles - Update help_template.go to use FormatExperimentalBadge() 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Show experimental warning for annotation-based experimental commands The findExperimentalParent function was only checking the command registry for experimental status, which missed subcommands marked with annotations like "list affected", "terraform backend", and "terraform workdir". Now also checks the cobra command's annotations for experimental status. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * refactor: Simplify experimental feature message Change experimental warning from verbose feature-specific message to simple "Experimental feature. Learn more <link>" with muted gray styling. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Update experimental feature example output Update example output in docs to match the new simpler message format with test tube emoji and direct link to settings documentation. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Use correct /experimental URL in experimental feature message The experimental warning should link to /experimental (the overview page explaining what experimental features are) not the settings documentation. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Add link to /experimental from settings documentation Link the settings.experimental documentation page to the main /experimental page which explains what experimental means. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Add CLI configuration section to /experimental page Add section explaining how to control experimental feature behavior via settings.experimental in atmos.yaml or ATMOS_EXPERIMENTAL env var. Links to detailed settings documentation. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Move experimental features list after "What Experimental Means" section Reorganizes the /experimental page to show the list of current experimental features earlier, immediately after explaining what experimental means. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Update Slack links and add experimental docs to flag-handler agent - Update Slack links to use /community/slack instead of external URL - Add experimental feature handling documentation to flag-handler agent - Add experimental-related keywords to agent auto-invoke triggers 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Fix stacks sidebar sorting and improve Experimental badge Stacks sidebar: - Remove sidebar_position from all stacks docs to enable alphabetical sorting - Keep position 1 on stacks.mdx (Overview) to ensure it stays first - Remove position from components and settings category JSON files Experimental badge component: - Replace UTF-8 emoji with RiFlaskLine from react-icons - Remove "Learn more" link - whole badge is now clickable - Make badge behave like a button with hover/focus states 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Fix toolchain label capitalization in CLI configuration Change "Toolchain" to "toolchain" to match the lowercase convention used by other CLI configuration sections (settings, stacks, integrations, version). 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Fix toolchain subsection label capitalization Change sidebar labels to lowercase to match the convention: - Overview -> toolchain - Registries -> registries - Aliases -> aliases 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Fix Registry label capitalization in toolchain commands Change "Registry" to "registry" to match lowercase convention. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * refactor: Reduce flag-handler agent file size to meet limit Consolidate duplicate Resources and Relevant PRDs sections into one compact section. Condense verbose Self-Maintenance documentation while preserving key monitoring guidance. File reduced from 25712 to 23265 bytes (under 25000 limit). 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Regenerate CLI help snapshots Update golden snapshots for atmos --help output to reflect current command list and ordering. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Regenerate snapshots for experimental settings Update golden snapshots to include: - settings.experimental: warn default value in describe config output - [EXPERIMENTAL] badges on terraform backend and workdir commands 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * feat(website): Add automatic 'Unreleased' badge for documentation pages Add a new doc-release-data plugin that automatically detects which documentation pages have changes not yet included in a release. When a doc's last-modified commit is not in any stable release tag, an "Unreleased" badge appears in the TOC sidebar. Changes: - Add doc-release-data plugin that scans docs and checks git history - Extract shared ReleaseBadge component for reuse - Add DocReleaseBadge component that reads from plugin global data - Extend TOC component to render badges for both blog and doc pages - Update styles to make unreleased badges clickable (links to /changelog) The badge only appears for unreleased docs - released docs show no badge to keep the UI clean. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * style(website): Update Unreleased badge to match Experimental style Change the Unreleased badge from solid gray to a subtle semi-transparent style with border, matching the Experimental badge pattern. This provides a more consistent visual language across badge types. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * feat(website): Add /unreleased page with index of unreleased documentation Add a dedicated page at atmos.tools/unreleased that: - Explains what "unreleased" means (content not yet in a formal release) - Lists all documentation pages with unreleased changes - Shows the build date so users know when the list was generated - Links to changelog, releases, and community resources Changes: - Create UnreleasedDocsList component that reads from plugin global data - Create /unreleased page with explanation and auto-generated list - Update doc-release-data plugin to export unreleasedDocs array with title, path, and description for each unreleased doc - Fix URL path computation to handle Docusaurus id/slug conventions - Update ReleaseBadge to link to /unreleased instead of /changelog 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * feat(website): Add confetti celebration when all docs are released When visiting /unreleased and all documentation is up to date with the latest release, show a celebration state with: - Confetti animation on first page load (using canvas-confetti) - Celebratory message "All caught up!" - Links to changelog and GitHub releases - Build date showing when the check was last performed This provides positive feedback to users who check the page and find everything is current. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Add missing descriptions to terraform command docs Add description frontmatter to docs that were missing it: - atmos terraform clean - atmos terraform generate files - atmos terraform output - Using Remote State (redirect page) These descriptions now appear in the /unreleased page list. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix(website): Address CodeRabbit review feedback for unreleased badges - Fix React hooks violation in UnreleasedDocsList by calling usePluginData unconditionally and checking return value instead of using try-catch - Fix React hooks violation in DocReleaseBadge using same pattern - Add /roadmap to NON_DOC_PATHS to prevent showing unreleased badge on roadmap page (which is not a documentation page) - Add color to transition property for smooth hover color changes 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Regenerate CLI help snapshots for experimental features Update terraform command help snapshots to reflect new column widths and [EXPERIMENTAL] badges added to backend, workdir, and source subcommands. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs(roadmap): Add PR number to experimental feature controls milestone 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Add tests to increase code coverage Add tests for: - cmd/toolchain/du.go: DuCommandProvider methods (GetCommand, GetName, GetGroup, GetFlagsBuilder, GetPositionalArgsBuilder, GetCompatibilityFlags, GetAliases, IsExperimental) - pkg/ui/formatter.go: Reset, SetColorProfile, Hint, Hintf, Experimental, Experimentalf, Badge, FormatExperimentalBadge, ClearLine Coverage improvements: - pkg/ui: 73.1% → 87.8% - cmd/toolchain/du.go: 0% → covered 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Add comprehensive tests for root.go and help_template.go Add tests to improve patch coverage: - TestConvertToTermenvProfile: Test terminal color profile conversion - TestFindExperimentalParent: Test experimental command detection - TestParseUseVersionFromArgsInternal: Test --use-version parsing - TestBuildFlagDescription: Test flag description generation - TestRenderWrappedLines: Test wrapped line rendering - TestSyncGlobalFlagsToViper: Test viper flag synchronization - TestConfigureEarlyColorProfile: Test early color profile setup - TestFindProviderName: Test command hierarchy traversal - TestRenderCompatFlags: Test compatibility flag rendering - TestPrintCompatibilityFlags: Test compat flags section - TestPrintFooterWithSubcommands: Test footer display - TestSetRendererProfileForAutoDetect: Test all color profiles - TestCalculateCommandWidthWithExperimental: Test badge width - TestGetExperimentalBadge: Test badge generation 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Add more tests to increase patch coverage Add comprehensive tests to improve coverage from 69.5% toward 75%: cmd/root_helpers_test.go: - TestFormatFlagNameParts: Test flag name formatting for bool/string/int/stringSlice - TestGetTerminalWidth: Test terminal width detection with fallback - TestCalculateMaxFlagWidth: Test flag width calculation excluding hidden flags - TestRenderFlags: Test flag rendering with styles - TestRenderFlagsNilFlagSet: Test nil flag set handling pkg/ui/formatter_test.go: - TestConfigureColorProfileAllProfiles: Test all 4 color profiles - TestFormatterHintMethod/Hintf/Toast/Toastf: Test formatter methods - TestFormatterBold/Muted/Heading/Label: Test text formatting methods - TestFormatterHintWithBackticks: Test inline markdown in hints 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Add coverage tests for pkg/ui/formatter fallback and error paths Add tests for uncovered code paths in formatter.go: - Experimental/Experimentalf error paths when formatter not initialized - Badge error fallback when formatter not initialized - FormatExperimentalBadge no-color and error paths - ClearLine terminal not initialized and color profile branches - Formatter method tests for Experimentalf, Badge, and Experimental Coverage improved from 89.9% to 90.5% for pkg/ui package. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Add coverage for experimental command mode switch cases Add TestExperimentalModeHandling to test all four experimental modes: - "silence" - no output or exit - "disable" - command disabled with exit - "warn" - warning shown but no exit - "error" - warning and exit This increases test coverage for root.go lines 497-520. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix(roadmap): correct experimental feature controls status to in-progress PR #1940 is still open, so the milestone should not be marked as shipped. Updated dx initiative progress from 92% to 88% to reflect accurate count. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: regenerate snapshots for experimental feature changes Update golden snapshots to include: - New `experimental: warn` setting in describe config output - [EXPERIMENTAL] badges on terraform subcommands Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: regenerate terraform --help snapshot Update golden snapshot for [EXPERIMENTAL] badges on subcommands. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Regenerate snapshots for experimental badges Update golden snapshots to include [EXPERIMENTAL] badges for: - atmos toolchain - atmos devcontainer - atmos terraform backend - atmos terraform workdir The experimental feature controls PR added visual badges to help output, requiring snapshot updates. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * - PRD environment variable fixed (ATMOS_EXPERIMENTAL) - PRD experimental commands list updated - PRD subcommand-level section updated - Documentation error messages match actual output - Experimental() function now includes feature name - findExperimentalParent() returns correct parent names - Toolchain command calls parent's PersistentPreRun * add tests --------- Co-authored-by: Claude Haiku 4.5 <noreply@anthropic.com> Co-authored-by: Andriy Knysh <aknysh@users.noreply.github.com> Co-authored-by: aknysh <andriy.knysh@gmail.com>
|
Warning This PR exceeds the recommended limit of 1,000 lines.Large PRs are difficult to review and may be rejected due to their size. Please verify that this PR does not address multiple issues. |
|
💥 This pull request now has conflicts. Could you fix it @osterman? 🙏 |
|
Important Cloud Posse Engineering Team Review RequiredThis pull request modifies files that require Cloud Posse's review. Please be patient, and a core maintainer will review your changes. To expedite this process, reach out to us on Slack in the |
Resolved conflicts in: - cmd/root.go: Keep ui.Experimental() calls without error assignment - pkg/ui/formatter.go: Remove duplicate Experimental/Experimentalf functions - pkg/ui/formatter_test.go: Update ClearLine tests for no-error-return API Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
📝 WalkthroughWalkthroughThe PR converts core UI output functions to void (removing error returns) and updates ~60+ call sites to stop assigning discarded return values, replacing Changes
Sequence Diagram(s)(omitted) Estimated code review effort🎯 4 (Complex) | ⏱️ ~45 minutes Possibly related PRs
Suggested labels
Suggested reviewers
🚥 Pre-merge checks | ✅ 2 | ❌ 1❌ Failed checks (1 warning)
✅ Passed checks (2 passed)
✏️ Tip: You can configure your own custom pre-merge checks in the settings. ✨ Finishing touches
🧪 Generate unit tests (beta)
Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out. Comment |
Dependency Review✅ No vulnerabilities or license issues found.Scanned Files
|
Codecov Report❌ Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #1980 +/- ##
==========================================
- Coverage 74.75% 74.72% -0.03%
==========================================
Files 777 777
Lines 71176 71213 +37
==========================================
+ Hits 53205 53216 +11
- Misses 14511 14524 +13
- Partials 3460 3473 +13
Flags with carried forward coverage won't be shown. Click here to find out more.
🚀 New features to boost your workflow:
|
There was a problem hiding this comment.
Actionable comments posted: 0
Caution
Some comments are outside the diff and can’t be posted inline due to platform limitations.
⚠️ Outside diff range comments (1)
pkg/terraform/clean/deleter.go (1)
27-29: Add user-facing error message for symlink rejection.The symlink error path returns an error but doesn't notify the user via
ui.Errorf, unlike the other error paths (lines 24 and 33). This creates an inconsistent experience.🔧 Suggested fix
if fileInfo.Mode()&os.ModeSymlink != 0 { + ui.Errorf("Cannot delete %s: refusing to delete symbolic link", normalizedObjectName) return fmt.Errorf("%w: %s", errUtils.ErrRefuseDeleteSymbolicLink, normalizedObjectName) }
The ui.Successf function no longer returns an error after refactor in #1980. Update executeGitHubOutput to call Successf separately and return nil. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
Main branch merged #1980 which removed error returns from ui.* functions. Updated cmd/ci/status.go and cmd/terraform/planfile/*.go to match the new API that doesn't return values. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
Continue the ui.* function error return removal from #1980 to scaffold commands. The ui package now returns void since output functions cannot meaningfully fail in ways callers can handle. Also fix blog post tags (use valid tags from tags.yml) and add PR/changelog links to init/scaffold milestones in roadmap. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
|
These changes were released in v1.204.1-rc.2. |
…ckage (#1985) * feat: Add --format=github for terraform output and unified pkg/env package This commit adds GitHub Actions integration for terraform outputs and creates a unified environment variable formatting package to eliminate code duplication. Key changes: 1. New `pkg/env/` package for environment variable formatting: - Supports env, dotenv, bash, and github formats - Options pattern: WithUppercase(), WithFlatten() - Sorted keys for deterministic output - Shell escaping for single-quoted literals - GitHub heredoc syntax for multiline values 2. New `pkg/github/actions/env/` package: - GetOutputPath(), GetEnvPath(), GetPathPath(), GetSummaryPath() - IsGitHubActions() detection 3. `atmos terraform output --format=github`: - Writes outputs to $GITHUB_OUTPUT or --output-file - Supports --uppercase and --flatten options - Uses heredoc syntax for multiline values 4. Refactored cmd/env and pkg/terraform/output to use pkg/env: - Eliminated duplicate formatting code - Consistent behavior across all format commands Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * refactor: Remove pkg/env/github.go wrapper, use pkg/github/actions/env directly Eliminates unnecessary indirection by having consumers import directly from pkg/github/actions/env instead of going through a thin wrapper in pkg/env. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * refactor: Consolidate pkg/github/actions package structure Move GitHub Actions utilities from pkg/github/actions/env/ to pkg/github/actions/. The nested env/ subpackage was confusing since it's unrelated to pkg/env/. Changes: - Create pkg/github/actions/actions.go with path helpers - Create pkg/github/actions/format.go with GitHub formatting (heredoc) - Create pkg/github/actions/actions_test.go with comprehensive tests - Update pkg/env/formatters.go to delegate to ghactions.FormatValue() - Update cmd imports to use ghactions alias - Delete pkg/github/actions/env/ directory Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * feat: Add --export flag to atmos env command Add flexible export control for bash format output: - `atmos env --format=bash` outputs `export KEY='value'` (default) - `atmos env --format=bash --export=false` outputs `KEY='value'` Changes: - Add WithExport(bool) option to pkg/env for controlling export prefix - Add ParseFormat() function for cleaner format string conversion - Simplify cmd/env/env.go by removing duplicate switch statements - Add comprehensive tests for new functionality Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * [autofix.ci] apply automated fixes * [autofix.ci] apply automated fixes (attempt 2/3) * [autofix.ci] apply automated fixes (attempt 3/3) * refactor: Use shellescape.Quote for shell-safe quoting Replace custom EscapeSingleQuotes with battle-tested shellescape library: - shellescape.Quote handles all edge cases properly - Only quotes values when needed (simple values stay unquoted) - Uses `'"'"'` pattern for single quote escaping - Remove unused EscapeSingleQuotes function Output format changes: - Simple values: `export FOO=bar` (was: `export FOO='bar'`) - Quoted values: `export MSG='it'"'"'s'` (was: `export MSG='it'\''s'`) Both formats are valid shell syntax. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * [autofix.ci] apply automated fixes * test: Update terraform output tests for shellescape format Update test expectations to match shellescape.Quote behavior: - Simple values like "vpc-123", "localhost" are not quoted - Only values requiring escaping get quotes Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * [autofix.ci] apply automated fixes * fix: Address CodeRabbit PR review feedback - Regenerate NOTICE file with updated dependencies - Fix heredoc delimiter collision in FormatValue by adding suffix iteration - Add tests for delimiter collision avoidance - Update blog post author from 'atmos' to 'osterman' Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * [autofix.ci] apply automated fixes * fix: Update ui.Successf call after return type change The ui.Successf function no longer returns an error after refactor in #1980. Update executeGitHubOutput to call Successf separately and return nil. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Preserve empty values in GitHub Actions output format GitHub Actions supports empty values (e.g., FOO=) per the official specification. The previous implementation skipped empty values which could break downstream workflows expecting variables to exist even when empty. This aligns with pkg/env behavior which preserves empty strings. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Add backticks around CLI flags in error message for markdown rendering Addresses CodeRabbit PR review feedback for proper markdown formatting. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address PR comments and improve CI resilience - Honor single-output requests for --format=github by filtering outputs when a specific output name is provided - Wrap FormatOutputsWithOptions and WriteToFile errors with proper errUtils.Build() for consistent error handling - Add retry logic with exponential backoff to fetch-latest-release plugin - Use fallback version in production to prevent transient network issues from breaking website builds Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Default --format=github to stdout when GITHUB_OUTPUT not set - Remove error when $GITHUB_OUTPUT is not set and --output-file not provided - Write to stdout instead, allowing local preview of github format - Update docs to reflect output priority: --output-file > $GITHUB_OUTPUT > stdout Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Improve roadmap entry for GitHub Actions terraform outputs - Update label to be more descriptive and action-oriented - Fuse description and benefits for clearer messaging - Emphasize multiline value support without jq/manual heredocs Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Add PR number to roadmap entry for traceability Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * address comments * update docs --------- Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: aknysh <andriy.knysh@gmail.com>
Main branch merged #1980 which removed error returns from ui.* functions. Updated cmd/ci/status.go and cmd/terraform/planfile/*.go to match the new API that doesn't return values. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
Main branch merged #1980 which removed error returns from ui.* functions. Updated cmd/ci/status.go and cmd/terraform/planfile/*.go to match the new API that doesn't return values. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
…cle (#2079) * feat: Add CI Summary Templates and --ci flag for automated pipelines Implement comprehensive CI integration with rich tfcmt-style templates for terraform plan/apply outputs. Auto-generates job summaries, outputs, and artifact management. - Add CIProvider interface for extensible CI component support - Implement terraform CI provider with JSON-based output parsing - Create embedded default templates (plan.md, apply.md) with resource counts, badges, and collapsible sections - Add template loader with atmos.yaml override support (base_path, per-component templates) - Add generic CI provider for local testing (--ci flag without platform detection) - Implement unified CI executor with hook bindings and declarative actions - Add golden file tests for template regression testing - Add --ci flag to plan/apply commands (respects CI env var precedence) - Wire CI hooks through terraform PostRunE for automatic execution Template features match existing GitHub Actions with tfcmt formatting: - Plan summaries with resource change badges (CREATE, CHANGE, REPLACE, DESTROY) - Caution warning when resources will be deleted - Terraform output variables table after apply - Error/warning extraction from command output - Markdown rendering with collapsible sections CI integration is controlled by: 1. ci.enabled in atmos.yaml (enables/disables integration) 2. CI environment detection (GitHub Actions auto-detected) 3. --ci flag on plan/apply (forces CI mode for testing) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com> * fix: Add perf.Track and linting fixes for CI package - Add defer perf.Track() to all public functions in CI package - Fix import ordering (go-fumpt) - Fix octal literal formatting (0644 → 0o644) - Update golangci.yml to exclude pkg/ci/github/ from depguard - Update lintroller to exclude pkg/ci/ from some checks - Fix test file permission literals 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Add blog post announcing native CI integration Announces the new native CI integration feature with: - Simple GitHub Actions workflow examples - Explanation of auto-detection and --ci flag - Matrix strategy for multiple components - Local testing instructions - Configuration options 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Add missing planfile packages and fix broken blog link The planfile command and pkg/ci/planfile packages were not committed because .gitignore had a rule `**/planfile` which ignored any directory named "planfile". Changed the rule to only ignore files matching `*.planfile` pattern (already covered by existing rules). Also: - Fixed broken link in CI integration blog post that referenced /ci - Added pkg/ci/planfile/s3/ to golangci exclusions for AWS SDK imports - Fixed lint issues in internal/exec/describe_affected.go Note: The newly tracked files have pre-existing lint issues that will need to be addressed in a follow-up commit. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Remove duplicate defaultFilePermissions constant The constant was already defined in docs_generate.go in the same package. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address all lint issues in CI integration code Refactored CI integration code to resolve all lint issues without using nolint directives: - Extract helper functions to reduce cyclomatic/cognitive complexity - Use pointer parameters for large structs (hugeParam fixes) - Extract constants for magic numbers - Refactor nested if blocks into early returns - Split long functions into focused helpers Files refactored: - cmd/ci/status.go: Split getRepoContext into helper functions - cmd/terraform/planfile/*.go: Extract format/download helpers - pkg/ci/executor.go: Extract platform detection and binding logic - pkg/ci/terraform/parser.go: Extract resource processing functions - pkg/ci/planfile/github/store.go: Extract repo info and zip handling - pkg/ci/templates/loader.go: Extract template loading by source 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Update golden snapshots for CI integration Regenerated golden snapshots to reflect new CI integration features: - New `ci` command in atmos --help output - New `planfile` subcommand under `terraform` - New `--ci` flag for terraform plan/apply commands - New CI configuration fields in describe config output 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Make TestLoaderResolvePath cross-platform compatible Use filepath.FromSlash() for path literals in test expectations to ensure the test passes on both Unix and Windows, where path separators differ. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Update CI PRDs with implementation status - native-ci-integration.md: Added Implementation Status section showing Phase 1 complete, Phase 2 ~70%, and Phases 3-6 pending. Updated package structure and Files to Create table with status indicators. Documented additional components implemented beyond original PRD. - ci-summary-templates.md: Marked as complete with all files implemented. Added missing test files to the implementation table. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Clarify CI mode activation in blog post Address review comment: clarify that ci.enabled: true in atmos.yaml is respected as a way to enable CI mode. Added numbered list of activation conditions and clarified precedence order. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address CodeRabbit review comments on CI integration This commit addresses multiple CodeRabbit review comments: - cmd/terraform/planfile/download.go: Fix double %w error wrapping using errors.Join, fix Windows path handling using filepath.Base() - cmd/terraform/planfile/upload.go: Fix unreachable GitHub Actions detection by reordering store type logic - pkg/ci/github/checks.go: Add documentation for completed status mapping, remove unused mapGitHubConclusionToCheckRunState function - pkg/ci/planfile/github/store.go: Add HTTP timeout (30s) for artifact downloads, fix error wrapping with errors.Join - pkg/ci/planfile/local/store.go: Fix file filter to only skip .metadata.json files - pkg/ci/planfile/s3/store.go: Simplify error check functions by removing unused second parameter - pkg/ci/terraform/provider.go: Add nil check for result parameter in GetOutputVariables - tools/lintroller/rule_perf_track.go: Add pkg/template exclusion with proper documentation 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address additional CodeRabbit review comments on CI integration This commit addresses the second round of CodeRabbit review comments: Comment #1 - Global flags in planfile commands: - Add global flag parsing (--base-path, --config, --config-path, --profile) to delete.go, download.go, and upload.go using flags.ParseGlobalFlags() - Refactored upload.go to extract helper functions and reduce function length Comment #3 - GenerateKey placeholder validation: - Add validation for required fields (Stack, Component, SHA) when used in pattern - Return ErrPlanfileKeyInvalid error instead of leaving placeholders unreplaced - Update interface_test.go with new test cases for validation behavior Comments #4-5 - Golden file anchor mismatches: - Update templates to use user-content- prefix on anchor IDs for proper markdown link fragment resolution - Regenerate all golden files to match new template output 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Add comprehensive CI integration test coverage Add test files for CI integration packages to improve code coverage: - pkg/ci/planfile/github/store_test.go: GitHub Artifacts store tests - pkg/ci/planfile/s3/store_test.go: S3 store helper function tests - pkg/ci/github/status_test.go: GitHub status fetching tests - pkg/ci/github/checks_test.go: Check run creation/update tests - cmd/ci/status_test.go: CI status command helper tests - pkg/ci/output_test.go: Output writer tests - cmd/terraform/planfile/upload_test.go: Upload command helper tests - cmd/terraform/planfile/list_test.go: List formatting tests - Expanded pkg/ci/executor_test.go with data structure tests - Expanded pkg/ci/planfile/local/store_test.go with edge cases Also removes accidentally committed lintroller binary and adds it to .gitignore. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * refactor: Restructure CI config schema for provider-agnostic naming Reorganize CI configuration from confusing nested structure to a cleaner, provider-agnostic structure with four top-level capabilities: - output: key=value pairs for downstream jobs (GitHub: $GITHUB_OUTPUT) - summary: markdown job summary (GitHub: $GITHUB_STEP_SUMMARY) - checks: commit status checks (GitHub: Check Runs API) - comments: PR/MR comments (GitHub: PR comments, GitLab: MR notes) Key changes: - Rename status_checks -> checks - Rename pr_comment -> comments - Move variables under output where it belongs - Remove outputs wrapper (was conflating concepts) - Add template field to summary and comments configs This structure supports GitHub Actions, GitLab CI, and other CI providers with consistent, intuitive naming. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * feat: Wire up CI config settings to executor implementation - Add isActionEnabled() to check if CI actions are enabled based on config - Summary and Output enabled by default, Checks disabled by default - Upload/Download always enabled (controlled by planfile config) - Add filterVariables() to filter output variables by CI.Output.Variables - Update executeSummaryAction() to support custom template from config - Add comprehensive tests for config-aware behavior 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address CodeRabbit review comments on CI integration - Use ErrNotImplemented for GitHub Artifacts upload limitation - Fix broken internal link fragment in plan_no_changes.md template - Remove non-deterministic TestGetDefaultProvider test - Remove tautological TestTableHeaderWidth and TestPlanfileInfoSorting tests - Use errors.Is() for specific error sentinel verification in upload_test.go - Handle JSON decode errors in checks_test.go mock handlers - Check url.Parse errors in checks_test.go - Fix config key names in PRD docs (ci.checks.enabled, ci.comments.enabled) - Add Screengrab component to ci/status.mdx per documentation standards 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address error handling patterns in CI and config code Changes: - Use consistent fmt.Errorf("%w: ...") pattern in planfile store instead of errors.Join() for consistency with other methods - Make error messages unique to avoid linter warning about duplicate string literals - Fix type switch on error to use errors.As() in config loading - Add nolint comment for ATMOS_CLI_CONFIG_PATH os.Getenv (bootstrap config) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Move ATMOS_PROFILE/ATMOS_IDENTITY env vars to job level Move environment variables from step level to job level in workflow examples for better practice. This ensures all steps in the job have access to the environment variables without repetition. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Restructure PRD and blog with reproducibility narrative Lead with WHY before WHAT: complex bash scripts in CI workflows signal hidden complexity from tools not designed for CI. The reproducibility principle—same command, same behavior everywhere—is now the core narrative for native CI integration. PRD changes: - Add Executive Summary with key insight - Expand Problem Statement with Hidden Complexity Problem - Add The Reproducibility Principle section with before/after examples - Rename "What You Get" to "What This Enables" (after context) - Remove duplicate Problem Statement section Blog post changes: - Lead with reproducibility narrative - Add "The Problem with CI Glue Code" section - Add "The Reproducibility Principle" with concrete examples - Add "What This Enables" to connect solution to problem 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: Add formal functional requirements and fix matrix examples Add Functional Requirements (FR-1 through FR-9): - FR-1: CI Environment Detection - FR-2: Job Summary Output - FR-3: CI Output Variables - FR-4: Status Checks - FR-5: Planfile Storage - FR-6: Plan Verification - FR-7: Command Parity - FR-8: Describe Affected Matrix Format - FR-9: CI Status Command Add Non-Functional Requirements (NFR-1 through NFR-4): - NFR-1: Performance targets - NFR-2: Reliability (graceful degradation) - NFR-3: Security boundaries - NFR-4: Extensibility Fix matrix examples to use --output-file flag: - Add --output-file="$GITHUB_OUTPUT" usage pattern - Show complete workflow example with affected job - Document key=value output format for $GITHUB_OUTPUT 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Remove pkg/template from perf-track exclusions The pkg/template package performs template.Parse and recursive AST tree traversal, which are non-trivial operations requiring perf tracking per coding guidelines. Only trivial String() methods qualify for exclusion. Addresses CodeRabbit review comment. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address CodeRabbit review comments on CI integration - Parse global flags before loading config in ci status command - Add static error sentinels for planfile operations - Add validation to planfile registry Register function - Wrap errors with static sentinels in local and S3 stores - Fix MD028 violations in markdown templates with HTML comments 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Update golden snapshots for CI schema and terraform flags Update snapshots to reflect: - CI config schema changes (outputs->output, status_checks->checks, pr_comment->comments, added summary section) - New terraform apply flags (--auto-generate-backend-file, --init-run-reconfigure) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Regenerate terraform plan help snapshot Update snapshot for terraform plan --help to include new flags: - --auto-generate-backend-file - --init-run-reconfigure 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Use platform-specific absolute paths in TestLoaderResolvePath On Windows, filepath.IsAbs() requires a drive letter (e.g., C:\) for a path to be considered absolute. The test was using Unix-style paths (/absolute/path) which become \absolute\path on Windows - not absolute. This fix uses runtime.GOOS to select appropriate absolute paths for each platform, ensuring the test works correctly on both Windows and Unix systems. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address CodeRabbit review comments on planfile commands 1. delete.go: Require --force flag for deletion (returns error instead of silently exiting), using static error ErrPlanfileDeleteRequireForce 2. list.go: Add global flag parsing (--base-path, --config, etc.) 3. show.go: Add global flag parsing (--base-path, --config, etc.) 4. check.go: Add Name field to UpdateCheckRunOptions (distinct from Title) 5. checks.go: Use opts.Name instead of opts.Title for GitHub API Note: Comment #5 about template field access was investigated and found to be a false positive. The templates correctly access fields from TerraformTemplateContext which provides .Resources, .HasChanges() etc. at the top level (not under .Result). 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * refactor: Use StandardParser pattern and pkg/list for planfile commands Refactor all 5 planfile commands (list, show, delete, download, upload) to: 1. Use StandardParser pattern for flag handling (instead of package-level variables) 2. Use pkg/list infrastructure for list output formatting (instead of custom formatters) Benefits: - Automatic environment variable support (ATMOS_PLANFILE_*) - Proper precedence handling (CLI > ENV > config > defaults) - Type-safe options structs - Consistent output formatting with TTY detection - Less code to maintain 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * chore: Add .claude/plans/ to .gitignore 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Rename shadowed fmt variable to outputFmt in list.go The local variable `fmt` was shadowing the imported fmt package. Renamed to `outputFmt` to avoid the shadowing issue. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address CodeRabbit review comments on CI integration - Use *bool pointer types for CI config Enabled fields to distinguish "not set" from "explicitly false" (fixes isActionEnabled defaults) - Document Detect() non-deterministic map iteration order in registry.go - Replace manual mock with mockgen-generated MockComponentCIProvider - Add validation for empty Stack/ComponentFromArg in GetArtifactKey - Add perf.Track() to RunCIHooks function per coding guidelines 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * chore: Add TODO comment for GetArtifactKey interface consideration Address CodeRabbit feedback about aligning with planfile.GenerateKey validation pattern. The current defensive approach with placeholders is appropriate since the key is only used for debug logging, but noted for future consideration if the interface is used for actual operations. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Remove unused PlanFile and Content fields from Hook struct These fields were placeholders for deprecated CI hook commands (ci.upload, ci.download, ci.summary). The modern approach uses RunCIHooks which delegates to ci.Execute() with provider bindings. Added comment explaining the deprecation and pointing to pkg/ci/. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address CodeRabbit review comments on CI integration (part 2) - GenericProvider: Return ErrCIOperationNotSupported error instead of (nil, nil) for GetStatus, CreateCheckRun, and UpdateCheckRun methods to prevent nil dereference panics at call sites - s3/store.go: Wrap loadMetadata errors with ErrPlanfileMetadataFailed sentinel for consistent error handling - loader_test.go: Handle fs.Sub error explicitly with panic for the (impossible) failure case since the directory is compile-time embedded 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Address CodeRabbit review comments on CI integration (part 3) Security fixes: - Add path traversal validation in local planfile store to prevent directory escape attacks via malicious keys Bug fixes: - Fix type assertion panic in hooks.go when "hooks" section is missing - Replace custom errorAs with stdlib errors.As in S3 store Code quality improvements: - Replace custom replaceAll/indexOf functions with strings.ReplaceAll - Fix comment/constant name mismatch in status.go - Add error logging in GitHub provider init - Simplify error wrapping in download.go using errUtils.Build() - Use errUtils.Build() pattern in delete.go for consistency - Refactor store detection into helper functions in upload.go Implementation: - Implement actual upload/download actions in executor.go instead of no-op placeholders. Actions now read/write planfiles to configured storage backends with proper metadata. Documentation: - Add thread-safety documentation for regex compilation in parser.go - Add comment about file permissions in describe_affected.go - Add planfile subcommand documentation (upload, download, list, delete, show) Testing: - Add path traversal prevention tests for local store - Remove obsolete tests for deleted custom helper functions 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Wrap errors with static sentinels per CodeRabbit review - Wrap file open errors in output.go with ErrCIOutputWriteFailed and ErrCISummaryWriteFailed sentinels - Wrap JSON unmarshal errors in parser.go with ErrParseFile sentinel This ensures consistent error checking using errors.Is() throughout the codebase. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Wrap write errors with static sentinels per CodeRabbit review - Wrap fmt.Fprintf error in WriteOutput with ErrCIOutputWriteFailed - Wrap WriteString error in WriteSummary with ErrCISummaryWriteFailed 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * test: Regenerate golden snapshots for CI/terraform features Update golden snapshot files to include new features added to this branch: - ci command (CI/CD integration) - planfile subcommand for terraform - --ci flag for terraform plan - planfiles configuration section Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * fix: Update ui.* calls to match new void-return API Main branch merged #1980 which removed error returns from ui.* functions. Updated cmd/ci/status.go and cmd/terraform/planfile/*.go to match the new API that doesn't return values. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * [autofix.ci] apply automated fixes * fix: Wrap CI status fetch failures with sentinel error Address CodeRabbit feedback: Wrap provider.GetStatus errors with ErrCIStatusFetchFailed sentinel so callers can reliably detect the failure class, following coding guidelines for error handling. Also fixes: - gofumpt formatting in schema.go - godot (comment periods) in log_utils.go Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * [autofix.ci] apply automated fixes * Added native ci fixtures * Added test to clarify atmos terraform planfile list works * Added terraform planfile cmd * Move planfile name from options to flags * Added planfile storage on terraform plan * Regenerate snapshots for planfile subcommand in terraform help Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Regenerate secrets-masking snapshot for planfiles and ci config sections Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Fix readme and tests * Refactor ci pkg - defnine providers and plugins * Move generic provider to separate package * [autofix.ci] apply automated fixes * Separate provider and plugin interfaces * Refactor code * Refactor * Refactor * Refactoring * Added before.terraform.plan hook * Added before.terraform.plan * Add CI failure test case and refactor generic provider UI output Refactor UpdateCheckRun to use consistent UI method per status (success, error, warning) for title and summary lines. Add mock-failure component and acceptance test verifying check run failure reporting with --ci flag. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Added error checks * Prepare cancel check test case * Added outputs * Fix outputs * Fix tests * Fix hooks * Fix hooks * Force local storage usage * Force local storage usage * Force local storage usage * Added debug logs * Fix golden snapshot * Fix golden snapshot * Install GHA * Fix mock component * Fix ci summary * Fix tests * Fix markdown * Fix outputs parse * [autofix.ci] apply automated fixes * Fix parser * Fix warning * [autofix.ci] apply automated fixes * Fix templating * Fix templating * Macos Tests takes more the 45 minutes * Macos Tests takes more the 45 minutes * Fix macos longs running tests * Fix macos atmos vendor pull * [autofix.ci] apply automated fixes * Added native ci fixtures * Added test to clarify atmos terraform planfile list works * Added terraform planfile cmd * Move planfile name from options to flags * Added planfile storage on terraform plan * Regenerate snapshots for planfile subcommand in terraform help Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Regenerate secrets-masking snapshot for planfiles and ci config sections Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Fix readme and tests * Refactor ci pkg - defnine providers and plugins * Move generic provider to separate package * Separate provider and plugin interfaces * [autofix.ci] apply automated fixes * Refactor code * Refactor * Refactor * Refactoring * Added before.terraform.plan hook * Added before.terraform.plan * Add CI failure test case and refactor generic provider UI output Refactor UpdateCheckRun to use consistent UI method per status (success, error, warning) for title and summary lines. Add mock-failure component and acceptance test verifying check run failure reporting with --ci flag. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Added error checks * Prepare cancel check test case * Added outputs * Fix outputs * Fix tests * Fix hooks * Fix hooks * Force local storage usage * Force local storage usage * Force local storage usage * Added debug logs * Fix golden snapshot * Install GHA * Fix mock component * Fix ci summary * Fix tests * Fix markdown * Fix outputs parse * Fix parser * [autofix.ci] apply automated fixes * Fix warning * Fix templating * [autofix.ci] apply automated fixes * Fix templating * Macos Tests takes more the 45 minutes * Macos Tests takes more the 45 minutes * Fix macos longs running tests * Fix macos atmos vendor pull * Fix git toolchain * Added summary output * [autofix.ci] apply automated fixes * Improve terraform output parse * Change release workflow to use feature release file * Change release workflow to use auto-release script * Fix plugin terraform outputs * Fix terraform summary output * Fix no changes template * Fix test * Fix ci summary * Fix summary template * Added test * Added failure summary * Parse errors * Fix test * Fix test * Added github upload implementation * [autofix.ci] apply automated fixes * Added github upload implementation * Fix github storage * [autofix.ci] apply automated fixes * Fix github storage * Added md5 * Added artifacts storage * Update PRD * Update PRD * FR-6: CI-integrated stored vs fresh plan verification (#2147) * Added artifacts storage * Update PRD * Update PRD * Accept artifact storage interface * Updated PRD * Implement phase 2 * Added planfile storage * Update atmos in native-ci * Update PRD * Update native-ci-integration PRD * Added deceompose PRD * Decompose PRD * Clarify questions * Decompose clarification * Decompose clarification * Decompose clarification * Decompose clarification * Decompose clarification * Update implemented features * Update implemented features * Update implemented features * Update implemented features * Update implemented features * Update implemented features * Update implemented features * Update implemented features * Update implemented features * Update implemented features * Update implemented features * Update implemented features * Refactor executor-plugin * Refactor executor-plugin * Refactor executor-plugin * Update PRDs * Update PRDs * Move checkrun storage to github implementation * planfile storage validation PRD * Make local get sha from git * Added PRD to fix planfile storage metadata * Fix planfile storage medatada * Store planfile with lock file * Store planfile with lock file * Store planfile with lock file * Added planfile artifact store multiple files * Added planfile artifact store multiple files * Added planfile artifact store multiple files * Added planfile artifact store multiple files * Planfile and artifact store integration * Define responsibility between planfile storage, artifact storage and backend storage * Move github and s3 storage to artifact package * Generaliza github storage * Generaliza github storage * Improve planfile cli * Update status * Added terraform apply ci * Update prds * Apply terraform outputs * Update PRds with the status * Apply CI plan verfication step 1 * planfile download fix prd * Fix planfile download * Fix planfile download * Added apply verification plan * [autofix.ci] apply automated fixes * Fix CI test failures: update snapshots and stderr patterns - Add --verify-plan flag to apply help golden snapshots - Fix CI test stderr patterns: "CI action failed" → "CI hook" to match actual warning output ("CI hook handler failed", "CI check run creation failed") Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Update apply planfile storage prd * Clarify PRds * Added apply ci integration * [autofix.ci] apply automated fixes * Fix tests * fix tests * fix tests * Set atmos.config ci.enabled top priority * Update PRD * Fix auth problem * Fix outputs * Fix output * Added outputs parser * [autofix.ci] apply automated fixes * Fix github provider detection * Fix apply output summary * Enrich apply summary with resource lists and per-action badges Rewrite apply.md template to match plan.md style: CloudPosse logo, per-action-type badges (CREATE/CHANGE/DESTROY), CAUTION block for destroys, and resource lists by action type in diff code blocks. Parse resource names from apply progress lines (Creating/Modifying/ Destroying) to populate CreatedResources, UpdatedResources, and DeletedResources. Downgrade check run token errors to Debug level. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Render badges inline on a single line in plan and apply summaries Use right-trimming (-}}) on badge template blocks so multiple badges (CREATE/CHANGE/REPLACE/DESTROY) render on the same line instead of each appearing on a separate line. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Show plan diffs in apply summary instead of just result line Rework cleanApplyOutput to strip pre-plan noise and apply progress lines while keeping the plan resource diffs, apply result, and outputs. This gives the apply summary the same detail as the plan summary. Add OpenTofu marker support for plan output stripping. Use case-insensitive regex for progress lines since terraform outputs "Still modifying..." with lowercase after Still. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * Added apply warnings * Skip planfile storages if prirorities are empty * Fix github statuses update * Make CI experementatl * [autofix.ci] apply automated fixes * Decrease timeout for jobs in test workflow Reduced timeout for job and acceptance tests from 60 to 45 minutes. * Fix tests with experimental message * Update implementation status * Fix tests * Update documentation * Update documentation * Fix links * Fix documentation * Fix broken links * Update documentation * Address documentation comments * Address documentation comments * Fix tests * Create PRD for storage rename * Rename storage * Update website documentation * Resolve sha based on git for github * Fix tests * [autofix.ci] apply automated fixes * Rollback generate command * Rollback generate command * PRD for commit statuses (#2206) * PRD for commit statuses * Added checks based on github commit status * Fix tests * [autofix.ci] apply automated fixes * Fix tests * Fix status check url * Fix status check url * Update website docs * Update website docs * Update website docs --------- Co-authored-by: Erik Osterman <erik@cloudposse.com> Co-authored-by: Claude Haiku 4.5 <noreply@anthropic.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
what
_ = ui.*) across the codebasewhy
Errors from stderr writes are not meaningful for callers to handle. The io/Write API may fail for reasons beyond the caller's control (terminal buffering, redirect failures, etc.), but there's nothing actionable the caller can do. This matches the
log.*pattern which already doesn't return errors.references
Removes unnecessary error handling noise while maintaining the same output behavior.
Summary by CodeRabbit
Refactor
Chores
✏️ Tip: You can customize this high-level summary in your review settings.