Testing githib warden

How to run

Change dockerfile: need to add SECRET_TOKEN and BUGZILLA_API_KEY

Or from docker-compose

docker-compose up -d

There are easy way to update warden if you use docker-compose

docker-compose up --build -d

Don't forget to change important variables from docker_compose file:

How it works

After any push to repo, that we activate webhooks, github will sent post request to server. This request contains commit message and other data. Server take all of them, and if message of commit is matched with pattern, and if commit has pushed to allowed repository and to allowed branch, action will be added to redis queue. Actions will not be perform if bug is contains comment with hash of commit.

At now, there are two actions: add comment and change status to RESOLVED.

  • If commit message contain word "Bug" (or "bug"), and after it will be placed number (like "123456", or "#123456"), this bug will be commented.
  • If commit message contain word "Fix" (or "Fixed") + "Bug" (or "bug") + number (like "123456", or "#123456"), bug with id "123456" will be commented, and status will be changed.
  • Only "NEW", "REOPENED" or "ASSIGNED" statuses can be changed

Examples for changing status and commented: "Fix bug 123456", "fixed bug #123456 and other message", "FIxEd bUg #123456"

Examples for only comments: "For Bug #123456", "This text have no matter bUG 123456"

WARNING You can only close one bug via single commit. Until #82 is resolved

Adding new repo to list of repos

This process consists or three steps:

  1. Add repo to config/allowed_branches.yml. Example is PR like that
  2. Update backend service, what running on one of our servers. Only server administrators can do that.
  3. On repository side - new WebHook registration is required. Go to Settings -> Webhooks -> Add webhook and
    fill form like on screenshot below:

Webhook settings screenshot

Adding new event

Config for new pattern: config/warden_config.yml

Example:

  :commit_message_pattern: 'commit message'
  :action: 'action'

All of this fields is a regular expression, but don't need to add / / in start and end in this. Action is a custom name of action. Feel free to set something.

Adding repository and branch to allowed

Need to change config/allowed_branches.yml for adding repositories and branches to allowed list. Example:

    -
        :repository_name_array: ['repo_name']
        :branch_pattern: 'branch_name|other_branch_name'

repository_name_array must be array, branch_pattern must be regexp

For developer

testing-github-warden is contains of 3 services: redis, warden and executer.

  • Redis must share socket for work.
  • Warden listen 3000 port and push data for actions to redis.
  • Executer listen redis and execute every action.

For testing

Run server and tests in same keys:

SECRET_TOKEN='1234' BUGZILLA_API_KEY='<api key>' docker-compose up -d
SECRET_TOKEN='1234' BUGZILLA_API_KEY='<api key>' bundle exec rspec spec/tests/

For debugging

If you want to debugging server, you need to run it without docker.

For running server on debug, use config.ru file, and don't forget to add env variables to this file if you using IDE with special environment space (like rubymine)

For running test on debug, change spec/data/static_data.rb:PORT to 9292, and add env variables to spec/spec_helper.rb