All contributions are welcome to this project.
vendor/bin/phpunit
Make sure the dev dependencies are installed (composer install
),
and that ext/xdebug isn't enabled in the CLI PHP (it would slow down the benchmarks).
# Run the benchmark suite and set a reference point named "before"
vendor/bin/phpbench run --warmup=2 --retry-threshold=5 --iterations=10 --store --tag=before tests/benchmarks
# Make some changes...
# Benchmark and compare with the reference run
vendor/bin/phpbench run --warmup=2 --retry-threshold=5 --iterations=10 --report=aggregate --ref=before tests/benchmarks
- File an issue - if you found a bug, want to request an enhancement, or want to implement something (bug fix or feature).
- Send a pull request - if you want to contribute code. Please be sure to file an issue first.
We want to accept your pull requests. Please follow these steps:
Before writing any code, please file an issue stating the problem you want to solve or the feature you want to implement. This allows us to give you feedback before you spend any time writing code. There may be a known limitation that can't be addressed, or a bug that has already been fixed in a different way. The issue allows us to communicate and figure out if it's worth your time to write a bunch of code for the project.
Please take the time to add everything that could be useful to understnding your issue:
- Is it a bug or a feature?
- What were you expecting? What happened?
- Any file or code needed to reproduce the problem?
This will create your own copy of our repository.
The upstream source is the project under the Box organization on GitHub. To add an upstream source for this project, type:
git remote add upstream [email protected]:silecs/spout.git
This will come in useful later.
Create a branch with a descriptive name, such as add-search
.
As you develop code, continue to push code to your remote feature branch. Please make sure to include the issue number you're addressing in your commit message, such as:
git commit -m "Adding search (fixes #123)"
This helps us out by allowing us to track which issue your commit relates to.
Keep a separate feature branch for each issue you want to address.
Before sending a pull request, rebase against upstream, such as:
git fetch upstream
git rebase upstream/master
This will add your changes on top of what's already in upstream, minimizing merge issues.
Make sure that all tests are passing before submitting a pull request.
./vendor/bin/phpunit
Run the following command to check the code style of your changes:
vendor/bin/php-cs-fixer fix --config=.php-cs-fixer.dist.php --verbose --diff --dry-run
This will print a diff of proposed code style changes. To apply these suggestions, run the following command:
vendor/bin/php-cs-fixer fix --config=.php-cs-fixer.dist.php
Send the pull request from your feature branch to us. Be sure to include a description that lets us know what work you did.
Keep in mind that we like to see one issue addressed per pull request, as this helps keep our git history clean and we can more easily track down issues.