We'd love to accept your patches! Before we can take them, we have to jump a couple of legal hurdles.
Please fill out either the individual or corporate Contributor License Agreement (CLA).
- If you are an individual writing original source code and you're sure you own the intellectual property, then you'll need to sign an individual CLA.
- If you work for a company that wants to allow you to contribute your work, then you'll need to sign a corporate CLA.
Follow either of the two links above to access the appropriate CLA and instructions for how to sign and return it. Once we receive it, we'll be able to accept your pull requests.
- Submit an issue describing your proposed change.
- The repo owner will respond to your issue promptly.
- If your proposed change is accepted, and you haven't already done so, sign a Contributor License Agreement (see details above).
- Fork this repo, develop and test your code changes.
- Ensure that your code adheres to the existing style in the sample to which you are contributing.
- Ensure that your code has an appropriate set of unit tests which all pass.
- Submit a pull request.
To run the tests in a samples directory, you will need to install Composer.
First install the testing dependencies which are shared across all samples:
composer install -d testing/
Next, install the dependencies for the individual sample you're testing:
SAMPLES_DIRECTORY=translate
cd $SAMPLES_DIRECTORY
composer install
Set up application default credentials
by setting the environment variable GOOGLE_APPLICATION_CREDENTIALS
to the path to a service
account key JSON file.
Then set any environment variables needed by the test. Check the
$SAMPLES_DIRECTORY/test
directory to see what specific variables are needed.
export GOOGLE_PROJECT_ID=YOUR_PROJECT_ID
export GOOGLE_STORAGE_BUCKET=YOUR_BUCKET
If your tests require new environment variables, you can set them up in .kokoro/secrets.sh.enc. For instructions on managing those variables, view .kokoro/secrets-example.sh for more information.
Once the dependencies are installed and the environment variables set, you can run the tests in a samples directory.
cd $SAMPLES_DIRECTORY
# Execute the "phpunit" installed for the shared dependencies
PATH_TO_REPO=/path/to/php-docs-samples
$PATH_TO_REPO/testing/vendor/bin/phpunit
Use phpunit -v
to get a more detailed output if there are errors.
Samples in this repository follow the PSR2 and PSR4 recommendations. This is enforced using PHP CS Fixer.
Install that by running
composer global require friendsofphp/php-cs-fixer
Then to fix your directory or file run
php-cs-fixer fix .
php-cs-fixer fix path/to/file
The DLP snippets are an example of snippets following the latest style guidelines.