fix: consider renovate for dependency_security check#317
fix: consider renovate for dependency_security check#317kami619 merged 8 commits intoambient-code:mainfrom
Conversation
e3b54c4 to
dd95414
Compare
dd95414 to
0b68966
Compare
📈 Test Coverage Report
Coverage calculated from unit tests only |
AgentReady Code Review — PR #317fix: consider renovate for dependency_security check SummaryThis PR correctly addresses the gap of not recognizing Renovate as a valid dependency update tool alongside Dependabot. The implementation is generally solid with good test coverage. A few issues need attention before this is ready to merge. AgentReady Attribute Compliance
Issues1. Silent regression — Dependabot bonus points removed (Must Fix)The original code awarded 5 bonus points when Dependabot was configured and had at least one scheduled update ( Suggested fix: Either restore the bonus logic, or explicitly document the decision to drop it. 2. Attribute
|
| Test Case | Coverage |
|---|---|
renovate.json root |
✅ |
.github/renovate.json |
✅ |
.renovaterc.json |
✅ |
renovate.json5 |
✅ |
.renovaterc |
✅ |
Renovate in package.json |
✅ |
Malformed package.json |
✅ |
| Dependabot takes precedence | ✅ |
.github/renovate.json5 |
❌ Missing |
Score Impact
| Scenario | Before PR | After PR |
|---|---|---|
Dependabot with updates block |
35 pts | 30 pts (regression) |
Dependabot without updates block |
30 pts | 30 pts |
| Renovate (any config file) | 0 pts | 30 pts (improvement) |
| Both Dependabot + Renovate | 30–35 pts | 30 pts |
Verdict
Request changes before merging. The core implementation is correct and well-tested. The blocking items are:
- Restore or explicitly drop the Dependabot bonus points (with justification in the PR description)
- Update the
criteriastring on theAttributemodel - Update remediation steps to mention Renovate
Items 3 and 4 (remediation + .github/renovate.json5) are important but could follow as a fast-track cleanup PR if preferred.
AgentReady Code Review — PR #317PR: SummaryThis PR extends Attribute Compliance
IssuesScore Regression for Dependabot Users (Medium)The original code granted a +5 bonus for Dependabot configs with configured # REMOVED in this PR:
if config and "updates" in config and len(config["updates"]) > 0:
score += 5
evidence.append(f" {len(config['updates'])} package ecosystem(s) monitored")Repositories with well-configured Dependabot will now score 30 instead of 35 on this sub-criterion. This is a silent regression. If the intent was to simplify scoring parity between Dependabot and Renovate, that is reasonable — but it should be called out explicitly in the PR description and ideally restored as an equivalent check for Renovate too. Suggestion: Either restore the bonus (extend it to Renovate as well), or document the scoring change intentionally. Renovate + Dependabot Coexistence (Low)The if dependabot_config.exists():
score += 30
tools_found.append("Dependabot")
elif any(config.exists() for config in renovate_configs): # never reached if Dependabot found
...The test renovate.json5 Existence-Only Check (Low)
What's Good
Minor Notes
VerdictApprove with one request: Address the Dependabot scoring regression (restore the +5 bonus or document the intentional removal). All other observations are low-severity. The Renovate support itself is well-implemented and the test coverage is excellent. Generated by AgentReady review-agentready |
AgentReady Code Review — PR #317
SummaryWell-implemented addition of Renovate detection across all standard config file locations. Good error handling, proper JSON5 acknowledgment, and comprehensive tests. A few design decisions worth discussing. IssuesMedium
The structure is: if dependabot_config.exists():
score += 30 # Dependabot
elif any(config.exists() for config in renovate_configs):
score += 30 # Renovate
else:
# check package.json for renovateA repo with both Dependabot AND Renovate only gets credit for Dependabot (first match wins). The test Bonus points logic is inconsistent between Dependabot and Renovate Dependabot bonus: checks for scheduled updates in YAML (meaningful check). The Renovate bonus should check for meaningful configuration, e.g., presence of Minor
This is intentional (avoid double-counting), but a brief comment would make the intent clear to future maintainers. Import cleanup is good Moving What's Good
Attribute Impact
Verdict: Approve with minor fixes. Address the bonus points consistency issue and add a comment explaining the |
AgentReady Code Review — PR #317PR: SummaryThis PR correctly identifies that 🔴 Critical Bug
# tests/unit/test_assessors_security.py (bottom of file)
def test_remediation_includes_renovate(self, tmp_path): # ← module-level function with `self`This function is defined at module scope, not inside Fix: Indent this function under 🟡 Logic Concern: Mutual Exclusion of Dependabot + RenovateThe PR uses an if dependabot_config.exists():
score += 30
...
else:
# Only checked when Dependabot is absent
if has_renovate_files or has_renovate_package_json:
score += 30This means a repository with both Dependabot and Renovate configured only gets credit for Dependabot. The test 🟡 Minor:
|
AgentReady Code Review — PR #317Reviewer: Claude Code (AgentReady Development Agent) SummaryThis PR correctly extends the Verdict: ✅ Approved with two non-blocking notes AgentReady Attribute Compliance
Score Impact Analysis
Conclusion: No regressions. Repos using Renovate now receive full credit. Issues Resolved Since Previous Reviews
Remaining Notes (Non-Blocking)1. Partial remediation missing
|
There was a problem hiding this comment.
AgentReady Code Review — PR #317
fix: consider renovate for dependency_security check
All CI checks pass. This review covers AgentReady attribute compliance, code quality, and test adequacy.
Summary
This PR extends DependencySecurityAssessor to recognize Renovate as a valid alternative to Dependabot for dependency update management. The approach (Dependabot first, Renovate as fallback) is sound and the test coverage is thorough. A few issues require attention before merge.
Score Impact Analysis
| Scenario | Before | After |
|---|---|---|
| Renovate-only repo | 0 pts (dep tool) | 30–35 pts |
| Both Dependabot + Renovate | 30–35 pts | 30–35 pts (unchanged) |
| Dependabot-only repo | 30–35 pts | 30–35 pts (unchanged) |
This is a correct and meaningful change — Renovate is widely used and was previously invisible to the assessor.
Issues
🔴 Required Changes
1. Bug: package_json variable is defined twice
package_json = repository.path / "package.json" is now defined at two locations in assess():
- Line ~82 (new Renovate section, inside the
elseblock) - Line ~182 (existing npm audit section)
This works by accident today because the second definition is outside the else block. However, if the Dependabot path is taken, the package_json local variable from the else block is never set, yet the second reference still works because it's a fresh assignment. This is fine functionally but creates a confusing pattern. The import json was correctly moved to the module level — the same should be done for the package_json path computation. Define it once near the top of assess() or at the point it's first needed, outside any conditional block.
# Before (two separate definitions)
else:
package_json = repository.path / "package.json" # line ~82
...
# Later...
package_json = repository.path / "package.json" # line ~182# After (define once at top of assess())
package_json = repository.path / "package.json"2. Misleading variable name: cached_renovate_config
The variable cached_renovate_config is not a cache in any meaningful sense — it stores the parsed renovate key from package.json for reuse within the same function call. Naming it cached_* implies persistence across calls, which is misleading.
Suggested rename: renovate_pkg_config or pkg_renovate_config.
🟡 Recommendations
3. Test assertion gap in test_renovaterc_configuration
.renovaterc with "extends": [...] satisfies meaningful_keys, so this test will actually score 35 (not just 30). The assertion assert finding.score >= 30 is correct but under-specified. Consider asserting == 35 to document the expected bonus behavior, or add a separate "no bonus" test with a .renovaterc that lacks meaningful keys.
4. Inaccurate test comment in test_dependabot_first_match_wins_over_renovate
The docstring says "first match (Dependabot) wins due to elif structure" but the code uses an if/else structure, not elif. Minor but could mislead future readers.
5. Ambiguous criteria string punctuation
criteria="Dependabot or Renovate, CodeQL, or SAST tools configured; secret detection enabled",The comma after "Renovate" makes parsing ambiguous — is it "Dependabot" OR "Renovate, CodeQL, or SAST"? Suggest:
criteria="(Dependabot or Renovate) and/or CodeQL/SAST tools configured; secret detection enabled",6. No test for has_renovate_files=True (JSON5 only) + meaningful package.json → bonus awarded
When only a .json5 file exists (which gets base points but no bonus from the file loop) and package.json also has meaningful Renovate config, the fallback correctly awards +5 via cached_renovate_config. This case is not explicitly tested. Consider adding a test to document this behavior.
Positive Observations
- Moving
import jsonto module level is the right cleanup. - The
bonus_awardedflag correctly prevents double-counting the +5 bonus across multiple config sources. - JSON5 handling (detect presence, skip bonus parsing) is pragmatic and well-documented with inline comments.
- 15 new test cases cover the key scenarios thoroughly.
- Graceful error handling with
except Exception: pass/except Exception: continueis consistent with the existing codebase pattern. - Remediation text, tools list, and examples are all updated consistently.
Verdict
The core logic is correct and the test coverage is strong. The required changes are minor refactors (variable deduplication, naming) but important for maintainability. Address items 1–2 and this is ready to merge.
Reviewed by AgentReady Code Review Agent
Outdated review (click to expand)Outdated review (click to expand)Outdated review (click to expand)🤖 AgentReady Code ReviewPR Status: 4 issues found (0 🔴 Critical, 2 🟡 Major, 2 🔵 Minor) Note on Previous ReviewsEarlier review iterations incorrectly claimed the Dependabot +5 bonus scoring was removed (a false positive). The diff shows the bonus block is preserved intact — only the evidence string changed from "alerts" to "updates". The scoring regression claim should be disregarded. 🟡 Major Issues (Confidence 80-89) — Manual Review Required1.
|
AgentReady Code Review — PR #317fix: consider renovate for dependency_security check CI: All blocking checks pass. This review covers AgentReady attribute compliance, code quality, security, and best practices. OverviewThis PR extends Score Impact Analysis
This is a correct and meaningful change. Renovate is widely adopted (especially in mono-repos and non-GitHub-hosted codebases) and was previously invisible to the assessor. Required Changes 🔴1. Duplicate
Functionally this is harmless, but it creates a confusing pattern — readers may wonder whether the two definitions are intentionally different. Move the definition to the top of def assess(self, repository: Repository) -> Finding:
score = 0
evidence = []
tools_found = []
package_json = repository.path / "package.json" # defined once
# 1. Dependency update tools …2. Misleading variable name: This variable holds the parsed Recommendations 🟡3. The 4. Inaccurate docstring in
The code uses an 5. criteria="Dependabot or Renovate, CodeQL, or SAST tools configured; secret detection enabled",The comma after "Renovate" makes it unclear whether the grouping is criteria="(Dependabot or Renovate), CodeQL, or SAST tools configured; secret detection enabled",6. Untested: JSON5-only + meaningful When only a 7. Consider documenting the "both tools present → Dependabot wins" design decision A brief inline comment explaining why only one tool gets credit (they serve the same purpose; avoid double-counting) would help reviewers understand the intentional mutual exclusion without reading the full docstring or PR description. Positive Observations ✅
AgentReady Attribute Compliance
SecurityNo security concerns. File reads use VerdictThe logic is correct, the test coverage is strong, and the feature addresses a real gap. Address items 1 and 2 (required) before merge. Items 3–7 are optional improvements. Reviewed by Claude Code (claude-sonnet-4-6) |
the claude review's are not working as expected, there is some underlying issue, as the reviews addressed by contributors are not being validated after the fact.
## [2.29.4](v2.29.3...v2.29.4) (2026-02-24) ### Bug Fixes * consider renovate for dependency_security check ([#317](#317)) ([35bfbbf](35bfbbf))
|
🎉 This PR is included in version 2.29.4 🎉 The release is available on GitHub release Your semantic-release bot 📦🚀 |
# 1.0.0 (2026-03-05) ### Bug Fixes * add bounded retry logic for LLM rate limit handling ([ambient-code#205](https://github.com/patrickstrick/agentready/issues/205)) ([6ecb786](6ecb786)), closes [ambient-code#104](https://github.com/patrickstrick/agentready/issues/104) * Add comprehensive subprocess security guardrails (fixes [ambient-code#57](https://github.com/patrickstrick/agentready/issues/57)) ([ambient-code#66](https://github.com/patrickstrick/agentready/issues/66)) ([454b80e](454b80e)) * Add comprehensive YAML validation to prevent attacks (fixes [ambient-code#56](https://github.com/patrickstrick/agentready/issues/56)) ([ambient-code#63](https://github.com/patrickstrick/agentready/issues/63)) ([31ecb3a](31ecb3a)) * add repository checkout step to Claude Code Action workflow ([17aa0cf](17aa0cf)) * add uv.lock to recognized lockfiles ([ambient-code#143](https://github.com/patrickstrick/agentready/issues/143)) ([a98dc87](a98dc87)), closes [ambient-code#137](https://github.com/patrickstrick/agentready/issues/137) * address P1 code quality issues from code review ([ambient-code#36](https://github.com/patrickstrick/agentready/issues/36)) ([5976332](5976332)) * address P1 code quality issues from code review ([ambient-code#37](https://github.com/patrickstrick/agentready/issues/37)) ([4be1d5e](4be1d5e)) * address P1 code quality issues from code review ([ambient-code#38](https://github.com/patrickstrick/agentready/issues/38)) ([77f2300](77f2300)) * **assessors:** FileSizeLimitsAssessor now respects .gitignore ([ambient-code#248](https://github.com/patrickstrick/agentready/issues/248)) ([eaaecc2](eaaecc2)), closes [ambient-code#245](https://github.com/patrickstrick/agentready/issues/245) * **assessors:** search recursively for OpenAPI specification files ([ambient-code#127](https://github.com/patrickstrick/agentready/issues/127)) ([e2a5778](e2a5778)) * **assessors:** support project-named directories and test-only repos in standard_layout check ([ambient-code#322](https://github.com/patrickstrick/agentready/issues/322)) ([2fbb733](2fbb733)), closes [ambient-code#246](https://github.com/patrickstrick/agentready/issues/246) [ambient-code#305](https://github.com/patrickstrick/agentready/issues/305) * Check for all official commitlint config file formats ([ambient-code#308](https://github.com/patrickstrick/agentready/issues/308)) ([50588cf](50588cf)) * **ci:** add permissions for leaderboard PR comment posting ([ambient-code#276](https://github.com/patrickstrick/agentready/issues/276)) ([33252e4](33252e4)) * **ci:** use gh pr view for fork PR number lookup in coverage comment ([ambient-code#253](https://github.com/patrickstrick/agentready/issues/253)) ([1688362](1688362)) * **cli:** check .pre-commit-config.yaml for conventional commit ([ambient-code#310](https://github.com/patrickstrick/agentready/issues/310)) ([61c44d9](61c44d9)) * **cli:** Honor excluded_attributes from config file ([ambient-code#306](https://github.com/patrickstrick/agentready/issues/306)) ([ffda546](ffda546)), closes [ambient-code#302](https://github.com/patrickstrick/agentready/issues/302) [ambient-code#302](https://github.com/patrickstrick/agentready/issues/302) * **cli:** Use removesuffix instead of rstrip for .git URL stripping ([ambient-code#292](https://github.com/patrickstrick/agentready/issues/292)) ([6bd08cf](6bd08cf)) * consider renovate for dependency_security check ([ambient-code#317](https://github.com/patrickstrick/agentready/issues/317)) ([35bfbbf](35bfbbf)) * correct Assessment field name in demo command ([ambient-code#41](https://github.com/patrickstrick/agentready/issues/41)) ([b48622d](b48622d)), closes [ambient-code#12](https://github.com/patrickstrick/agentready/issues/12) * Correct datetime import pattern in RepomixService ([ambient-code#65](https://github.com/patrickstrick/agentready/issues/65)) ([517aa6e](517aa6e)) * correct GitHub repository link in site navigation ([5492278](5492278)) * correct Liquid syntax in developer-guide (elif -> elsif) ([75f3b1d](75f3b1d)) * Correct pre-commit template path in PrecommitHooksFixer ([ambient-code#269](https://github.com/patrickstrick/agentready/issues/269)) ([c42a3c9](c42a3c9)) * Create shared test fixtures and fix Assessment schema issues ([ambient-code#114](https://github.com/patrickstrick/agentready/issues/114)) ([46baa13](46baa13)) * disable attestations for Test PyPI to avoid conflict ([ambient-code#155](https://github.com/patrickstrick/agentready/issues/155)) ([a33e3cd](a33e3cd)), closes [pypa/#action-pypi-publish](https://github.com/patrickstrick/agentready/issues/action-pypi-publish) * downgrade docker/metadata-action to v5 and fix shellcheck warnings ([12f5509](12f5509)) * enable Harbor task filtering for smoketest support ([ambient-code#222](https://github.com/patrickstrick/agentready/issues/222)) ([f780188](f780188)) * Enable workflow_dispatch for leaderboard update and regenerate data ([ambient-code#299](https://github.com/patrickstrick/agentready/issues/299)) ([091d9dd](091d9dd)), closes [ambient-code#298](https://github.com/patrickstrick/agentready/issues/298) * exclude DEPLOYMENT.md and SETUP_SUMMARY.md from Jekyll build ([9611207](9611207)) * Improve CLAUDE.md generation prompt and add prompt loading for future LLM integrations [ambient-code#283](https://github.com/patrickstrick/agentready/issues/283) ([ambient-code#284](https://github.com/patrickstrick/agentready/issues/284)) ([c0aeae4](c0aeae4)) * Improve report metadata display with clean table format ([ca361a4](ca361a4)) * leaderboard workflow and SSH URL support ([ambient-code#147](https://github.com/patrickstrick/agentready/issues/147)) ([de28cd0](de28cd0)) * make E2E test timeouts configurable and add sensitive directory test ([ambient-code#206](https://github.com/patrickstrick/agentready/issues/206)) ([27e87e5](27e87e5)), closes [ambient-code#104](https://github.com/patrickstrick/agentready/issues/104) [ambient-code#192](https://github.com/patrickstrick/agentready/issues/192) * **metadata:** use Windows-compatible strftime token for human timestamp ([ambient-code#291](https://github.com/patrickstrick/agentready/issues/291)) ([faf536d](faf536d)) * P0 security and logic bugs from code review ([2af2346](2af2346)) * Prevent API key exposure in environment and logs (fixes [ambient-code#55](https://github.com/patrickstrick/agentready/issues/55)) ([ambient-code#64](https://github.com/patrickstrick/agentready/issues/64)) ([4d1d001](4d1d001)) * Prevent command injection in CommandFix.apply() (fixes [ambient-code#52](https://github.com/patrickstrick/agentready/issues/52)) ([ambient-code#60](https://github.com/patrickstrick/agentready/issues/60)) ([49be28e](49be28e)) * Prevent path traversal in LLM cache (fixes [ambient-code#53](https://github.com/patrickstrick/agentready/issues/53)) ([ambient-code#61](https://github.com/patrickstrick/agentready/issues/61)) ([2bf052d](2bf052d)) * prevent unauthorized message for non-command comments ([ambient-code#262](https://github.com/patrickstrick/agentready/issues/262)) ([84c6f69](84c6f69)) * Prevent XSS in HTML reports (fixes [ambient-code#54](https://github.com/patrickstrick/agentready/issues/54)) ([ambient-code#62](https://github.com/patrickstrick/agentready/issues/62)) ([7c60c69](7c60c69)) * properly indent multi-line fix previews in align output ([ambient-code#289](https://github.com/patrickstrick/agentready/issues/289)) ([4e36cb5](4e36cb5)), closes [ambient-code#285](https://github.com/patrickstrick/agentready/issues/285) * remove incorrect dbasunag/opendatahub-tests submission ([ambient-code#321](https://github.com/patrickstrick/agentready/issues/321)) ([e6aecf8](e6aecf8)), closes [ambient-code#301](https://github.com/patrickstrick/agentready/issues/301) * rename research report in data directory ([b8ddfdc](b8ddfdc)) * replace all remaining elif with elsif in developer-guide ([73f16fc](73f16fc)) * Resolve 35 pytest failures through model validation and path sanitization improvements ([ambient-code#115](https://github.com/patrickstrick/agentready/issues/115)) ([4fbfee0](4fbfee0)) * resolve all broken links failing CI lychee check ([ambient-code#288](https://github.com/patrickstrick/agentready/issues/288)) ([4412c27](4412c27)) * resolve all test suite failures - achieve zero failures ([ambient-code#180](https://github.com/patrickstrick/agentready/issues/180)) ([990fa2d](990fa2d)), closes [ambient-code#148](https://github.com/patrickstrick/agentready/issues/148) [ambient-code#147](https://github.com/patrickstrick/agentready/issues/147) [ambient-code#145](https://github.com/patrickstrick/agentready/issues/145) * resolve broken links and workflow failures ([ambient-code#160](https://github.com/patrickstrick/agentready/issues/160)) ([fbf5cf7](fbf5cf7)) * Resolve merge conflicts in CLI main module ([ambient-code#59](https://github.com/patrickstrick/agentready/issues/59)) ([9e0bf2d](9e0bf2d)) * resolve YAML syntax error in continuous-learning workflow ([ambient-code#172](https://github.com/patrickstrick/agentready/issues/172)) ([3d40fcc](3d40fcc)) * resolve YAML syntax error in update-docs workflow and add actionlint ([ambient-code#173](https://github.com/patrickstrick/agentready/issues/173)) ([97b06af](97b06af)) * Sanitize sensitive data in HTML reports (fixes [ambient-code#58](https://github.com/patrickstrick/agentready/issues/58)) ([ambient-code#67](https://github.com/patrickstrick/agentready/issues/67)) ([6fbac76](6fbac76)) * schema backwards compat for attributes_skipped key ([ambient-code#277](https://github.com/patrickstrick/agentready/issues/277)) ([841bcc4](841bcc4)) * **schema:** allow assessments with excluded attributes ([ambient-code#312](https://github.com/patrickstrick/agentready/issues/312)) ([81b999f](81b999f)), closes [ambient-code#301](https://github.com/patrickstrick/agentready/issues/301) [ambient-code#309](https://github.com/patrickstrick/agentready/issues/309) * **security:** replace pull_request_target with pull_request trigger ([ambient-code#328](https://github.com/patrickstrick/agentready/issues/328)) ([3c5d31b](3c5d31b)), closes [ambient-code#324](https://github.com/patrickstrick/agentready/issues/324) * set correct baseurl for GitHub Pages subdirectory deployment ([c4db765](c4db765)) * skip PR comments for external forks to prevent permission errors ([ambient-code#163](https://github.com/patrickstrick/agentready/issues/163)) ([2a29fb8](2a29fb8)) * update --version flag to show correct version and research report date ([ambient-code#221](https://github.com/patrickstrick/agentready/issues/221)) ([5a85abb](5a85abb)) * Update Claude workflow to trigger on [@claude](https://github.com/claude) mentions ([ambient-code#35](https://github.com/patrickstrick/agentready/issues/35)) ([a8a3fab](a8a3fab)) * Use GitHub URL instead of local one ([ambient-code#297](https://github.com/patrickstrick/agentready/issues/297)) ([5abc7c2](5abc7c2)) * **workflows:** ensure post-comment step runs after Claude Code Action ([b087e5c](b087e5c)) * **workflows:** handle all event types in agentready-dev workflow ([9b942bf](9b942bf)) * **workflows:** improve error handling and logging for comment posting ([9ea1e6b](9ea1e6b)) * **workflows:** improve issue number extraction and add debug step ([ecd896b](ecd896b)) * **workflows:** remove if:always() to test step execution ([ff0bb12](ff0bb12)) * **workflows:** simplify post-comment step condition ([1bbf40a](1bbf40a)) ### Features * add agentready-dev Claude agent specification ([ambient-code#44](https://github.com/patrickstrick/agentready/issues/44)) ([0f61f5c](0f61f5c)) * add ambient-code/agentready to leaderboard ([ambient-code#148](https://github.com/patrickstrick/agentready/issues/148)) ([621152e](621152e)) * Add automated demo command for AgentReady ([ambient-code#24](https://github.com/patrickstrick/agentready/issues/24)) ([f4e89d9](f4e89d9)), closes [ambient-code#1](https://github.com/patrickstrick/agentready/issues/1) [ambient-code#25](https://github.com/patrickstrick/agentready/issues/25) [hi#quality](https://github.com/hi/issues/quality) [hi#scoring](https://github.com/hi/issues/scoring) * add Claude Code GitHub Action for [@claude](https://github.com/claude) mentions ([3e7224d](3e7224d)) * Add comprehensive unit tests for utility modules (privacy.py and subprocess_utils.py) ([ambient-code#111](https://github.com/patrickstrick/agentready/issues/111)) ([9d3dece](9d3dece)) * Add customizable HTML report themes with runtime switching ([ambient-code#46](https://github.com/patrickstrick/agentready/issues/46)) ([7eeaf84](7eeaf84)), closes [hi#contrast](https://github.com/hi/issues/contrast) [ambient-code#10](https://github.com/patrickstrick/agentready/issues/10) * add dbasunag/opendatahub-tests to leaderboard ([ambient-code#301](https://github.com/patrickstrick/agentready/issues/301)) ([be7a55f](be7a55f)) * add dgutride/odh-dashboard to leaderboard ([ambient-code#268](https://github.com/patrickstrick/agentready/issues/268)) ([f4911b2](f4911b2)) * Add Doubleagent - specialized AgentReady development agent ([ambient-code#30](https://github.com/patrickstrick/agentready/issues/30)) ([0ab54cb](0ab54cb)) * add feast-dev/feast to leaderboard ([ambient-code#293](https://github.com/patrickstrick/agentready/issues/293)) ([c894ce9](c894ce9)) * add GitHub organization scanning to assess-batch command ([ambient-code#118](https://github.com/patrickstrick/agentready/issues/118)) ([e306314](e306314)) * add Harbor Terminal-Bench comparison for agent effectiveness ([ambient-code#199](https://github.com/patrickstrick/agentready/issues/199)) ([a56e318](a56e318)) * Add Interactive Dashboard backlog item ([adfc4c8](adfc4c8)) * add interactive heatmap visualization for batch assessments ([ambient-code#136](https://github.com/patrickstrick/agentready/issues/136)) ([4d44fc3](4d44fc3)) * Add interactive HTML report generation ([18664ea](18664ea)) * add Memory MCP server allow list to repository settings ([ambient-code#203](https://github.com/patrickstrick/agentready/issues/203)) ([41d87bb](41d87bb)) * add opendatahub-io/opendatahub-tests to leaderboard ([ambient-code#314](https://github.com/patrickstrick/agentready/issues/314)) ([7a52466](7a52466)) * add quay/quay to leaderboard ([ambient-code#162](https://github.com/patrickstrick/agentready/issues/162)) ([d6e8df0](d6e8df0)) * add Red-Hat-AI-Innovation-Team/sdg_hub to leaderboard ([ambient-code#279](https://github.com/patrickstrick/agentready/issues/279)) ([5b71392](5b71392)) * add release pipeline coldstart prompt ([ambient-code#19](https://github.com/patrickstrick/agentready/issues/19)) ([9a3880c](9a3880c)), closes [ambient-code#18](https://github.com/patrickstrick/agentready/issues/18) * Add Repomix integration for AI-friendly repository context generation ([ambient-code#29](https://github.com/patrickstrick/agentready/issues/29)) ([92bdde1](92bdde1)), closes [ambient-code#24](https://github.com/patrickstrick/agentready/issues/24) [ambient-code#1](https://github.com/patrickstrick/agentready/issues/1) [ambient-code#25](https://github.com/patrickstrick/agentready/issues/25) [hi#quality](https://github.com/hi/issues/quality) [hi#scoring](https://github.com/hi/issues/scoring) * add report header with repository metadata ([ambient-code#28](https://github.com/patrickstrick/agentready/issues/28)) ([7a8b34a](7a8b34a)) * Add research report management CLI commands ([ambient-code#45](https://github.com/patrickstrick/agentready/issues/45)) ([e1be488](e1be488)), closes [ambient-code#7](https://github.com/patrickstrick/agentready/issues/7) * Add security & quality improvements from code review ([ambient-code#40](https://github.com/patrickstrick/agentready/issues/40)) ([13cd3ca](13cd3ca)) * Add security & quality improvements from code review ([ambient-code#49](https://github.com/patrickstrick/agentready/issues/49)) ([889d6ed](889d6ed)) * Add SWE-bench experiment system for validating AgentReady impact ([ambient-code#124](https://github.com/patrickstrick/agentready/issues/124)) ([15edbba](15edbba)) * Add weekly research update skill and automation ([ambient-code#145](https://github.com/patrickstrick/agentready/issues/145)) ([7ba17a6](7ba17a6)) * **assessors:** implement File Size Limits assessor (Tier 2) ([ambient-code#141](https://github.com/patrickstrick/agentready/issues/141)) ([248467f](248467f)) * **assessors:** support AGENTS.md and @ references in CLAUDEmdAssessor ([ambient-code#265](https://github.com/patrickstrick/agentready/issues/265)) ([450ec25](450ec25)), closes [ambient-code#244](https://github.com/patrickstrick/agentready/issues/244) * Auto-sync CLAUDE.md during semantic-release ([ambient-code#101](https://github.com/patrickstrick/agentready/issues/101)) ([36b48cb](36b48cb)) * automate PyPI publishing with trusted publishing (OIDC) ([ambient-code#154](https://github.com/patrickstrick/agentready/issues/154)) ([71f4632](71f4632)), closes [pypa/#action-pypi-publish](https://github.com/patrickstrick/agentready/issues/action-pypi-publish) * Batch Report Enhancements + Bootstrap Template Inheritance (Phase 2 Task 5) ([ambient-code#133](https://github.com/patrickstrick/agentready/issues/133)) ([7762b23](7762b23)) * centralize Claude instructions via AGENTS.md and add init redirect tests ([ambient-code#273](https://github.com/patrickstrick/agentready/issues/273)) ([92c8f3f](92c8f3f)) * Community Leaderboard for AgentReady Scores ([ambient-code#146](https://github.com/patrickstrick/agentready/issues/146)) ([fea0b3e](fea0b3e)) * Complete Phases 5-7 - Markdown reports, testing, and polish ([7659623](7659623)) * consolidate GitHub Actions workflows by purpose ([ambient-code#217](https://github.com/patrickstrick/agentready/issues/217)) ([717ca6b](717ca6b)), closes [ambient-code#221](https://github.com/patrickstrick/agentready/issues/221) * container support ([ambient-code#171](https://github.com/patrickstrick/agentready/issues/171)) ([c6874ea](c6874ea)) * convert AgentReady assessment to on-demand workflow ([ambient-code#213](https://github.com/patrickstrick/agentready/issues/213)) ([b5a1ce0](b5a1ce0)), closes [ambient-code#191](https://github.com/patrickstrick/agentready/issues/191) * enhance assessors with multi-language support and security ([ambient-code#200](https://github.com/patrickstrick/agentready/issues/200)) ([85712f2](85712f2)), closes [ambient-code#10](https://github.com/patrickstrick/agentready/issues/10) * Harbor framework integration for Terminal-Bench evaluations ([ambient-code#202](https://github.com/patrickstrick/agentready/issues/202)) ([d73a8c8](d73a8c8)), closes [ambient-code#4](https://github.com/patrickstrick/agentready/issues/4) [ambient-code#178](https://github.com/patrickstrick/agentready/issues/178) * Implement AgentReady MVP with scoring engine ([54a96cb](54a96cb)) * Implement align subcommand for automated remediation (Issue [ambient-code#14](https://github.com/patrickstrick/agentready/issues/14)) ([ambient-code#34](https://github.com/patrickstrick/agentready/issues/34)) ([06f04dc](06f04dc)) * Implement ArchitectureDecisionsAssessor (fixes [ambient-code#81](https://github.com/patrickstrick/agentready/issues/81)) ([ambient-code#89](https://github.com/patrickstrick/agentready/issues/89)) ([9e782e5](9e782e5)) * implement automated semantic release pipeline ([ambient-code#20](https://github.com/patrickstrick/agentready/issues/20)) ([b579235](b579235)) * implement bootstrap command for GitHub infrastructure ([0af06c4](0af06c4)), closes [ambient-code#2](https://github.com/patrickstrick/agentready/issues/2) * Implement BranchProtectionAssessor stub (fixes [ambient-code#86](https://github.com/patrickstrick/agentready/issues/86)) ([ambient-code#98](https://github.com/patrickstrick/agentready/issues/98)) ([44c4b17](44c4b17)) * Implement CICDPipelineVisibilityAssessor (fixes [ambient-code#85](https://github.com/patrickstrick/agentready/issues/85)) ([ambient-code#91](https://github.com/patrickstrick/agentready/issues/91)) ([e68285c](e68285c)) * Implement CodeSmellsAssessor stub (fixes [ambient-code#87](https://github.com/patrickstrick/agentready/issues/87)) ([ambient-code#99](https://github.com/patrickstrick/agentready/issues/99)) ([f06b2a8](f06b2a8)) * Implement ConciseDocumentationAssessor (fixes [ambient-code#76](https://github.com/patrickstrick/agentready/issues/76)) ([ambient-code#93](https://github.com/patrickstrick/agentready/issues/93)) ([c356cd5](c356cd5)) * Implement InlineDocumentationAssessor (fixes [ambient-code#77](https://github.com/patrickstrick/agentready/issues/77)) ([ambient-code#94](https://github.com/patrickstrick/agentready/issues/94)) ([e56e570](e56e570)) * Implement IssuePRTemplatesAssessor (fixes [ambient-code#84](https://github.com/patrickstrick/agentready/issues/84)) ([ambient-code#90](https://github.com/patrickstrick/agentready/issues/90)) ([819d7b7](819d7b7)) * Implement multi-repository batch assessment (Phase 1 of issue [ambient-code#68](https://github.com/patrickstrick/agentready/issues/68)) ([ambient-code#74](https://github.com/patrickstrick/agentready/issues/74)) ([befc0d5](befc0d5)) * Implement OneCommandSetupAssessor (fixes [ambient-code#75](https://github.com/patrickstrick/agentready/issues/75)) ([ambient-code#88](https://github.com/patrickstrick/agentready/issues/88)) ([668ba1b](668ba1b)) * Implement OpenAPISpecsAssessor (fixes [ambient-code#80](https://github.com/patrickstrick/agentready/issues/80)) ([ambient-code#97](https://github.com/patrickstrick/agentready/issues/97)) ([45ae36e](45ae36e)) * implement Phase 2 multi-repository assessment reporting ([ambient-code#117](https://github.com/patrickstrick/agentready/issues/117)) ([8da56c2](8da56c2)), closes [ambient-code#69](https://github.com/patrickstrick/agentready/issues/69) * implement report schema versioning ([ambient-code#43](https://github.com/patrickstrick/agentready/issues/43)) ([4c4752c](4c4752c)) * Implement SemanticNamingAssessor (fixes [ambient-code#82](https://github.com/patrickstrick/agentready/issues/82)) ([ambient-code#95](https://github.com/patrickstrick/agentready/issues/95)) ([d87a280](d87a280)) * Implement SeparationOfConcernsAssessor (fixes [ambient-code#78](https://github.com/patrickstrick/agentready/issues/78)) ([ambient-code#92](https://github.com/patrickstrick/agentready/issues/92)) ([99bfe28](99bfe28)) * Implement StructuredLoggingAssessor (fixes [ambient-code#79](https://github.com/patrickstrick/agentready/issues/79)) ([ambient-code#96](https://github.com/patrickstrick/agentready/issues/96)) ([2b87ca7](2b87ca7)) * integrate ACL file with Claude Code Action allowed_users ([ambient-code#261](https://github.com/patrickstrick/agentready/issues/261)) ([fe52489](fe52489)) * Phase 1 Task 1 - Consolidate Security Validation Patterns ([ambient-code#129](https://github.com/patrickstrick/agentready/issues/129)) ([8580c45](8580c45)), closes [ambient-code#122](https://github.com/patrickstrick/agentready/issues/122) [ambient-code#122](https://github.com/patrickstrick/agentready/issues/122) [ambient-code#122](https://github.com/patrickstrick/agentready/issues/122) * Phase 1 Tasks 2-3 - Consolidate Reporter Base & Assessor Factory ([ambient-code#131](https://github.com/patrickstrick/agentready/issues/131)) ([8e12bf9](8e12bf9)), closes [ambient-code#122](https://github.com/patrickstrick/agentready/issues/122) [ambient-code#122](https://github.com/patrickstrick/agentready/issues/122) [ambient-code#122](https://github.com/patrickstrick/agentready/issues/122) [ambient-code#122](https://github.com/patrickstrick/agentready/issues/122) * Phase 2 Task 4 - Replace manual config validation with Pydantic ([ambient-code#134](https://github.com/patrickstrick/agentready/issues/134)) ([d83cf58](d83cf58)) * Redesign homepage features with two-column layout and research links ([ambient-code#189](https://github.com/patrickstrick/agentready/issues/189)) ([570087d](570087d)), closes [ambient-code#187](https://github.com/patrickstrick/agentready/issues/187) * redesign HTML report with dark theme and larger fonts ([ambient-code#39](https://github.com/patrickstrick/agentready/issues/39)) ([59f6702](59f6702)), closes [#8b5cf6](https://github.com/patrickstrick/agentready/issues/8b5cf6) [#XX](https://github.com/patrickstrick/agentready/issues/XX) * Rename 'learn' command to 'extract-skills' for clarity ([ambient-code#125](https://github.com/patrickstrick/agentready/issues/125)) ([64d6563](64d6563)), closes [hi#scoring](https://github.com/hi/issues/scoring) [ambient-code#123](https://github.com/patrickstrick/agentready/issues/123) * replace markdown-link-check with lychee for link validation ([ambient-code#177](https://github.com/patrickstrick/agentready/issues/177)) ([f1a4545](f1a4545)) * Standardize on Python 3.12+ with forward compatibility for 3.13 ([ambient-code#132](https://github.com/patrickstrick/agentready/issues/132)) ([84f2c46](84f2c46)) * **submit:** add --gh flag for gh CLI-based submission ([ambient-code#278](https://github.com/patrickstrick/agentready/issues/278)) ([48bb624](48bb624)) * Terminal-Bench eval harness (MVP Phase 1) ([ambient-code#178](https://github.com/patrickstrick/agentready/issues/178)) ([d06bab4](d06bab4)), closes [ambient-code#171](https://github.com/patrickstrick/agentready/issues/171) * **workflows:** add comment posting for [@agentready-dev](https://github.com/agentready-dev) agent ([5dff614](5dff614)) ### Performance Improvements * implement lazy loading for heavy CLI commands ([ambient-code#151](https://github.com/patrickstrick/agentready/issues/151)) ([6a7cd4e](6a7cd4e)) ### BREAKING CHANGES * Users must update scripts from 'agentready learn' to 'agentready extract-skills'. All flags and options remain identical.
Description
Add consideration for renovate in depdency_security check
Type of Change
Related Issues
Fixes # #316
Relates to #
Changes Made
Testing
pytest)Checklist
Screenshots (if applicable)
Additional Notes