Run terminus self:info
to confirm you are running the latest version before opening a new issue.
- Clone this Git repository on your local machine.
- Install Composer if you don't already have it.
- Run
composer install
to fetch all the dependencies. - Run
./bin/terminus --help
to test that everything was installed properly.
Whether you want to fix a bug or implement a new feature, the process is pretty much the same:
- Search existing issues; if you can't find anything related to what you want to work on, open a new issue so that you can get some initial feedback.
- Fork the repository.
- Push the code changes from your local clone to your fork.
- Open a pull request.
It doesn't matter if the code isn't perfect. The idea is to get it reviewed early and iterate on it.
If you're adding a new feature, please add one or more functional tests for it in the tests/features/
directory. See below. Also, keep the documentation up-to-date by running:
cd /install/location/terminus
composer docs
Lastly, please follow PSR-2. You can test for conformance via:
cd /install/location/terminus
composer cs
The PHP code beautifier can automatically fix a number of style issues. Run it via:
cd /install/location/terminus
composer cbf
There are two types of automated tests:
Both the unit and functional tests can be run together via:
composer test
The unit test files are in the tests/unit-tests
directory.
To run the unit tests for Terminus 0.x, simply execute:
vendor/bin/phpunit
The Terminus 1.x unit tests can be run via:
cd /install/location/terminus
composer phpunit
The functional test files are in the tests/features
directory. Any test which touches the backed is mocked with VCR.
To run the entire test suite for Terminus 0.x:
vendor/bin/behat --config tests/config/behat.yml
Or to test a single feature:
vendor/bin/behat --config tests/config/behat.yml tests/features/core.feature
The functional test files for the new version of Terminus are in the tests/active-features
directory. The complete behat suite for Terminus 1.x can be run via:
cd /install/location/terminus
composer behat
More information can be found by running vendor/bin/behat --help
.
To record a new test, configure the parameters
section of the file tests/config/behat.yml as follows:
parameters:
user_id: '[[YOUR-USER-ID-HERE]]'
username: '[[YOUR-EMAIL-ADDRESS-HERE]]'
host: 'terminus.pantheon.io:443'
vcr_mode: 'new_episodes'
machine_token: '[[YOUR-MACHINE-TOKEN-HERE]]'
Then, run a single test as described above. VCR will then call the backend and record the results received in the specified .yml file. This is done for any Behat scenario labeled @vcr filename.yml
. Pick a filename appropriate for the test.
Once the VCR .yml file has been saved, you may restore your behat.yml configuration file to its previous state (at a minimum, set vcr_mode
back to none
). Subsequent test runs will pull data from the VCR .yml file to satisfy future web requests.
You may need to add yourself to the team of the behat-tests site (Pantheon employees) or use a different test site. Once you have captured the events you would like to record, hand-sanitize them of any sensitive information such as machine tokens and bearer authorization headers.
In keeping with the standards of semantic versioning, backward-incompatible fixes are targeted to "major" versions. "Minor" versions are reserved for significant feature/bug releases needed between major versions. "Patch" releases are reserved only for critical security issues and other bugs critical to stabilizing the release.
After a new major version is released, previous major versions are actively supported for one year.
Our initial commitment will be to command compatibility and parameter compatibility. However, since on the command line STDOUT and STDERR are essentially APIs we will make a best effort to keep machine-readable output compatibility, meaning if your code interfaces with Terminus via --format=json or --format=bash formatting, we will try our best to ensure these are stable and compatible between minor release. However, changes to the STDOUT, like success and fail messages, should not be assumed to be compatible.
If you are using Terminus in a production environment, you should be deploying the executable for the latest release.
Ongoing development on the next planned release will be on the master branch and should not be considered stable, as changes will be taking place on a daily basis.
Writing for Terminus should be fun. If you find any of this hard to figure out, let us know so we can improve our process or documentation!