Skip to content

haadcode/labels-and-milestones

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

labels-and-milestones

Sync labels and milestones across Github repositories

Labels and milestones are set in config.yml. The project is hooked to CI. When a new version of config.yml is committed to master, CI will run the sync script automatically.

To run the sync locally, do:

export GITHUB_TOKEN=token
npm run lint
npm run sync

See original README below for details.


Starter Project for github-sync-labels-milestones

This is a project to quickly get started using Jimdo/github-sync-labels-milestones for syncing milestones and labels across Github repos, especially using CI.

The intended workflow is:

  1. Update config.yml with new milestones and labels
  2. Commit and push to a git repo (preferably via pull request)
  3. CI syncs labels and milestones across target Github repos

For more info on github-sync-labels-milestones see https://github.com/Jimdo/github-sync-labels-milestones

Usage

Prerequisites

  • Set GITHUB_TOKEN env var to Github personal access token
  • Install node/npm
  • Install Ruby and bundler (http://bundler.io/)
  • Clone this repo and delete .git directory

Configuration

For additional details on using gslm, see https://github.com/Jimdo/github-sync-labels-milestones

Target Repos

In config.yml place target repo slugs in a list under repositories

Labels and Milestones

config.yml has example labels and milestones. Follow the examples and gslm docs to create your desired config.

(optional) git user for CI

In do-release.sh uncomment the lines that configure the git user settings and replace the name and email with your or your CI account's settings.

Syncing

Running locally

First install dependencies

npm install
bundle install

To ensure your yaml is valid, first run

npm run lint

If you just want to perform syncs locally, just run

npm run sync

This command will read config.yml and sync the labels and milestones to the target repos.

Running via CI

Syncing and versioning your configs are easiest when done via CI. Setting this up is quick and painless:

  1. Create a git repo for your config and populate it with this starter project
  2. Set the GITHUB_TOKEN env var in CI to your Github personal access token
  3. (optional) Ensure that CI has write access to your git repo
  4. Configure CI to install dependencies (npm install and bundle install)
  5. Configure the CI test command to be npm run lint
  6. Configure the CI deployment command to be npm run sync
  7. (optional) After npm run sync run npm run release
    • This will create and push a git tag on every sync

circle.yml will make sync and release work out of the box using CircleCI (https://circleci.com/). PRs welcome for configs for other CI services.

About

Starter Project for github-sync-labels-milestones

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 93.5%
  • Ruby 6.5%