The Cloud Foundry team uses GitHub and accepts code contributions via pull requests. If you have any questions, ask away on the #cli channel in our Slack community and the cf-dev mailing list.
The cf CLI follows a branching model:
- V8 of the cf CLI is built from the master branch. This branch is under active development.
- V7 of the cf CLI is built from the v7 branch. This branch is maintenance only and will only be updated to patch CVEs and very severe blocking defects.
- V6 of the cf CLI is built from the v6 branch. This branch is maintenance only and will only be updated to patch CVEs and very severe blocking defects.
Before working on a PR to the CLI code base, please:
- reach out to us first via a GitHub issue,
- look for the contributions welcome label on GitHub for issues we are actively looking for help on.
You can always chat with us on our Slack #cli channel (request an invite),
After reaching out to the CLI team and the conclusion is to make a PR, please follow these steps:
- Ensure that you have either:
- completed our Contributor License Agreement (CLA) for individuals,
- or, are a public member of an organization that has signed the corporate CLA.
- Review the CF CLI Style Guide, Architecture Guide, Product Style Guide, and Internationalization Guide.
- Fork the project repository.
- Create a feature branch from the earliest branch that's appropriate for your change (e.g.
git checkout v7 && git checkout -b better_cli
) and make changes on this branch- Follow the other sections on this page to set up your development environment, build
cf
and run the tests. - Tests are required for any changes.
- Follow the other sections on this page to set up your development environment, build
- Push to your fork (e.g.
git push origin better_cli
) and submit a pull request - The cf CLI team will merge your changes from the versioned branch (e.g. v7) to master for you after the PR is merged.
Note: All contributions must be sent using GitHub Pull Requests. We prefer a small, focused pull request with a clear message that conveys the intent of your change.
Documentation on installing GoLang can be found here. While
the CF CLI might be compatible with other versions of GoLang, this is the only
version that the cli
binary is built and tested with.
The CF CLI requires the following development tools in order to run our test:
- Ginkgo / Gomega - Test framework/Matchers Library
- golangci-lint - Comprehensive linting tool
- counterfeiter - Generate
fakes/mocks for testing. Currently using version
6.*
. - make - tool for building the CLI and running its tests.
Clone the repository.
git clone https://github.com/cloudfoundry/cli.git
Build the binary for the current architecture and adding it to the PATH
:
cd cli
make build
export PATH=<path-to-cli-directory>/out:$PATH # Puts the built CLI first in your PATH
The supported platforms for the CF CLI are Linux (32-bit and 64-bit), Windows
(32-bit and 64-bit) and OSX (aka Darwin). The commands that build the binaries
can be seen in the Makefile where the target begins with the
out/cf-cli
.
For general information on how to cross compile GoLang binaries, see the Go environment variables documentation for details on how to cross compile binaries for other architectures.
To run the unit tests:
cd cli
make units-full # will run all unit tests
make units # runs all non-cf directory unit tests
Note: make units-full
is recommended over make units
if you are unsure of
how wide-reaching the intended changes are.
The Integration test README contains a full set of
details on how to configure and run the integration tests. In addition to the
configuration mentioned in the README, the CLI's Makefile
contains the
following support commands that will run make build integration-cleanup
prior
to running integration tests:
make integration-experimental # runs the experimental integration tests
make integration-global # runs the global integration tests
make integration-isolated # runs the isolated integration tests
make integration-plugin # runs the plugin integration tests
make integration-push # runs the push integration tests
make integration-tests # runs the isolated, push and global integration tests
make integration-tests-full # runs all the integration suites
To adjust the number of parallel nodes for the non-global test suites, set the
NODES
environment variable:
NODES=10 make integration-tests
All changes to the CF CLI require updates to the unit/integration tests. There are additional requirements around updating the CF CLI that will be listed below.
The CLI uses counterfeiter
to
generate fakes from interfaces for the unit tests. If any changes are made to an
interface, the fakes be should regenerated using counterfeiter:
go generate ./<package>/...
where <package>
contains the package with the changed interface.
counterfeiter
fakes should never be manually edited. They are only created/modified viago generate
. All pull requests with manually modified fakes will be rejected.- Do not run
go generate
from the root directory. Fakes in the legacy codebase require additional intervention so it preferred not to modify them unless it is absolutely necessary.
The CLI uses go modules
to manage
dependencies. Refer to the vendoring section
documentation for managing
dependencies.
If you are vendoring a new dependency, please read License and Notice Files to abide by third party licenses.
The CLI has a minimum version requirements for the APIs it interfaces with. The requirements for these APIs are listed in the Version Policy guide.
If your pull request requires a CAPI version higher than the minimum API version, the CLI code and integration tests must be versioned tests. This new functionality has the following requirements:
- The minimum version is added to the Minimum API version list.
- The feature has an appropriate version check in the
command
layer to prevent use of that feature if the targeted API is below the minimum version. Note: commands should FAIL prior to execution when minimum version is not met for specified functionality. - The integration tests that are added use the
helpers.SkipIfVersionLessThan
orhelpers.SkipIfVersionGreaterThan
helpers in theirBeforeEach
. See this example.