Preferences
Pixee works immediately after installation without any further configuration. Yet, Pixee exposes preferences for users to tailor its behavior when desirable.
Users may set Pixee preferences at either the organization or repository levels.
-
Repository preferences: Create a
pixeebot.yaml
file in the.github
directory of the target repository. Preferences in the target repository will take precedence over other preferences. -
Organization-wide preferences: Alternatively, you can create the
pixeebot.yaml
file in the.github
directory of your.github
repository. This will serve as the global preferences that apply to all repositories in this installation.
Properties
ai
Contains settings related to AI functionality.
allow_llm_access
true
by default.
Setting to false
disables Pixee features that rely on generative AI to analyze your code.
Example:
ai:
allow_llm_access: false
codemods
Contains optional preferences related to the codemod catalog Pixee uses to make changes to repositories.
exclude
A set of codemods to exclude from the catalog. Each codemod is identified by its codemod ID.
Example:
codemods:
exclude:
- pixee:python/https-connection
prepend
A list of non-default codemods to prepend to the codemod catalog. This list is ordinal: the continuous improvement campaign will execute the codemods in the order given.
Example:
codemods:
prepend:
- pixee:python/use-walrus-if
paths
Contains optional preferences for controlling the files and directories that are included in Pixee analysis.
exclude
A set of paths to files or directories to exclude from Pixee analysis. Each path is relative to the root of the repository. Each path in the set may be a file, directory, or UNIX glob pattern.
Example:
paths:
exclude:
- buildSrc/
Configuring automatic assignment
To automatically assign reviewers to Pixee PRs, consider setting up a CODEOWNERS
file.
To automatically assign users to Pixee PRs, consider creating a GitHub action. Below is an example action that will assign all Pixee PRs to the user Octocat:
on:
pull_request:
types: [opened, reopened, ready_for_review]
jobs:
auto-assign:
runs-on: ubuntu-latest
if: github.actor == 'pixeebot[bot]'
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Assign PR to Collaborators
uses: actions/github-script@v7
with:
script: |
const collaborators = ['octocat']; // Replace with actual GitHub usernames
github.rest.issues.addAssignees({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: context.issue.number,
assignees: collaborators
})
Please contact us at help@pixee.ai with any questions, or if you would like more options for automatic assignment.
Configuring Automatic Formatting
Many projects enforce a consistent code style by using automatic code formatters. This section contains instructions for configuring GitHub Actions to automatically format PRs that are created by Pixee.
Python
The most popular Python code formatter is Black. To automatically format PRs created by Pixee using Black, add the following GitHub action workflow to your repository:
name: Format Pixeebot PRs
on:
pull_request:
types: [opened, synchronize]
jobs:
apply-black:
if: github.event.pull_request.user.login == 'pixeebot[bot]'
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: "3.12"
- name: Install black
run: pip install black
- name: Apply black formatting
run: black .
- name: Commit and push changes
uses: stefanzweifel/git-auto-commit-action@v5
with:
commit_message: ":art: Apply formatting"
This action can be added to your repository by creating a .github/workflows/pixeebot-autoformat-black.yml
file with the above content.
Note that it may be necessary to pin the version of Black to ensure that the formatting is consistent with your project's style. Depending on your project's configuration it may also be necessary to pass additional arguments to the black
command to ensure that the correct settings are used.
Java
For Java projects it is common to use a tool such as Spotless to enforce code formatting. To automatically format PRs created by Pixee using Gradle to apply Spotless, add the following GitHub action workflow to your repository:
name: Format Pixeebot PRs
on:
pull_request:
types: [opened, synchronize]
jobs:
spotless-apply:
if: github.event.pull_request.user.login == 'pixeebot[bot]'
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- uses: actions/checkout@v4
- name: "Setup JDK"
uses: actions/setup-java@v4
with:
distribution: "temurin"
java-version: "17"
- name: 🐘Setup Gradle
uses: gradle/actions/setup-gradle@v3
- name: 🎨 Run spotless via Gradle
run: ./gradlew spotlessApply
- name: Commit and push changes
uses: stefanzweifel/git-auto-commit-action@v5
with:
commit_message: ":art: Apply formatting"
Configuring Lockfile Updates
Some Pixee fixes add dependencies to your project. For package managers that rely on lockfiles, it is important to update the lockfile after adding dependencies. We recommend using a GitHub Action to automatically update lockfiles for Pixee PRs.
Python: Poetry
Poetry is a popular Python package manager that uses a pyproject.toml
file to manage dependencies. To automatically update the Poetry lockfile for Pixee PRs that add dependencies, add the following GitHub action workflow to your repository:
name: Update Poetry Lockfile
on:
pull_request:
paths:
- "pyproject.toml"
jobs:
update-lock-file:
if: github.event.pull_request.user.login == 'pixeebot[bot]'
runs-on: ubuntu-latest
steps:
- name: Check out repository
uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: "3.11" # Specify your Python version here
- name: Install Poetry
run: pip install poetry
- name: Generate lock file
run: poetry update
- name: Commit and push changes
uses: stefanzweifel/git-auto-commit-action@v5
with:
commit_message: ":lock: Update Poetry lock file"