Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
125 changes: 125 additions & 0 deletions AI_POLICY.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,125 @@
# AI Policy

> **TL;DR** — AI tools assist our workflow at every stage. Humans remain in control of every decision, every review, and every release.

---

## Overview

This document describes how artificial intelligence tools are used in the maintenance and development of this project. It is intended to be transparent with our contributors, users, and the broader open-source community about the role AI plays — and, equally importantly, the role it does **not** play.

We believe in honest, clear communication about AI-assisted workflows. This policy will be updated as our practices evolve.

---

## Our Guiding Principle

**AI assists. Humans decide.**

The maintainers who have been stewarding this project for years remain fully responsible for every line of code that ships. AI tools extend our capacity to review, research, and improve — they do not replace human judgment, expertise, or accountability.

---

## How AI Is Used in This Project

### 1. Code and Issue Analysis

AI tools help us process and understand incoming issues, pull requests, and code changes at scale. This includes:

- Summarising issue reports and identifying patterns across similar bugs
- Analysing code diffs for potential problems, regressions, or style inconsistencies
- Surfacing relevant context from the codebase, documentation, and prior discussions
- Flagging potential security concerns for human review

This analysis is **always** used as input to human decision-making, never as a substitute for it.

### 2. Draft Pull Requests

AI may generate draft pull requests as a starting point for a fix, a refactor, or an improvement. These drafts:

- Are clearly labelled as AI-generated when created
- Represent a first pass only — they are never considered complete or correct without human review
- May be substantially reworked, rejected, or replaced entirely by maintainers

Think of these drafts the way you would think of a junior contributor's first attempt: useful raw material that still needs experienced eyes.

### 3. Human Review of Every Pull Request

**Every pull request — whether AI-drafted or human-authored — is reviewed by a human maintainer before it can be merged.**

During review, maintainers actively use AI as a tool to assist their own thinking:

- Asking AI to explain or justify specific implementation choices
- Challenging AI-generated code and requesting alternative approaches
- Using AI to research edge cases, relevant standards, or upstream behaviour
- Requesting targeted rewrites of individual sections based on review feedback

The maintainer's judgment always takes precedence. AI answers are treated as input to be verified, not conclusions to be accepted.

### 4. Test Coverage and Defect Detection

AI helps us improve the quality and completeness of our test suite by:

- Suggesting test cases for edge conditions and failure modes
- Identifying gaps in existing test coverage
- Proposing tests that target known classes of defects or security issues
- Helping reproduce and characterise reported bugs

All suggested tests are reviewed and validated by maintainers before being committed.

### 5. Security Review

AI tools assist in identifying potential security issues, including:

- Common vulnerability patterns (injection, insecure defaults, deprecated APIs, etc.)
- Dependencies with known CVEs
- Code paths that may warrant closer scrutiny

Security findings from AI are **always** verified by a human maintainer. We do not act on AI-flagged security issues without independent assessment. For responsible disclosure, please refer to our [`SECURITY.md`](SECURITY.md).

---

## What AI Does Not Do

To be explicit about the limits of AI involvement in this project:

| ❌ AI does not… | ✅ A human maintainer does… |
|---|---|
| Approve or merge pull requests | Review and decide on every PR |
| Make architectural decisions | Own all design and direction choices |
| Triage and close issues autonomously | Assess and respond to all issues |
| Publish releases | Tag, build, and release manually |
| Represent the project publicly | Communicate on behalf of the project |

---

## Releases

Releases are performed manually by the same long-standing maintainers as always. The release process — including changelog review, version tagging, and publication — involves no automation that is not fully understood and supervised by a human.

AI may assist in drafting changelogs or release notes, but these are always reviewed and edited before publication.

---

## Attribution and Transparency

Where AI has played a material role in generating code or content within a pull request, we aim to note this in the PR description (e.g. via a `Generated-By` or `AI-Assisted` label or note). We do not consider AI the author of any contribution — the maintainer who reviewed and approved the work takes responsibility for it.

---

## Why We Do This

Open-source software is built on trust. Our users and downstream dependants trust us to ship correct, secure, and well-considered code. AI tools help us do that work better — but they do not change who is responsible for the outcome.

We use AI because it makes our maintainers more effective, not because it replaces them.

---

## Questions and Feedback

If you have questions about our use of AI, or concerns about a specific pull request or change, please open an issue or start a discussion. We are committed to being open about our process.

---

*Last updated: 2026-03-23*
*This policy is maintained by the project maintainers and subject to revision as AI tooling and community norms evolve.*
4 changes: 4 additions & 0 deletions README.mkdn
Original file line number Diff line number Diff line change
Expand Up @@ -491,6 +491,10 @@ This will succeed:

(Using strict-mode will not fix it, even though you should use it.)

# AI POLICY

This project uses AI tools to assist development. Humans review and approve every change before it is merged. See [AI\_POLICY.md](AI_POLICY.md) for details.

# AUTHOR

Todd Rinaldo, `<toddr at cpan.org>`
Expand Down
Loading