We appreciate that. But before you do, please learn our basic rules:
- This is not a support or discussion forum. If you have a question, please ask it on The Cukes Google Group or on Gitter.
- Do you have a feature request? Then don't expect it to be implemented unless you or someone else sends a pull request.
- Reporting a bug? We need to know what compiler, operating system and architecture (32 or 64 bit) you are using, including versions of all libraries. Bugs with pull requests get fixed quicker. Some bugs may never be fixed.
- You have to tell us how to reproduce a bug. Bonus point for a pull request with a failing test that reproduces the bug.
- Want to paste some code or output? Put ``` on a line above and below your code/output. See GFM's Fenced Code Blocks for details.
- We love pull requests, but if you don't have a test to go with it we probably won't merge it.
Before you can contribute, you have to be able to build the source and run tests.
The process for using git/github is similar to the Github-Flow
- Anything in the main branch is good enough to release
- Working on nontrivial features
- Create a descriptively named branch off of main
- Commit to that branch locally and regularly
- Push your work to the same named branch on the server
- Regularly rebase this branch from main to keep it up to date
- Open a pull request
- When you need feedback or help
- You think the branch is ready for merging (you can use the hub command-line tool)
- For any nontrivial change, even if you have the rights to merge the pull request yourself, wait before someone else has reviewed and agreed on the change
Here is an Example of this process in action
- Read up on Github Flavored Markdown
- Especially links and syntax highlighting. GFM can be used in tickets as well as commit messages (e.g. put "#4" somewhere in a commit message to link ticket 4 to that commit
- Close tickets with commits if you can
- Add "Closes #5, #9" somewhere in the commit message to both link and close. See Issues 2.0 the Next Generation for details.
- Use this script to compile and view GFM locally
- Subscribe to ticket feeds so you stay in the loop and get a chance to provide feedback on tickets
- The code standard is the existing code
- Use the same indentation, spacing, line ending, ASCII for source code, UTF-8 everywhere else
- Use git diff (or git diff --cached if you have staged) before every commit
- This helps you avoid committing changes you didn't mean to
- Verify that:
- All checks have passed
- At least one maintainer has approved any non-trivial change, and a discussion has occurred for any breaking change
- The branch does not need rebasing or squashing of commits
- To merge:
- Follow the command line instructions on GitHub
- If it is either a new feature or a bugfix, specify the
--no-commit
flag when merging and add a line toCHANGELOG.md
following the current convention. Add this file to the changes to be committed and commit the merge. - Commit message should follow the current convention:
Merge #42 'Description of the change usually from the PR description'
- Release commit (e.g. fdf8a5c):
- Change
CHANGELOG.md
renaming the "In Git" section with the release number and date - Commit with message
Update changelog for the X.Y.Z release
- Create an annotated tag for this commit named
vX.Y.Z
- Change
- New development branch commit (e.g. da60995):
- Add new "In Git" section to
CHANGELOG.md
- Commit with message
Preparing history file for next development release
- Add new "In Git" section to
- Push commits and tags to main