Aucune description

Guillaume Tardif 16acc36033 Merge pull request #356 from docker/fix-non-interactive il y a 5 ans
.dependabot 9c21e09044 Run dependabot daily instead of weekly il y a 5 ans
.github 7a9a3d0e7e Indent master-ci.yml il y a 5 ans
azure 16acc36033 Merge pull request #356 from docker/fix-non-interactive il y a 5 ans
backend ad72c866cc Add license headers il y a 5 ans
cli cb3ac513cc Add run env variables support (KEY=AVLUE or KEY, will grab the process env value). il y a 5 ans
client ad72c866cc Add license headers il y a 5 ans
compose 622402709a Use compose-go's Project and ProjectOptions il y a 5 ans
config ad72c866cc Add license headers il y a 5 ans
containers cb3ac513cc Add run env variables support (KEY=AVLUE or KEY, will grab the process env value). il y a 5 ans
context 839b1b0b44 Delegate to Moby CLI, to allow executing ecs CLI plugin if user has switched to the AWS context (created by the plugin) il y a 5 ans
docs 6e6ed0648f docs: Add Linux install instructions il y a 5 ans
errdefs 964e331a10 Specific exit code when command fails because azure login is required. Will be used by VSCode Docker integration il y a 5 ans
example 7296290408 Add ”Platform” in docker inspect result, showing container OS (this field is used by VSCode) il y a 5 ans
formatter 1deb2b8b09 Integrate limits on inspect il y a 5 ans
local 7296290408 Add ”Platform” in docker inspect result, showing container OS (this field is used by VSCode) il y a 5 ans
metrics 188dc1b06c Metrics for azure commands il y a 5 ans
multierror ad72c866cc Add license headers il y a 5 ans
progress 50d932195d progress: Rename variable to clarify logic il y a 5 ans
protos 1deb2b8b09 Integrate limits on inspect il y a 5 ans
server 37f4c36c32 Use logrus for logging, not containerd's log il y a 5 ans
tests 16acc36033 Merge pull request #356 from docker/fix-non-interactive il y a 5 ans
.dockerignore 9097b1f750 Add .git to .dockerignore il y a 5 ans
.gitattributes 93984f8c68 Removed test requiring linux containers il y a 5 ans
.gitignore fcc7582826 Remove non-project path il y a 5 ans
.golangci.yml 69f10fe80c Extract interface / types to allow unit tests / mock il y a 5 ans
CHANGELOG.md d40acb3146 Changelog updates il y a 5 ans
Dockerfile ad72c866cc Add license headers il y a 5 ans
Makefile ad72c866cc Add license headers il y a 5 ans
README.md fc8132167e Update doc for release il y a 5 ans
builder.Makefile 0bcba8d1d2 Set LD_FLAG version from git tag. Displayed version will be (default behaviour of git describe —tags): il y a 5 ans
go.mod 2e867f40d7 Merge pull request #355 from docker/fix_windows_login il y a 5 ans
go.sum 2e867f40d7 Merge pull request #355 from docker/fix_windows_login il y a 5 ans

README.md

Docker API

Actions Status

Dev Setup

The recommended way is to use the main Makefile that runs everything inside a container.

If you don't have or want to use Docker for building you need to make sure you have all the needed tools installed locally:

And then you can call the same make targets but you need to pass it the builder.Makefile (make -f builder.Makefile).

The new CLI delegates to the classic docker for default contexts ; delegation is done to com.docker.cli.

  • make moby-cli-link will create a com.docker.cli link in /usr/local/bin if you don't already have it from Docker Desktop

Building the project

$ make

This will make the cli with all backends enabled. make cross on the other hand will cross-compile the cli without the example and local backend. We use make cross to build for our release, hence the exclusion of those backends. You can still cross-compile with all backends enabled: BUILD_TAGS=example,local make cross.

If you make changes to the .proto files, make sure to make protos to generate go code.

Tests

unit tests

make test

If you need to update a golden file simply do go test ./... -test.update-golden.

e2e tests

make e2e_local

This requires a local docker engine running

AZURE_TENANT_ID="xxx" AZURE_CLIENT_ID="yyy" AZURE_CLIENT_SECRET="yyy" make e2e_aci

This requires azure service principal credentials to login to azure. To get the values to be set in local environment variables, you can create a new service principal once you're logged in azure (with docker login azure)

az ad sp create-for-rbac --name 'MyTestServicePrincipal' --sdk-auth

Running aci e2e tests will override your local login, the service principal credentials use a token that cannot be refreshed automatically. You might need to run again docker login azure to properly use the command line after running ACI e2e tests.

Release

To create a new release:

  • check that the CI is green on the master commit you want to release
  • simply create a new tag of th form vx.y.z, following existing tags, and push the tag

Pushing the tag will automatically ceate a new release and make binaries (mac, win, linux) available for download.

Note: Linux binaries are not automatically copied to /docker/aci-integration-beta, if you want to make the linux binary publically available, you'll need to manually create a release in aci-integration-beta and upload the binary.
For Desktop integration, you need to make a PR in /docker/pinata and update the cli release number here