bugbug/README.md

84 строки
4.9 KiB
Markdown
Исходник Обычный вид История

# bugbug
2019-06-09 02:03:22 +03:00
[![Task Status](https://github.taskcluster.net/v1/repository/mozilla/bugbug/master/badge.svg)](https://github.taskcluster.net/v1/repository/mozilla/bugbug/master/badge.svg)
## Classifiers
- **assignee** - The aim of this classifier is to suggest an appropriate assignee for a bug.
- **backout** - The aim of this classifier is to detect patches that might be more likely to be backed-out (because of build or test failures). It could be used for test prioritization/scheduling purposes.
2019-02-20 03:10:12 +03:00
- **bugtype** - The aim of this classifier is to classify bugs according to their type.
2019-02-20 03:10:12 +03:00
- **component** - The aim of this classifier is to assign product/component to (untriaged) bugs.
- **defect vs enhancement vs task** - Extension of the **defect** classifier to detect differences also between feature requests and development tasks.
- **defect** - Bugs on Bugzilla aren't always bugs. Sometimes they are feature requests, refactorings, and so on. The aim of this classifier is to distinguish between bugs that are actually bugs and bugs that aren't. The dataset currently contains 2110 bugs, the accuracy of the current classifier is ~93% (precision ~95%, recall ~94%).
2018-12-21 16:46:42 +03:00
2019-02-20 03:10:12 +03:00
- **devdocneeded** - The aim of this classifier is to detect bugs which should be documented for developers.
- **duplicate** - The aim of this classifier is to detect duplicate bugs.
2019-02-20 03:10:12 +03:00
- **qaneeded** - The aim of this classifier is to detect bugs that would need QA verification.
- **regression vs non-regression** - Bugzilla has a `regression` keyword to identify bugs that are regressions. Unfortunately it isn't used consistently. The aim of this classifier is to detect bugs that are regressions.
- **regressionrange** - The aim of this classifier is to detect regression bugs that have a regression range vs those that don't.
- **regressor** - The aim of this classifier is to detect patches which are more likely to cause regressions. It could be used to make riskier patches undergo more scrutiny.
- **stepstoreproduce** - The aim of this classifier is to detect bugs that have steps to reproduce vs those that don't.
- **tracking** - The aim of this classifier is to detect bugs to track.
- **uplift** - The aim of this classifier is to detect bugs for which uplift should be approved and bugs for which uplift should not be approved.
## Setup
2018-11-20 19:24:02 +03:00
Run `pip install -r requirements.txt` and `pip install -r test-requirements.txt`
If you update the bugs database, run `xz -v9 -k data/bugs.json`.
If you update the commits database, run `xz -v9 -k data/commits.json`.
2018-12-22 04:34:09 +03:00
## Usage
2019-01-16 23:46:52 +03:00
Run the `run.py` script to perform training / classification. The first time `run.py` is executed, the `--train` argument should be used to automatically download databases containing bugs and commits data.
### Running the repository mining script
1. Clone https://hg.mozilla.org/mozilla-central/.
2. Run `./mach vcs-setup` in the directory where you have cloned mozilla-central.
3. Enable the pushlog, hgmo and mozext extensions. For example, if you are on Linux, add the following to the extensions section of the `~/.hgrc` file:
```
2019-03-19 02:56:59 +03:00
pushlog = ~/.mozbuild/version-control-tools/hgext/pushlog
hgmo = ~/.mozbuild/version-control-tools/hgext/hgmo
mozext = ~/.mozbuild/version-control-tools/hgext/mozext
firefoxtree = ~/.mozbuild/version-control-tools/hgext/firefoxtree
```
3. Run the `repository.py` script, with the only argument being the path to the mozilla-central repository.
Note: the script will take a long time to run (on my laptop more than 7 hours). If you want to test a simple change and you don't intend to actually mine the data, you can modify the repository.py script to limit the number of analyzed commits. Simply add `limit=1024` to the call to the `log` command.
## Structure of the project
- `bugbug/labels` contains manually collected labels;
- `bugbug/db.py` is an implementation of a really simple JSON database;
- `bugbug/bugzilla.py` contains the functions to retrieve bugs from the Bugzilla tracking system;
- `bugbug/repository.py` contains the functions to mine data from the mozilla-central (Firefox) repository;
- `bugbug/bug_features.py` contains functions to extract features from bug/commit data;
- `bugbug/model.py` contains the base class that all models derive from;
- `bugbug/models` contains implementations of specific models;
- `bugbug/nn.py` contains utility functions to include Keras models into a scikit-learn pipeline;
- `bugbug/utils.py` contains misc utility functions;
- `bugbug/nlp` contains utility functions for NLP;
- `bugbug/labels.py` contains utility functions for handling labels;
- `bugbug/bug_snapshot.py` contains a module to play back the history of a bug.
## Auto-formatting setup
This project is using [pre-commit](https://pre-commit.com/). Please run `pre-commit install` to install the git pre-commit hooks on your clone.
Then every time you will try to commit, it will check that the files are correctly formatted before letting you commit.