Ingen beskrivning

Guillaume Lours b6a7b985f5 Merge pull request #543 from docker/dependabot/go_modules/gopkg.in/ini.v1-1.60.1 5 år sedan
.dependabot 9c21e09044 Run dependabot daily instead of weekly 5 år sedan
.github dc7df90115 Merge pull request #523 from docker/test_triggers 5 år sedan
aci dc1e313858 Revert "Debug for CI failing tests (green locally)" 5 år sedan
backend 44b2b8b21d integrate functionality from ecs-plugin 5 år sedan
cli 69ce33321f Merge pull request #528 from docker/secrets 5 år sedan
client 635ecd7b99 Return a default implementation when nil 5 år sedan
compose ec4615ae57 Apply linter recommendations 5 år sedan
config e7e2d20050 config: Move to gotest.tools 5 år sedan
containers 1a3182fb7f Implement `docker start` for ACI 5 år sedan
context 207b57ba81 context: Move to gotest.tools 5 år sedan
docs 95de770e87 Update or add license header which are not valid 5 år sedan
ecs 10b7197e4a Remove version in test compose files 5 år sedan
errdefs 8e893fc5eb errdefs: Move to gotest.tools 5 år sedan
example 44b2b8b21d integrate functionality from ecs-plugin 5 år sedan
formatter 3ba70a27c6 formatter,multierror,progress: Move to gotest.tools 5 år sedan
local 981665b02c Better renaming 5 år sedan
metrics f442eafe0b Validate run restart option value. Default value is “none”, instead of “no”, this is more in line with compose values, and changes only the default so should not have too much impact on legacy usage. 5 år sedan
progress f442eafe0b Validate run restart option value. Default value is “none”, instead of “no”, this is more in line with compose values, and changes only the default so should not have too much impact on legacy usage. 5 år sedan
prompt 95de770e87 Update or add license header which are not valid 5 år sedan
protos 33758f0764 Add start to gRPC 5 år sedan
scripts b4e45bf597 Add a script to check if go.mod and go.sum are up-to-date 5 år sedan
secrets ec4615ae57 Apply linter recommendations 5 år sedan
server 95de770e87 Update or add license header which are not valid 5 år sedan
tests a61c2d16de Merge pull request #537 from docker/e2e_better_logs 5 år sedan
utils 95de770e87 Update or add license header which are not valid 5 år sedan
.dockerignore 9097b1f750 Add .git to .dockerignore 5 år sedan
.gitattributes 93984f8c68 Removed test requiring linux containers 5 år sedan
.gitignore fcc7582826 Remove non-project path 5 år sedan
.golangci.yml 69f10fe80c Extract interface / types to allow unit tests / mock 5 år sedan
CHANGELOG.md d40acb3146 Changelog updates 5 år sedan
CONTRIBUTING.md 8cfcfc8645 Add issue template, Contributing guide and maintainers list 5 år sedan
Dockerfile b41d216aaa Add import restrictions check 5 år sedan
LICENSE d7d9bb28bb Add LICENSE and NOTICE files 5 år sedan
MAINTAINERS 8cfcfc8645 Add issue template, Contributing guide and maintainers list 5 år sedan
Makefile 3a83d85d7a First ECS E2E test 5 år sedan
NOTICE d7d9bb28bb Add LICENSE and NOTICE files 5 år sedan
README.md d49d4473c3 Allow running ECS E2E tests locally 5 år sedan
builder.Makefile b41d216aaa Add import restrictions check 5 år sedan
go.mod 2fafa23736 build(deps): bump gopkg.in/ini.v1 from 1.60.0 to 1.60.1 5 år sedan
go.sum a15679fb94 Update go.sum after dependabot PR 5 år sedan
import-restrictions.yaml b41d216aaa Add import restrictions check 5 år sedan

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

Local ACI E2E tests:

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 the 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.

You can also run a single ACI test from the test suite:

AZURE_TENANT_ID="xxx" AZURE_CLIENT_ID="yyy" AZURE_CLIENT_SECRET="yyy" make E2E_TEST=TestContainerRun e2e-aci

Local ECS E2E tests:

TEST_AWS_PROFILE=myProfile TEST_AWS_REGION=eu-west-3 make e2e-ecs

This requires a valid AWS profile defined in ~/.aws/credentials.

Release

To create a new release:

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

Pushing the tag will automatically create 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 publicly 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