# Introduction

\*Pull request analysis is available starting in [*Developer Edition*](https://www.sonarsource.com/plans-and-pricing/developer/). \*

A pull request analysis occurs when a pull request is opened and every time a change is pushed to the pull request branch. Analysis results only include issues that have been introduced by the pull request itself. A quality gate on the pull request uses these results to ensure that the code changes introduced are always clean.

The pull request analysis must be integrated into a CI pipeline. For more information, see **Integration into your CI pipeline** on the [analysis-overview](https://docs.sonarsource.com/sonarqube-server/10.8/analyzing-source-code/analysis-overview "mention") page.

{% hint style="info" %}
The term *pull request* is used by most repository providers. GitLab, however, uses the term "merge request". Both terms refer to the same functionality and are handled equivalently in Sonar products. In our documentation, any use of the term *pull request* applies equally to GitLab merge requests.
{% endhint %}

## Improving code quality <a href="#clean-as-you-code" id="clean-as-you-code"></a>

The Quality Gate of your project is used for the pull request analyses. Only the Quality Gate’s conditions applying to new code metrics are used.

In a pull request analysis, new code is defined as the code that has changed in the pull request branch compared to the target branch. Only issues on new code are reported.

{% hint style="warning" %}

* Due to its mechanism for identifying issues on new code, pull request analysis doesn’t report issues raised at the file level.
* During a pull request analysis, new issues on old code are not reported since only new code issues are reported (For more information, see **Issue backdating (new issues on old code)** in [solution-overview](https://docs.sonarsource.com/sonarqube-server/10.8/user-guide/issues/solution-overview "mention").). It means that the first analysis on the target branch after the merge may report new issues on old code that were not reported by the pull request analysis.
  {% endhint %}

{% hint style="info" %}
To get valuable results when performing a pull request analysis, the target branch should have been analyzed first.
{% endhint %}

## Quality gate status report (pull request decoration) <a href="#decoration" id="decoration"></a>

The pull request analysis results and quality gate status can be reported directly to your DevOps platform’s interface.

## Incremental pull request analysis <a href="#incremental-pull-request-analysis" id="incremental-pull-request-analysis"></a>

To shorten the pull request analysis, different [introduction](https://docs.sonarsource.com/sonarqube-server/10.8/analyzing-source-code/incremental-analysis/introduction "mention") are used.

## Issue synchronization <a href="#issue-synchronization" id="issue-synchronization"></a>

SonarQube Server synchronizes issue attributes (status, assignee, change log, comments) between the pull request and the target branch. For more information, see the corresponding section in [solution-overview](https://docs.sonarsource.com/sonarqube-server/10.8/user-guide/issues/solution-overview "mention"). Note that security hotspots are not synchronized.

## Related pages <a href="#related-pages" id="related-pages"></a>

* [setting-up-the-pull-request-analysis](https://docs.sonarsource.com/sonarqube-server/10.8/analyzing-source-code/pull-request-analysis/setting-up-the-pull-request-analysis "mention")
* [maintaining-the-branches-of-your-project](https://docs.sonarsource.com/sonarqube-server/10.8/project-administration/maintaining-the-branches-of-your-project "mention").
* [introduction](https://docs.sonarsource.com/sonarqube-server/10.8/analyzing-source-code/incremental-analysis/introduction "mention")


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.sonarsource.com/sonarqube-server/10.8/analyzing-source-code/pull-request-analysis/introduction.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
