- Dependencies
- Run tests
- How use hooks
- Style guide
- Making changes to tracked branches
- Setup protectection for repo
- Git useful links
- bash 4+
- Install bats
git clone https://github.com/sstephenson/bats.git
sudo bats/install.sh /usr/local
rm -rf bats
- Run tests
cd tests
./all-tests.sh
git clone [email protected]:pdffiller/styleguide-hooks.git
cd styleguide-hooks
git checkout v0.2.2.0 2>/dev/null && git status
cd -
You should see HEAD detached at v0.2.2.0
.
2. Set it up as your template directory
git config --global init.templatedir $(pwd)/styleguide-hooks
You may ignore the remainder nevertheless it's better to follow the next steps in order to avoid running git init
each time the 'global' hooks are changed or updated.
git config --global core.hooksPath $(pwd)/styleguide-hooks/hooks
After every git clone
and git checkout
the post-checkout hook will create or recreate symlink to your hooks directory. Documentation.
- Look into
hooks/_default_settings.sh
If you'd like to change something: - Create
hooks/_user_defined_settings.sh
- Copy settings for change from
default
touser_defined
- Change settings in
hooks/_user_defined_settings.sh
Constant | What it changes | Default | Affects |
---|---|---|---|
COLOR_INFO |
Change default output color for Information messages. Available colors. |
"Light_Blue" |
pre-commit |
COLOR_WARNING |
Change default output color for Warning. Ineractive messages. Available colors. |
"Yellow" |
pre-commit , post-checkout |
IGNORE_TRAILING_ SPACE_EXTENTIONS |
Ignore trailing whitespaces for specified file extentions. Format ext1|ext2|ext3 . |
"md|rst" |
pre-commit |
INTERACTIVE_MODE |
Pseudo-interactive mode for: 1. Replacing trailing whitespaces 2. Removing multilines at EOF 3. Adding new line at EOF if it doesn't exist Can be disabled or enabled . |
"disabled" |
pre-commit |
FORСE_WARNING_TO_ERROR |
Forсing exit if enabled. Affects "Too many changes per one commit" check. Can be disabled or enabled . |
"disabled" |
pre-commit |
FOOTER |
Styleguide message that is added to every error message. | [1] | pre-commit |
GITHUB_REGEX |
Regex for matching Github issue inside branch name. A link to issue is created if a match was found. | '^[0-9]+$' |
pre-commit ,prepare-commit-msg |
JIRA_ISSUE_LINK |
Link to Jira task endpoint. | [2] | prepare-commit-msg |
JIRA_REGEX |
Regex for matching Jira issue inside branch name. A link to issue is created if a match was found. Default Jira regex. |
'^[A-Z]{2,}-[0-9]+' |
pre-commit ,prepare-commit-msg |
STYLE_GUIDE_LINK |
Commit message styleguide format link. | [3] | prepare-commit-msg |
CHECK_FOR_UPDATES_EVERY |
Set how often to check for updates. Format as in date command. |
1 week |
post-checkout |
FOOTER="\n
Our style guide can be found at:
https://github.com/pdffiller/styleguide-hooks#branch-naming-format
A quick way to rename your branch:
git branch -m NEW_BRANCH_NAME
"
declare -A JIRA_ISSUE_LINK=(
["org_name_in_github"]="https://org_name_in_jira.atlassian.net/browse"
["org_name2_in_github"]="https://org_name2_in_jira.atlassian.net/browse"
)
STYLE_GUIDE_LINK="https://github.com/pdffiller/styleguide-hooks#commit-message-format"
Each feature, bug fix or any other change must be developed in a separate branch.
Example:
Add
Delete
Change
Fix
Update
Correct
Test
...
The only exception allowed is Initial commit
Reasons:
- Has advantages with automatic code-review
- Makes reading easier
- Reduces the number of characters in the commit message (for example,
Add
versusWas added
orHas been added
) - Matches the format accepted by git itself
When making a commit message, just mentally add a phrase in front of it "When this commit is applied the git will ..."
and your commit message should logically continue this phrase.
Example:
Add new feature
instead of Add new feature.
)
It's git recommendation and soft limit, 50+ characters can be truncated when displayed.
Hard limit - 72 characters.
- https://chris.beams.io/posts/git-commit
- https://alistapart.com/article/the-art-of-the-commit
- https://robots.thoughtbot.com/5-useful-tips-for-a-better-commit-message
- https://github.com/erlang/otp/wiki/writing-good-commit-messages
- https://wiki.openstack.org/wiki/GitCommitMessages
- https://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html
- https://dev.to/gonedark/when-to-make-a-git-commit
Used pattern: issue_type / [path_to_folder /] [Jira issue ID /| GitHub issue # /] short_description
short_description
: a short phrase reflecting the essence of the changes, with a separator_
Jira issue ID
: project name and issue number with a hyphenGitHub issue
: short numeric number of a specific issue previously created in this repository
feature
- new functionalityimprove
- improve existing functionalityfix
- various fixes and fixestest
- branch for research, various tests, temporary copy, etc. It is useful, for example, for temporary merging of several branches that are not yet in the master for carrying out integration testing of these branches.docs
- everything related to documentationstyle
- fix typos, fix formattingrefactor
- refactoring application codelegacy
- in some cases, it may take a long time to parallelly develop several development directions in one repository (for example, we have already switched to the v3 module version, but for some terraform configurations, we need changes in the modules of v2 versions, and they will also need an indefinite long time). Such branches are strictly forbidden to be removed from the repository without the permission of the technical support.
Issue_type must be lowercase.
Exceptions:
- Terraform copy-paste development from one enviroment to another. But, if it new infrastucture - you MUST setup environment changes in separate commit.
- Vendor-dependency updates (such like in Go)
- Addition/Deletions/changes same little stuff in every file. Like
enviroment
->environment
10000 times
If you need make fix
and feature
- their MUST BE in different branches.
Exceptions:
-
If:
- you work with 1 (<1000 lines) functional autonomy file which not affect any other
- you make
refactor
and some other stuff - All changes in sum be <1000
If you add many clusters which not depend on each other - they MUST BE in diferent branches.
Tracked branch is a branch, changes in which are tracked by any build-configuration of Teamcity or another CI process or tool.
Work branch is a branch that has budded off from any one being tracked to make changes to the code, and after that it will be rebased again with the parent branch.
Making any changes to the tracked branches should take place exclusively through pull request.
Otherwise nobody is able to forcast all the consequences of such usage.
Use only stable, tracked branches on GitHub in your applications!
Make sure that the working branch does not conflict with the parent branch.
The corresponding pull request can be merged into the tracked branch only after succesfull review at least one review.
Merge is performed by executing the "rebase and merge" command — a special button at the bottom of the page — from the interface of this pull request in GitHub.
Right after the working branch is returned to the church is rebased into the tracked branch - deleted. Branch is to be deleted by the PR assignee who perform the rebase.
Go to repo Settings.
Enable Vulnerability alerts if the repo is private. In public repos it is enabled by default.
Allow only Rebase
WIP check can be found here.
Also, you can enable WIP check protection (or any other) only after creating your first pull request.
Protection rules can be enforced by enforce_branch_protection.py script.