Run Coverity once per month
[qBittorrent.git] / CONTRIBUTING.md
bloba14e4ff3efdda41c90a8dc9bbeedd2595e4b2b13
1 # How to contribute to qBittorrent
3 There are three main ways to contribute to the project.
4 Read the respective section to find out more.
6 ### Table Of Contents
8 *   **[Bug reporting etiquette](#bug-reporting-etiquette)**
11 *   **[Submitting an issue/bug report](#submitting-an-issuebug-report)**
12     *   [What is an actual bug report?](#what-is-an-actual-bug-report)
13     *   [Before submitting a bug report](#before-submitting-a-bug-report)
14     *   [Steps to ensure a good bug report](#steps-to-ensure-a-good-bug-report)
17 *   **[Suggesting enhancements/feature requests](#suggesting-enhancementsfeature-requests)**
18     *   [Before submitting an enhancement/feature request](#before-submitting-an-enhancementfeature-request)
19     *   [Steps to ensure a good enhancement/feature suggestion](#steps-to-ensure-a-good-enhancementfeature-suggestion)
22 *   **[Opening a pull request](#opening-a-pull-request)**
23     *   [Must read](#must-read)
24     *   [Good to know](#good-to-know)
26 # Bug reporting etiquette
28 *   Issues, pull requests, and comments must always be in **English.**
30 *   This project is supported by volunteers, do not expect "customer support"-style interaction.
32 *   **Be patient.** The development team is small and resource limited. Developers and contributors take from their free time to analyze the problem and fix the issue. :clock3:
34 *   Harsh words or threats won't help your situation. What's worse, your complain will (very likely) be **ignored.** :fearful:
36 # Submitting an issue/bug report
38 This section guides you through submitting an issue/bug report for qBittorrent.
40 Following these guidelines helps maintainers and the community understand your report, reproduce the behavior, and find related reports.
42 Make sure to follow these rules carefully when submitting a bug report. Failure to do so will result in the issue being closed.
44 ## What is an actual bug report?
46 Developers and contributors are not supposed to deal with issues for which little to no investigation to find the actual cause of a purported issue was made by the reporter.
48 Positive contributions are those which are reported with efforts to find the actual cause of an issue, or at the very least efforts were made to narrow it as much as possible.
50 Requiring people to investigate as much as possible before opening an issue will more than likely avoid burdening the project with invalid issues or issues unrelated to qBittorrent.
52 The following are _not_ bug reports. **Check the [wiki][wiki-url], [forum][forum-url] or other places for help and support for issues like these**:
54 -   Explanation of qBittorrent options (see [wiki][wiki-url]).
55 -   Help with WebUI setup.
56 -   Help with embedded tracker setup.
57 -   Help about BitTorrent in general.
58 -   Issues with specific search plugins.
59 -   Asking for specific builds of qBittorrent other than the current one. You can install older releases at your own risk or for regression testing purposes. Previous Windows and macOS builds are available [here][builds-url].
60     -   If you want older Linux builds, you will have to compile them yourself from the corresponding commits, or ask someone on the [forum][forum-url] to do it for you.
61 -   Possibly others. Read on and use common sense.
63 The issue tracker is for provable issues only: You will have to make the case that the issue is really with qBittorrent and not something else on your side.
65 To make a case means to provide detailed steps so that anybody can reproduce the issue.
66 Be sure to rule out that the issue is not caused by something specific on your side.
68 Issue reports for bugs that apparently aren't easily reproducible or that you can't figure out what triggers it even though you tried are OK.
70 Any issue opened without effort to provide the required details for developers, contributors or anybody else to reproduce the problem will be closed as invalid.
71 For example:
72 -   Crash reports with just a stack trace.
73 -   Speculated performance issues that do not come with actual profiling data + analysis supporting the claim.
75 ## Before submitting a bug report
77 -   **Do some basic troubleshooting (examples)**:
78     -   Restart qBittorrent.
79     -   Restart your PC.
80     -   Update your OS (e.g. Windows updates).
81     -   Update your network card drivers.
82     -   Fully reinstall qBittorrent.
83     -   etc...
84 -   Make sure the problem is not caused by anti-virus or other program messing with your files.
85 -   Check if you can reproduce the problem in the latest version of qBittorrent.
86 -   **Check [forum][forum-url] and [wiki][wiki-url].** You might be able to find the cause of the problem and fix things yourself.
87 -   **Check if the issue exists already in the issue tracker.**
88     -   If it does and the issue is still open, add a comment to the existing issue instead of opening a new one.
89     -   If you find a Closed issue that seems like it is the same thing that you're experiencing, open a new issue and include a link to the original issue in the body of your new one.
90 -   If the issue is with the search functionality:
91     -   **Make sure you have [`python`][python-url] installed correctly (remember the search functionality requires a working python installation).**
92     -   Make sure it is in fact a problem with the search functionality itself, and not a problem with the plugins. If something does not work properly with the search functionality, the first step is to rule out search plugin-related issues.
93         -   For search plugin issues, report on the respective search plugin support page, or at [qbittorrent/search-plugins][search-plugins-url].
95 ## Steps to ensure a good bug report
97 **Follow these guidelines** in order to provide as much useful information as possible right away. Not all of them are applicable to all issues, but you are expected to follow most of these steps (use common sense).
98 Otherwise, we've noticed that a lot of your time (and the developers') gets thrown away on exchanging back and forth to get this information.
100 *   Use a **clear and descriptive title** for the issue to identify the problem.
102 *   Post only **one specific issue per submission.**
104 *   **Fill out the issue template properly.**
106 -   **Make sure you are using qBittorrent on a supported platform.** Do not submit issues which can only be reproduced on beta/unsupported releases of supported operating systems (e.g. Windows 10 Insider, Ubuntu 12.04 LTS, etc).
107 These are unstable/unsupported platforms, and in all likelihood, whatever the issue is, it is not related to qBittorrent.
109 *   **Specify the OS you're using, its version and architecture.**
110     *   Examples: Windows 8.1 32-bit, Linux Mint 17.1 64-bit, Windows 10 Fall creators Update 64-bit, etc.
113 *   **Report only if you run into the issue with an official stable release, a beta release, or with the most recent upstream changes (in this last case specify the specific commit you are on).** (beta testing is encouraged :smile:). We do not provide support for bugs on unofficial Windows builds.
115 *   **Specify the version of qBittorrent** you are using, as well as its **architecture** (x86 or x64) and its **libraries' versions** (Help -> About -> Libraries).
117 *   Specify **how you installed**:
118     -   Linux: either from the PPA, your distribution's repositories, or compiled from source, or even possibly third-party repositories.
119     -   Windows: either from the installer, or compiled from source, or even possibly third-party repositories.
120     -   macOS: either from the installer, or compiled from source, or even possibly third-party repositories.
123 *   **Describe the exact steps which reproduce the problem in as many details as possible.**
124     -   For example, start by explaining how you started qBittorrent, e.g. was it via the terminal? Desktop icon? Did you start it as root or normal user?
125     -   **When listing steps, don't just say what you did, but explain how you did it.**
126         -   For example, if you added a torrent for download, did you do so via a `.torrent` file or via a magnet link? If it was with a torrent file did you do so by dragging the torrent file from the file manager to the transfer list, or did you use the "Add Torrent File" in the Top Bar?
127     -   Describe the behavior you observed after following the steps and point out what exactly is the problem with that behavior; this is what we'll be looking for after executing the steps.
130 *   **Explain which behavior you expected to see instead** and why.
132 *   Use **screenshots/animated GIFs to help describe the issue** whenever appropriate [(How?)][attachments-howto-url].
134 *   If the problem wasn't triggered by a specific action, describe what you were doing before the problem happened.
136 *   **If you are reporting that qBittorrent crashes**, include the stack trace in the report; include it in a code block, a file attachment, or put it in a gist and provide link to that gist.
138 *   **For performance-related issues**, include as much profiling data as you can (resource usage graphs, etc).
140 *   Paste the **qBittorrent log** (or put the contents of the log in a gist and provide a link to the gist). The log can be viewed in the GUI (View -> Log -> tick all boxes). If you can't do that, the file is at:
141     -   Linux: `~/.local/share/qBittorrent/logs/qBittorrent.log`
142     -   Windows: `%LocalAppData%\qBittorrent\logs`
143     -   macOS: `~/Library/Application Support/qBittorrent/qBittorrent.log`
146 *   **Do NOT post comments like "+1" or "me too!"** without providing new relevant info on the issue. Using the built-in reactions is OK though. Remember that you can use the "subscribe" button to receive notifications of that report without having to comment first.
148 *   If there seems to be an **issue with specific torrent files/magnet links**:
149     -   Don't post private `.torrent` files/magnet links, or ones that point to copyrighted content. If you are willing, offer to email a link or the `.torrent` file itself to whoever developer is debugging it and requests it.
150     -   Make sure you can't reproduce the problem with another client, to rule out the possibility that the issue is with the `.torrent` file/magnet link itself.
153 *   A screenshot, transcription or file upload of any of **qBittorrent's preferences that differ from the defaults.** Please include everything different from the defaults whether or not it seems relevant to your issue.
155 *   **Attachment rules**:
156     -   Short logs and error messages can be pasted as quotes/code whenever small enough; otherwise make a gist with the contents and post the link to the gist.
157     -   Avoid linking/attaching impractical file formats such as PDFs/Word documents with images. If you want to post an image, just post the image.
159 ### Provide more context by answering these questions (if applicable):
161 -   Can you **reliably reproduce the issue?** If not, provide details about how often the problem happens and under which conditions it normally happens (e.g. only happens with extremely large torrents/only happens after qBittorrent is open for more than 2 days/etc...)
163 -   Did the problem start happening recently (e.g. after updating to a new version of qBittorrent) or was this always a problem?
165 -   If the problem started happening recently, can you reproduce the problem in an older version of qBittorrent?
167 -   Are you saving files locally (in a disk in your machine), or are you saving them remotely (e.g. network drives)?
169 -   Are you using qBittorrent with multiple monitors? If so, can you reproduce the problem when you use a single monitor?
171 Good read: [How to Report Bugs Effectively][howto-report-bugs-url]
173 # Suggesting enhancements/feature requests
175 This section guides you through submitting an enhancement suggestion for qBittorrent, including completely new features and minor improvements to existing functionality.
177 Following these guidelines helps maintainers and the community understand your suggestion and find related suggestions.
179 ## Before submitting an enhancement/feature request
181 *   Check the [wiki][wiki-url] and [forum][forum-url] for tips — you might discover that the enhancement is already available.
182 *   Most importantly, check if you're using the latest version of qBittorrent and if you can get the desired behavior by changing qBittorrent's settings.
183 *   Check in the [releases][releases-url] page or on the [forum][forum-url], see if there's already a alpha/beta version with that enhancement.
184 *   Perform a cursory search to see if the enhancement has already been suggested. If it has, add a comment to the existing issue instead of opening a new one.
186 ## Steps to ensure a good enhancement/feature suggestion
188 -   Specify which version of qBittorrent you're using.
189 -   Specify the name and version of the OS you're using.
190 -   Provide a step-by-step description of the suggested enhancement in as many details as possible.
191 -   Describe the current behavior and explain which behavior you expected to see instead and why.
192 -   Include screenshots and animated GIFs which help you demonstrate the steps or point out the part of qBittorrent which the suggestion is related to.
193 -   If this enhancement exists in other BitTorrent clients, list those clients.
195 # Opening a pull request
197 ### Must read
198 *   Read our [**coding guidelines**][coding-guidelines-url]. There are some scripts to help you: [uncrustify script][uncrustify-script-url], [astyle script][astyle-script-url], [(related thread)][coding-guidelines-thread-url].
199 *   Keep the title **short** and provide a **clear** description about what your pull request does.
200 *   Provide **screenshots** for UI related changes.
201 *   Keep your git commit history **clean** and **precise.** Refer to the section about "Git commit messages" in the [**coding guidelines**][coding-guidelines-url].
202 *   If your commit fixes a reported issue (for example #4134), add the following message to the commit `Closes #4134.`. Example [here][commit-message-fix-issue-example-url].
204 ### Good to know
205 *   **Search** pull request history! Others might have already implemented your idea and it is waiting to be merged (or got rejected already). Save your precious time by doing a search first.
206 *   When resolving merge conflicts, do `git rebase <target_branch_name>`, don't do `git pull`. Then you can start fixing the conflicts. Here is a good explanation: [link][merging-vs-rebasing-url].
208 [astyle-script-url]: https://gist.github.com/Chocobo1/539cee860d1eef0acfa6
209 [attachments-howto-url]: https://help.github.com/articles/file-attachments-on-issues-and-pull-requests
210 [coding-guidelines-url]: https://github.com/qbittorrent/qBittorrent/blob/master/CODING_GUIDELINES.md
211 [coding-guidelines-thread-url]: https://github.com/qbittorrent/qBittorrent/issues/2192
212 [commit-message-fix-issue-example-url]: https://github.com/qbittorrent/qBittorrent/commit/c07cd440cd46345297debb47cb260f8688975f50
213 [forum-url]: http://forum.qbittorrent.org/
214 [howto-report-bugs-url]: https://www.chiark.greenend.org.uk/~sgtatham/bugs.html
215 [merging-vs-rebasing-url]: https://www.atlassian.com/git/tutorials/merging-vs-rebasing
216 [python-url]: https://www.python.org/
217 [releases-url]: https://github.com/qbittorrent/qBittorrent/releases
218 [search-plugins-url]: https://github.com/qbittorrent/search-plugins
219 [uncrustify-script-url]: https://raw.githubusercontent.com/qbittorrent/qBittorrent/master/uncrustify.cfg
220 [wiki-url]: https://github.com/qbittorrent/qBittorrent/wiki
221 [builds-url]: https://sourceforge.net/projects/qbittorrent/files/