etcd/Documentation/contributor-guide/dependency_management.md
Chao Chen b2c39fc8e6 2023-06-06: bump up dependencies update identified by dependabot
Signed-off-by: Chao Chen <chaochn@amazon.com>
2023-06-06 20:18:44 -07:00

5.7 KiB

Dependency management

Table of Contents

Main branch

The dependabot is enabled & configured to manage dependencies for etcd main branch. But dependabot doesn't work well for multi-module repository like etcd, see dependabot-core/issues/6678. Usually human intervention is required each time when dependabot automatically opens some PRs to bump dependencies. Please see guidance below.

Dependencies used in workflows

The PRs which automatically bump dependencies (see examples below) used in workflows are fine, and can be approved & merged directly as long as all checks are successful.

Bumping order

When multiple etcd modules depend on the same package, please bump the package version for all the modules in the correct order. The rule is simple: if module A depends on module B, then bump the dependency for module B before module A. If the two modules do not depend on each other, then it doesn't matter to bump which module first. For example, multiple modules depend on github.com/spf13/cobra, we need to bump the dependency in the following order,

  • go.etcd.io/etcd/pkg/v3
  • go.etcd.io/etcd/server/v3
  • go.etcd.io/etcd/etcdctl/v3
  • go.etcd.io/etcd/etcdutl/v3
  • go.etcd.io/etcd/tests/v3
  • go.etcd.io/etcd/v3
  • go.etcd.io/etcd/tools/v3 For more details about etcd Golang modules, please check https://etcd.io/docs/next/dev-internal/modules/

Note the module go.etcd.io/etcd/tools/v3 doesn't depend on any other modules, nor by any other modules, so it doesn't matter when to bump dependencies for it.

Steps to bump a dependency

Use the github.com/spf13/cobra as an example, follow steps below to bump it from 1.6.1 to 1.7.0 for module go.etcd.io/etcd/etcdctl/v3,

$ cd ${ETCD_ROOT_DIR}/etcdctl
$ go get github.com/spf13/cobra@v1.7.0
$ go mod tidy
$ cd ..
$ ./scripts/fix.sh

Execute the same steps for all other modules. When you finish bumping the dependency for all modules, then commit the change,

$ git add .
$ git commit --signoff -m "dependency: bump github.com/spf13/cobra from 1.6.1 to 1.7.0"

Please close the related PRs which were automatically opened by dependabot.

When you bump multiple dependencies in one PR, it's recommended to create a separate commit for each dependency. But it isn't a must; for example, you can get all dependencies bumping for the module go.etcd.io/etcd/tools/v3 included in one commit.

Indirect dependencies

Usually we don't bump a dependency if all modules just indirectly depend on it, such as github.com/go-logr/logr.

If an indirect dependency (e.g. D1) causes any CVE or bugs which affect etcd, usually the module (e.g. M1, not part of etcd, but used by etcd) which depends on it should bump the dependency (D1), and then etcd just needs to bump M1. However, if the module (M1) somehow doesn't bump the problematic dependency, then etcd can still bump it (D1) directly following the same steps above. But as a long-term solution, etcd should try to remove the dependency on such module (M1) that lack maintenance.

For mixed cases, in which some modules directly while others indirectly depend on a dependency, we have multiple options,

  • Bump the dependency for all modules, no matter it's direct or indirect dependency.
  • Bump the dependency only for modules which directly depend on it.

We should try to follow the first way, and temporarily fall back to the second one if we run into any issue on the first way. Eventually we should fix the issue and ensure all modules depend on the same version of the dependency.

Known incompatible dependency updates

arduino/setup-protoc

Please refer to build(deps): bump arduino/setup-protoc from 1.3.0 to 2.0.0

About gRPC

There is a compatible issue between etcd and gRPC 1.52.0, and there is a pending PR pull/15131.

The plan is to remove the dependency on some grpc-go's experimental API firstly, afterwards try to bump it again. Please get more details in issues/15145.

go.opentelemetry.io/otel version update is indirectly blocked due to this gRPC issue. Please get more details in pull/15810.

Rotation worksheet

The dependabot scheduling interval is weekly; it means dependabot will automatically raise a bunch of PRs per week. Usually human intervention is required each time. We have a rotation worksheet, and everyone is welcome to participate; you just need to register your name in the worksheet.

Stable branches

Usually we don't proactively bump dependencies for stable releases unless there are any CVEs or bugs that affect etcd.

If we have to do it, then follow the same guidance above. Note that there is no ./scripts/fix.sh in release-3.4, so no need to execute it for 3.4.