70 lines
2.3 KiB
Markdown
70 lines
2.3 KiB
Markdown
# GitHub Burndown App
|
|
|
|
An app that displays a burndown chart for your GitHub Issues.
|
|
|
|
![image](https://raw.github.com/radekstepan/github-burndown-chart/master/example.png)
|
|
|
|
## Requirements:
|
|
|
|
You can install all the following dependencies by running:
|
|
|
|
```bash
|
|
$ npm install -d
|
|
```
|
|
|
|
- [CoffeeScript](http://coffeescript.org/)
|
|
- [express](http://expressjs.com/)
|
|
- [eco](https://github.com/sstephenson/eco)
|
|
- [js-yaml](https://github.com/visionmedia/js-yaml)
|
|
|
|
## Configure:
|
|
|
|
The app is configured by pointing to a public GitHub user/project. Do so in `config.yml`:
|
|
|
|
```yaml
|
|
github_user: 'intermine'
|
|
github_project: 'InterMine'
|
|
project_name: 'Core InterMine Project'
|
|
```
|
|
|
|
The `project_name` key-value pair represents the title of the burndown chart that you will see in the top right corner of the page.
|
|
|
|
### Milestones
|
|
|
|
Then visit your GitHub project's Issues page and create a new milestone with a date due in the future. This will represent your iteration. This app will pick the Milestone with the **closest due date in the future** as the *current* one.
|
|
|
|
### Sizes
|
|
|
|
Then assign a few labels to tickets in this Milestone. These labels will represent your perceived size of the task. The label takes a form of *size [number]* so to say that an Issue is as big as *5* points I would create and assign this label (don't worry about the colors...):
|
|
|
|
```
|
|
size 5
|
|
```
|
|
|
|
### Weekends
|
|
|
|
If you have days when you do not work on a project, edit the `config.yml` file with a list of days of the week when you are off. The numbers are 1 indexed and follow the international standard of starting a week on Monday, so for a Saturday and Sunday weekend do this:
|
|
|
|
```yaml
|
|
weekend: [ 6, 7 ]
|
|
```
|
|
|
|
### Base URL to app
|
|
|
|
If the app does not live in the root path of your server, edit the `base_url` property in the config file.
|
|
|
|
## Use:
|
|
|
|
```bash
|
|
$ node start.js
|
|
```
|
|
|
|
Then visit [http://127.0.0.1:3000/](http://127.0.0.1:3000/) or whichever port was configured in `process.env.PORT`.
|
|
|
|
The **orange line** - this represents you closing the Issues as you go through them. When you hover over it you will see, for each day, what the closed Issues were and how many points are left.
|
|
|
|
The **blue line** - this represents the dropping size of the outstanding Issues planned for the iteration/Milestone.
|
|
|
|
There is nothing to save in a database so each refresh of the page fetches all of the latest information from GitHub.
|
|
|
|
Enjoy! |