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.
Write samples according to the sample style guide.
Change into the directory of the project you want to test (either
google-analytics-admin
or google-analytics-data
), configure
Composer and install dependencies as
described in the directory's README.md
.
Some tests require specific environment variables to run. PHPUnit will skip the tests
if these environment variables are not found. Run phpunit -v
for a message detailing
which environment variables are missing. Then you can set those environment variables
to run against any sample project as follows:
export GOOGLE_PROJECT_ID=YOUR_PROJECT_ID
export GA_TEST_PROPERTY_ID=YOUR_GA4_PROPERTY_ID
# This value is only required by Admin API samples tests.
export GA_TEST_ACCOUNT_ID=
Once the dependencies are installed and the environment variables set, you can run the tests in a samples directory. For example:
cd google-analytics-data
# Execute the "phpunit" installed for the shared dependencies
./vendor/bin/phpunit
Use phpunit -v
to get a more detailed output if there are errors.
The Google Cloud Samples Style Guide is considered the primary guidelines for all Google Cloud samples.
Samples in this repository also follow the PSR2 and PSR4 recommendations. This is enforced using PHP CS Fixer, using the config in .php-cs-fixer.dist.php
Install that by running
composer require --dev friendsofphp/php-cs-fixer
Then to fix your directory or file run
./vendor/bin/php-cs-fixer fix --config .php-cs-fixer.dist.php .
./vendor/bin/php-cs-fixer fix --config .php-cs-fixer.dist.php path/to/file