Samurai is a command-line tool to simplify and automate the deployment initiation process for your projects hosted on GitHub. This tool integrates with GitHub, Slack, and utilizes several Ruby gems to streamline the creation of release branches, pull requests, notifications, and email notifications.
To install this gem:
- Clone the Repo.
cd
into the repo location on your local system.- Run:
gem build samurai.gemspec && gem install samurai-0.1.0.gem
. - Run:
echo 'export PATH="$HOME/.gem/bin:$PATH"' >> ~/.zshrc
.
- Go to releases and download the latest release.
- Run:
gem install samurai-0.1.0.gem
.
On rubygems.org, there is another gem with the same name, thats why this specific gem cannot be installed with
gem install samurai
Before using Samurai, you need to configure it for your repository. This configuration includes setting up your GitHub token, source and target branches, Slack notifications, and email notifications if needed. Run the following command at the location of your GitHub repo setup on your local system to start the interactive configuration process:
samurai config
This command will prompt you to enter the necessary configuration details, including:
- GitHub repository location
- GitHub token
- Source branch name (default: staging)
- Target branch name (default: master)
- Slack notification preferences
- Email notification preferences
If you choose to inform about releases on Slack, you will also be prompted to enter:
- Slack channel name
- Slack user name
- Slack webhook URL
- Slack icon emoji
If you choose to send email notifications, you will also be prompted to enter:
- SMTP settings
- Receiver email
- Sender email
- CC emails
The configuration is saved in ~/.samurai.config
.
Once configured, you can use Samurai to prepare for deployment by executing the following command:
samurai execute
This command will:
- Stash any existing changes.
- Reset the repository to its original state.
- Pull the latest changes from the target branch.
- Pull the latest changes from the source branch.
- Create a new release branch.
- Push the release branch to the remote repository.
- Create a pull request for the release branch.
- Notify the configured Slack channel about the release (if enabled).
- Send email notifications about the release (if enabled).
$ samurai config
Enter the GitHub repository local setup location: /path/to/repo
Enter your GitHub token: **********
What is your source branch? (staging)
What is your target branch? (master)
Inform about releases on slack? (yes)
Enter the slack channel name (releases)
Enter the slack user name (Bot)
Enter the slack webhook url: https://hooks.slack.com/services/your/webhook/url
What slack icon emoji do you want to use? (:rocket:)
Send email notifications? (yes)
SMTP address: smtp.example.com
SMTP port: 587
SMTP domain: example.com
SMTP username: user@example.com
SMTP password: **********
SMTP authentication method (plain, login, cram_md5): plain
Enable STARTTLS (yes/no): yes
Receiver email: receiver@example.com
Sender email: sender@example.com
Comma separated CC emails: cc1@example.com,cc2@example.com
Configuration saved for /path/to/repo
$ samurai execute
Make sure your paths are clean and there is nothing to commit
Stashing existing changes (if any)
Resetting original repository state
Pulling master
Pulling staging
Created a release branch release-14.06.24_12_30
Pushed release branch release-14.06.24_12_30
Created Release PR https://github.com/your/repo/pull/123
Fetching release PR details...
PUSHED master AND TAG 14.06.24_12_30
To contribute to Samurai, follow these steps:
- Fork the repository.
- Create a feature branch (
git checkout -b feature-branch
). - Commit your changes (
git commit -am 'Add new feature'
). - Push to the branch (
git push origin feature-branch
). - Create a new Pull Request.
Tip You can use a single comand to test your changes:
rm -rf samurai-0.1.0.gem && gem uninstall samurai && gem build samurai.gemspec && gem install samurai-0.1.0.gem
Samurai is available under the MIT License.
Samurai uses the following Ruby gems:
- Thor for command-line interface
- Octokit for GitHub API integration
- HighLine for interactive command-line input
- Slack Notifier for Slack notifications
- RestClient for making HTTP requests