Pull requests must also adhere to the following guidelines:
- Pull requests must be atomic and targeted at a single issue rather than broad scope.
- Pull requests must contain clear testing steps and justification, and all other information required by the pull request template.
- Pull requests must pass automated tests before they will be reviewed. Acquia recommends running the tests locally before submitting.
- Pull requests must meet Drupal coding standards and best practices as defined by the project maintainers.
Every commit on the Acquia CLI repository, including for pull requests, automatically builds and uploads acli.phar as a build artifact to assist with reviews. To download acli.phar for any commit:
- For pull requests, GitHub Actions will comment on the PR with a link to the dev build.
- For any other commit, wait for the CI workflow to complete.
- On the workflow summary page, in the "Artifacts" section, click on
acli.phar
. - Unzip the downloaded file.
- Make the file executable:
chmod +x acli.phar
No special tools or dependencies are necessary to develop or contrib to Acquia CLI. Simply clone the Git repo and install Composer dependencies:
git clone [email protected]:acquia/cli.git
cd cli
composer install
./bin/acli
Be sure to validate and test your code locally using the provided Composer test scripts (composer test
) before opening a PR.
To test changes in production mode, build and run acli.phar
using this process. The build-release stage of .github/workflows/ci.yml
follows a similar process.
- Install Composer production dependencies:
composer install --no-dev --optimize-autoloader
- Populate
.env
:cp .env.example .env
- Clear and rebuild your Symfony caches:
./bin/acli ckc && ./bin/acli cc
- Install Box (only need to do this once):
composer box-install
- Compile phar:
composer box-compile
New code should be covered at 100% (or as close to it as reasonably possible) by PHPUnit tests. It should also minimize the number of escaped mutants (as close to 0% as reasonably possible), which will appear as annotations on your PR after unit tests run.
Every class / command has a corresponding test file. The first test case in each file should be the "default" passing workflow for that command. Additional test cases should cover any possible inputs for that command as well as any possible error cases.
PHPUnit data providers may be used to fuzz input for a test case as long as the output remains the same. However, if the output of a command varies non-trivially based on input, it should probably be broken into different test cases rather than using a data provider.
Test cases are declarative specifications. They should not implement or utilize any logic, especially not as provided by the covered source code itself.
Acquia CLI stores a local copy of the Cloud Platform API spec in the assets
directory. To update the Cloud Platform API spec, run:
composer update-cloud-api-spec
- The release drafter plugin should have already created a release for you, visible in the GitHub UI, according to Semantic Versioning.
- Ensure that release notes are accurate and issues are correctly labeled.
- Ensure that release has been approved by maintainers and any other required stakeholders.
- Validate that testing has passed on the commit to be released.
- In the GitHub UI, publish the release. This will trigger a GitHub actions build that generates a phar file and attaches it to the release.
If the build fails to generate a phar and attach it properly, follow these steps to manually create and attach the phar.
- Check out the tag locally
git remote update
git checkout [the tag]
- Follow the steps above for Building acli.phar
- Validate that the phar works and has the right version defined:
./build/acli.phar --version
- Attach the phar file to the release in the GitHub UI.
To generate docs for all commands in RST format, run:
./bin/acli self:make-docs
To copy the output easily to the clipboard, run:
./bin/acli self:make-docs | pbcopy
If you're on Mac, you can render and view the outputted RST using a command like this:
brew install restview
./bin/acli self:make-docs > /tmp/acli.rst && restview /tmp/acli.rst
Code, comment, and other style standards should generally follow those set by the PHP community and upstream projects, especially Drupal, Symfony, ORCA, and PSR-1. PHPCodeSniffer enforces many of these standards.
- Organize commands by topic (noun) first and action (verb) second, separated by a colon (
ide:create
). - Write command descriptions in sentence case and imperative mood without a trailing period (
Create a Cloud IDE
). Do not use a trailing period for argument and option descriptions. - Use camelCase for all property, method, and variable names.
- Use hyphens to separate words in options and arguments (
addOption('ssh-key')
), or any other variable exposed to end users.