The describe
tool scans the PR code changes, and generates a description for the PR - title, type, summary, walkthrough and labels.
The tool can be triggered automatically every time a new PR is opened, or it can be invoked manually by commenting on any PR:
/describe
For example:
This feature is available only in PR-Agent Pro
You can control the custom labels that will be suggested by the describe
tool, from the repo's labels page:
- GitHub : go to
https://github.com/{owner}/{repo}/labels
(or click on the "Labels" tab in the issues or PRs page) - GitLab : go to
https://gitlab.com/{owner}/{repo}/-/labels
(or click on "Manage" -> "Labels" on the left menu)
Now add/edit the custom labels. they should be formatted as follows:
- Label name: The name of the custom label.
- Description: Start the description of with prefix
pr_agent:
, for example:pr_agent: Description of when AI should suggest this label
.
The description should be comprehensive and detailed, indicating when to add the desired label. For example:
To edit configurations related to the describe tool, use the following template:
/describe --pr_description.some_config1=... --pr_description.some_config2=...
Possible configurations:
-
publish_labels
: if set to true, the tool will publish the labels to the PR. Default is true. -
publish_description_as_comment
: if set to true, the tool will publish the description as a comment to the PR. If false, it will overwrite the origianl description. Default is false. -
add_original_user_description
: if set to true, the tool will add the original user description to the generated description. Default is false. -
keep_original_user_title
: if set to true, the tool will keep the original PR title, and won't change it. Default is false. -
extra_instructions
: Optional extra instructions to the tool. For example: "focus on the changes in the file X. Ignore change in ...". -
To enable
custom labels
, apply the configuration changes described here -
enable_pr_type
: if set to false, it will not show thePR type
as a text value in the description content. Default is true. -
final_update_message
: if set to true, it will add a comment messagePR Description updated to latest commit...
after finishing calling/describe
. Default is true. -
enable_semantic_files_types
: if set to true, "Changes walkthrough" section will be generated. Default is true. -
collapsible_file_list
: if set to true, the file list in the "Changes walkthrough" section will be collapsible. If set to "adaptive", the file list will be collapsible only if there are more than 8 files. Default is "adaptive".
To enable markers, set pr_description.use_description_markers=true
.
markers enable to easily integrate user's content and auto-generated content, with a template-like mechanism.
For example, if the PR original description was:
User content...
## PR Type:
pr_agent:type
## PR Description:
pr_agent:summary
## PR Walkthrough:
pr_agent:walkthrough
The marker pr_agent:type
will be replaced with the PR type, pr_agent:summary
will be replaced with the PR summary, and pr_agent:walkthrough
will be replaced with the PR walkthrough.
==>
Configuration params:
use_description_markers
: if set to true, the tool will use markers template. It replaces every marker of the formpr_agent:marker_name
with the relevant content. Default is false.include_generated_by_header
: if set to true, the tool will add a dedicated header: 'Generated by PR Agent at ...' to any automatic content. Default is true.
- When you first install the app, the default mode for the describe tool is:
pr_commands = ["describe --pr_description.add_original_user_description=true
--pr_description.keep_original_user_title=true", ...]
meaning the describe
tool will run automatically on every PR, will keep the original title, and will add the original user description above the generated description.
This default is quite conservative, and strikes a good balance between automation and control:
If you want more automation, just give the PR a title, and the tool will auto-write a full description; If you want more control, you can add a detailed description, and the tool will add the complementary description below it.
- For maximal automation, you can change the default mode to:
pr_commands = ["describe --pr_description.add_original_user_description=false
--pr_description.keep_original_user_title=true", ...]
so the title will be auto-generated as well.
- Markers are an alternative way to control the generated description, to give maximal control to the user. If you set:
pr_commands = ["describe --pr_description.use_description_markers=true", ...]
the tool will replace every marker of the form pr_agent:marker_name
in the PR description with the relevant content, where marker_name
is one of the following:
type
: the PR type.summary
: the PR summary.walkthrough
: the PR walkthrough.
Note that when markers are enabled, if the original PR description does not contain any markers, the tool will not alter the description at all.
The default labels of the describe tool are quite generic, since they are meant to be used in any repo: [Bug fix
, Tests
, Enhancement
, Documentation
, Other
].
If you specify custom labels in the repo's labels page, you can get tailored labels for your use cases. Examples for custom labels:
Main topic:performence
- pr_agent:The main topic of this PR is performanceNew endpoint
- pr_agent:A new endpoint was added in this PRSQL query
- pr_agent:A new SQL query was added in this PRDockerfile changes
- pr_agent:The PR contains changes in the Dockerfile- ...
The list above is eclectic, and aims to give an idea of different possibilities. Define the custom labels that are relevant for your repo and use cases. Note that Labels are not mutually exclusive, so you can add multiple label categories. Make sure to provide proper title, and detailed and well-phrased description for each label, so the tool will know when to suggest it.