mirror of
https://github.com/retailcrm/graphql-php.git
synced 2024-11-22 12:56:05 +03:00
57 lines
1.3 KiB
Markdown
57 lines
1.3 KiB
Markdown
# Contributing to GraphQL PHP
|
|
|
|
## Workflow
|
|
|
|
If your contribution requires significant or breaking changes, or if you plan to propose a major new feature,
|
|
we recommend you to create an issue on the [GitHub](https://github.com/webonyx/graphql-php/issues) with
|
|
a brief proposal and discuss it with us first.
|
|
|
|
For smaller contributions just use this workflow:
|
|
|
|
* Fork the project.
|
|
* Add your features and or bug fixes.
|
|
* Add tests. Tests are important for us.
|
|
* Check your changes using `composer check-all`
|
|
* Send a pull request
|
|
|
|
## Using GraphQL PHP from a Git checkout
|
|
```sh
|
|
git clone https://github.com/webonyx/graphql-php.git
|
|
cd graphql-php
|
|
composer install
|
|
```
|
|
|
|
## Running tests
|
|
```sh
|
|
./vendor/bin/phpunit
|
|
```
|
|
|
|
Some tests have annotation `@see it('<description>')`. It is used for reference to same tests in [graphql-js implementation](https://github.com/graphql/graphql-js) with the same description.
|
|
|
|
## Coding Standard
|
|
Coding standard of this project is based on [Doctrine CS](https://github.com/doctrine/coding-standard). To run the inspection:
|
|
|
|
```sh
|
|
./vendor/bin/phpcs
|
|
```
|
|
|
|
Auto-fixing:
|
|
```sh
|
|
./vendor/bin/phpcbf
|
|
```
|
|
|
|
## Static analysis
|
|
Based on [PHPStan](https://github.com/phpstan/phpstan)
|
|
```sh
|
|
./vendor/bin/phpstan analyse --ansi --memory-limit 256M
|
|
```
|
|
|
|
|
|
## Running benchmarks
|
|
|
|
Benchmarks are run via phpbench:
|
|
|
|
```sh
|
|
./vendor/bin/phpbench run .
|
|
```
|