Skip to content

Commit

Permalink
Add logic to connect to a remote context
Browse files Browse the repository at this point in the history
  • Loading branch information
guillaume.bouvignies committed Mar 21, 2023
1 parent f4034e5 commit 595d0bc
Show file tree
Hide file tree
Showing 22 changed files with 593 additions and 124 deletions.
6 changes: 4 additions & 2 deletions cli/cli/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ go 1.18
replace (
github.com/kurtosis-tech/kurtosis/api/golang => ../../api/golang
github.com/kurtosis-tech/kurtosis/container-engine-lib => ../../container-engine-lib
github.com/kurtosis-tech/kurtosis/contexts-config-store => ../../contexts-config-store
github.com/kurtosis-tech/kurtosis/engine/launcher => ../../engine/launcher
github.com/kurtosis-tech/kurtosis/kurtosis_version => ../../kurtosis_version
)
Expand All @@ -18,6 +19,7 @@ require (
github.com/go-yaml/yaml v2.1.0+incompatible
github.com/kurtosis-tech/kurtosis/api/golang v0.0.0 // local dependency
github.com/kurtosis-tech/kurtosis/container-engine-lib v0.0.0 // local dependency
github.com/kurtosis-tech/kurtosis/contexts-config-store v0.0.0 // local dependency
github.com/kurtosis-tech/kurtosis/engine/launcher v0.0.0 // local dependency
github.com/kurtosis-tech/kurtosis/kurtosis_version v0.0.0 // Local dependency generated during build
github.com/kurtosis-tech/metrics-library/golang v0.0.0-20230221115618-70c305416224
Expand All @@ -30,7 +32,7 @@ require (
github.com/stretchr/testify v1.7.4
golang.org/x/crypto v0.0.0-20220214200702-86341886e292
google.golang.org/grpc v1.41.0
google.golang.org/protobuf v1.27.1
google.golang.org/protobuf v1.29.1
k8s.io/apimachinery v0.24.0 // indirect
k8s.io/client-go v0.24.0
)
Expand All @@ -45,7 +47,6 @@ require (
)

require (
github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1 // indirect
github.com/Microsoft/go-winio v0.4.17 // indirect
github.com/chzyer/readline v0.0.0-20180603132655-2972be24d48e // indirect
github.com/davecgh/go-spew v1.1.1 // indirect
Expand Down Expand Up @@ -84,6 +85,7 @@ require (
golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4 // indirect
golang.org/x/net v0.7.0 // indirect
golang.org/x/oauth2 v0.0.0-20211104180415-d3ed0bb246c8 // indirect
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4 // indirect
golang.org/x/sys v0.5.0 // indirect
golang.org/x/term v0.5.0 // indirect
golang.org/x/text v0.7.0 // indirect
Expand Down
9 changes: 5 additions & 4 deletions cli/cli/go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,7 @@ cloud.google.com/go/storage v1.6.0/go.mod h1:N7U0C8pVQ/+NIKOBQyamJIeKQKkZ+mxpohl
cloud.google.com/go/storage v1.8.0/go.mod h1:Wv1Oy7z6Yz3DshWRJFhqM/UCfaWIRTdp0RXyy7KQOVs=
cloud.google.com/go/storage v1.10.0/go.mod h1:FLPqc6j+Ki4BU591ie1oL6qBQGu2Bl/tZ9ullr3+Kg0=
dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9/go.mod h1:H6x//7gZCb22OMCxBHrMx7a5I7Hp++hsVxbQ4BYO7hU=
github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1 h1:UQHMgLO+TxOElx5B5HZ4hJQsoJ/PvUvKRhJHDQXO8P8=
github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1/go.mod h1:xomTg63KZ2rFqZQzSB4Vz2SUXa1BpHTVz9L5PTmPC4E=
github.com/Azure/go-ansiterm v0.0.0-20230124172434-306776ec8161 h1:L/gRVlceqvL25UVaW/CKtUDjefjrs0SPonmDGUVOYP0=
github.com/Azure/go-autorest v14.2.0+incompatible/go.mod h1:r+4oMnoxhatjLLJ6zxSWATqVooLgysK6ZNox3g/xq24=
github.com/Azure/go-autorest/autorest v0.11.18/go.mod h1:dSiJPy22c3u0OtOKDNttNgqpNFY/GeWa7GH/Pz56QRA=
github.com/Azure/go-autorest/autorest/adal v0.9.13/go.mod h1:W/MM4U6nLxnIskrw4UwWzlHfGjwUS50aOsc/I3yuU8M=
Expand Down Expand Up @@ -486,6 +485,8 @@ golang.org/x/sync v0.0.0-20200625203802-6e8e738ad208/go.mod h1:RxMgew5VJxzue5/jJ
golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20201207232520-09787c993a3a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4 h1:uVc8UZUe6tr40fFVnUP5Oj+veunVezqYl9z7DYw9xzw=
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20181122145206-62eef0e2fa9b/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
Expand Down Expand Up @@ -536,7 +537,6 @@ golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7w
golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210616094352-59db8d763f22/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20211025201205-69cdffdb9359/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20211216021012-1d35b9e2eb4e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
Expand Down Expand Up @@ -730,8 +730,9 @@ google.golang.org/protobuf v1.24.0/go.mod h1:r/3tXBNzIEhYS9I1OUVjXDlt8tc493IdKGj
google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c=
google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw=
google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
google.golang.org/protobuf v1.27.1 h1:SnqbnDw1V7RiZcXPx5MEeqPv2s79L9i7BJUlG/+RurQ=
google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
google.golang.org/protobuf v1.29.1 h1:7QBf+IK2gx70Ap/hDsOmam3GE0v9HicjfEdAxE62UoM=
google.golang.org/protobuf v1.29.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
Expand Down
8 changes: 8 additions & 0 deletions cli/cli/helpers/engine_manager/engine_existence_guarantor.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,8 @@ type engineExistenceGuarantor struct {

engineServerKurtosisBackendConfigSupplier engine_server_launcher.KurtosisBackendConfigSupplier

kurtosisRemoteBackendConfigSupplier *engine_server_launcher.KurtosisRemoteBackendConfigSupplier

engineServerLauncher *engine_server_launcher.EngineServerLauncher

imageVersionTag string
Expand All @@ -70,6 +72,7 @@ func newEngineExistenceGuarantorWithDefaultVersion(
kurtosisBackend backend_interface.KurtosisBackend,
shouldSendMetrics bool,
engineServerKurtosisBackendConfigSupplier engine_server_launcher.KurtosisBackendConfigSupplier,
kurtosisRemoteBackendConfigSupplier *engine_server_launcher.KurtosisRemoteBackendConfigSupplier,
logLevel logrus.Level,
maybeCurrentlyRunningEngineVersionTag string,
kurtosisClusterType resolved_config.KurtosisClusterType,
Expand All @@ -80,6 +83,7 @@ func newEngineExistenceGuarantorWithDefaultVersion(
kurtosisBackend,
shouldSendMetrics,
engineServerKurtosisBackendConfigSupplier,
kurtosisRemoteBackendConfigSupplier,
defaultEngineImageVersionTag,
logLevel,
maybeCurrentlyRunningEngineVersionTag,
Expand All @@ -93,6 +97,7 @@ func newEngineExistenceGuarantorWithCustomVersion(
kurtosisBackend backend_interface.KurtosisBackend,
shouldSendMetrics bool,
engineServerKurtosisBackendConfigSupplier engine_server_launcher.KurtosisBackendConfigSupplier,
kurtosisRemoteBackendConfigSupplier *engine_server_launcher.KurtosisRemoteBackendConfigSupplier,
imageVersionTag string,
logLevel logrus.Level,
maybeCurrentlyRunningEngineVersionTag string,
Expand All @@ -103,6 +108,7 @@ func newEngineExistenceGuarantorWithCustomVersion(
preVisitingMaybeHostMachineIpAndPort: preVisitingMaybeHostMachineIpAndPort,
kurtosisBackend: kurtosisBackend,
engineServerKurtosisBackendConfigSupplier: engineServerKurtosisBackendConfigSupplier,
kurtosisRemoteBackendConfigSupplier: kurtosisRemoteBackendConfigSupplier,
engineServerLauncher: engine_server_launcher.NewEngineServerLauncher(kurtosisBackend),
imageVersionTag: imageVersionTag,
logLevel: logLevel,
Expand Down Expand Up @@ -137,6 +143,7 @@ func (guarantor *engineExistenceGuarantor) VisitStopped() error {
metricsUserId,
guarantor.shouldSendMetrics,
guarantor.engineServerKurtosisBackendConfigSupplier,
guarantor.kurtosisRemoteBackendConfigSupplier,
)
} else {
_, _, engineLaunchErr = guarantor.engineServerLauncher.LaunchWithCustomVersion(
Expand All @@ -148,6 +155,7 @@ func (guarantor *engineExistenceGuarantor) VisitStopped() error {
metricsUserId,
guarantor.shouldSendMetrics,
guarantor.engineServerKurtosisBackendConfigSupplier,
guarantor.kurtosisRemoteBackendConfigSupplier,
)
}
if engineLaunchErr != nil {
Expand Down
7 changes: 6 additions & 1 deletion cli/cli/helpers/engine_manager/engine_manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ type EngineManager struct {
kurtosisBackend backend_interface.KurtosisBackend
shouldSendMetrics bool
engineServerKurtosisBackendConfigSupplier engine_server_launcher.KurtosisBackendConfigSupplier
remoteBackendConfigSupplier *engine_server_launcher.KurtosisRemoteBackendConfigSupplier
clusterConfig *resolved_config.KurtosisClusterConfig
// Make engine IP, port, and protocol configurable in the future
}
Expand Down Expand Up @@ -71,12 +72,14 @@ func NewEngineManager(ctx context.Context) (*EngineManager, error) {
return nil, stacktrace.Propagate(err, "An error occurred getting the Kurtosis backend for cluster '%v'", clusterName)
}
engineBackendConfigSupplier := clusterConfig.GetEngineBackendConfigSupplier()
remoteBackendConfigSupplier := clusterConfig.GetKurtosisRemoteBackendConfigSupplier()

return &EngineManager{
kurtosisBackend: kurtosisBackend,
shouldSendMetrics: kurtosisConfig.GetShouldSendMetrics(),
engineServerKurtosisBackendConfigSupplier: engineBackendConfigSupplier,
clusterConfig: clusterConfig,
remoteBackendConfigSupplier: remoteBackendConfigSupplier,
clusterConfig: clusterConfig,
}, nil
}

Expand Down Expand Up @@ -143,6 +146,7 @@ func (manager *EngineManager) StartEngineIdempotentlyWithDefaultVersion(ctx cont
manager.kurtosisBackend,
manager.shouldSendMetrics,
manager.engineServerKurtosisBackendConfigSupplier,
manager.remoteBackendConfigSupplier,
logLevel,
engineVersion,
clusterType,
Expand Down Expand Up @@ -170,6 +174,7 @@ func (manager *EngineManager) StartEngineIdempotentlyWithCustomVersion(ctx conte
manager.kurtosisBackend,
manager.shouldSendMetrics,
manager.engineServerKurtosisBackendConfigSupplier,
manager.remoteBackendConfigSupplier,
engineImageVersionTag,
logLevel,
engineVersion,
Expand Down
62 changes: 48 additions & 14 deletions cli/cli/kurtosis_config/resolved_config/kurtosis_cluster_config.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,10 @@ import (
"context"
v2 "github.com/kurtosis-tech/kurtosis/cli/cli/kurtosis_config/overrides_objects/v2"
"github.com/kurtosis-tech/kurtosis/container-engine-lib/lib/backend_impls/docker/docker_kurtosis_backend/backend_creator"
"github.com/kurtosis-tech/kurtosis/container-engine-lib/lib/backend_impls/remote_context_backend"
"github.com/kurtosis-tech/kurtosis/container-engine-lib/lib/backend_interface"
"github.com/kurtosis-tech/kurtosis/contexts-config-store/api/golang/generated"
"github.com/kurtosis-tech/kurtosis/contexts-config-store/store"
"github.com/kurtosis-tech/kurtosis/engine/launcher/engine_server_launcher"
"github.com/kurtosis-tech/stacktrace"
"strings"
Expand All @@ -20,9 +23,10 @@ var dockerBackendApiContainerModeArgs *backend_creator.APIContainerModeArgs = ni
type kurtosisBackendSupplier func(ctx context.Context) (backend_interface.KurtosisBackend, error)

type KurtosisClusterConfig struct {
kurtosisBackendSupplier kurtosisBackendSupplier
engineBackendConfigSupplier engine_server_launcher.KurtosisBackendConfigSupplier
clusterType KurtosisClusterType
kurtosisBackendSupplier kurtosisBackendSupplier
engineBackendConfigSupplier engine_server_launcher.KurtosisBackendConfigSupplier
kurtosisRemoteBackendConfigSupplier *engine_server_launcher.KurtosisRemoteBackendConfigSupplier
clusterType KurtosisClusterType
}

func NewKurtosisClusterConfigFromOverrides(clusterId string, overrides *v2.KurtosisClusterConfigV2) (*KurtosisClusterConfig, error) {
Expand All @@ -41,15 +45,16 @@ func NewKurtosisClusterConfigFromOverrides(clusterId string, overrides *v2.Kurto
)
}

backendSupplier, engineBackendConfigSupplier, err := getSuppliers(clusterId, clusterType, overrides.Config)
backendSupplier, engineBackendConfigSupplier, kurtosisRemoteBackendConfigSupplier, err := getSuppliers(clusterId, clusterType, overrides.Config)
if err != nil {
return nil, stacktrace.Propagate(err, "An error occurred getting the suppliers that cluster '%v' will use", clusterId)
}

return &KurtosisClusterConfig{
kurtosisBackendSupplier: backendSupplier,
engineBackendConfigSupplier: engineBackendConfigSupplier,
clusterType: clusterType,
kurtosisBackendSupplier: backendSupplier,
engineBackendConfigSupplier: engineBackendConfigSupplier,
kurtosisRemoteBackendConfigSupplier: kurtosisRemoteBackendConfigSupplier,
clusterType: clusterType,
}, nil
}

Expand All @@ -65,6 +70,10 @@ func (clusterConfig *KurtosisClusterConfig) GetEngineBackendConfigSupplier() eng
return clusterConfig.engineBackendConfigSupplier
}

func (clusterConfig *KurtosisClusterConfig) GetKurtosisRemoteBackendConfigSupplier() *engine_server_launcher.KurtosisRemoteBackendConfigSupplier {
return clusterConfig.kurtosisRemoteBackendConfigSupplier
}

func (clusterConfig *KurtosisClusterConfig) GetClusterType() KurtosisClusterType {
return clusterConfig.clusterType
}
Expand All @@ -77,21 +86,36 @@ func (clusterConfig *KurtosisClusterConfig) GetClusterType() KurtosisClusterType
func getSuppliers(clusterId string, clusterType KurtosisClusterType, kubernetesConfig *v2.KubernetesClusterConfigV2) (
kurtosisBackendSupplier,
engine_server_launcher.KurtosisBackendConfigSupplier,
*engine_server_launcher.KurtosisRemoteBackendConfigSupplier,
error,
) {
kurtosisRemoteBackendConfigSupplier := engine_server_launcher.NewKurtosisRemoteBackendConfigSupplier(func() (*generated.KurtosisContext, error) {
contextsConfigStore := store.GetContextConfigStore()
currentContext, err := contextsConfigStore.GetCurrentContext()
if err != nil {
return nil, stacktrace.Propagate(err, "Error loading current context info")
}
return currentContext, nil
})

var backendSupplier kurtosisBackendSupplier
var engineConfigSupplier engine_server_launcher.KurtosisBackendConfigSupplier
switch clusterType {
case KurtosisClusterType_Docker:
if kubernetesConfig != nil {
return nil, nil, stacktrace.NewError(
return nil, nil, nil, stacktrace.NewError(
"Cluster '%v' defines cluster config, but config must not be provided when cluster type is '%v'",
clusterId,
clusterType.String(),
)
}

backendSupplier = func(_ context.Context) (backend_interface.KurtosisBackend, error) {
backend, err := backend_creator.GetLocalDockerKurtosisBackend(dockerBackendApiContainerModeArgs)
kurtosisRemoteBackendConfigMaybe, err := kurtosisRemoteBackendConfigSupplier.GetOptionalRemoteConfig()
if err != nil {
return nil, stacktrace.Propagate(err, "Error building optional remote Kurtosis backend config")
}
backend, err := remote_context_backend.GetContextAwareKurtosisBackend(kurtosisRemoteBackendConfigMaybe, dockerBackendApiContainerModeArgs)
if err != nil {
return nil, stacktrace.Propagate(err, "An error occurred creating the Docker Kurtosis backend")
}
Expand All @@ -101,14 +125,14 @@ func getSuppliers(clusterId string, clusterType KurtosisClusterType, kubernetesC
engineConfigSupplier = engine_server_launcher.NewDockerKurtosisBackendConfigSupplier()
case KurtosisClusterType_Kubernetes:
if kubernetesConfig == nil {
return nil, nil, stacktrace.NewError(
return nil, nil, nil, stacktrace.NewError(
"Cluster '%v' doesn't define cluster config, but config must be provided when cluster type is '%v'",
clusterId,
clusterType.String(),
)
}
if kubernetesConfig.KubernetesClusterName == nil {
return nil, nil, stacktrace.NewError(
return nil, nil, nil, stacktrace.NewError(
"Type of cluster '%v' is '%v' but has no Kubernetes cluster name in its config map",
clusterId,
clusterType,
Expand All @@ -119,7 +143,7 @@ func getSuppliers(clusterId string, clusterType KurtosisClusterType, kubernetesC
_ = *kubernetesConfig.KubernetesClusterName

if kubernetesConfig.StorageClass == nil {
return nil, nil, stacktrace.NewError(
return nil, nil, nil, stacktrace.NewError(
"Type of cluster '%v' is '%v' but no storage class was defined in the config",
clusterId,
clusterType,
Expand All @@ -133,6 +157,16 @@ func getSuppliers(clusterId string, clusterType KurtosisClusterType, kubernetesC
}

backendSupplier = func(ctx context.Context) (backend_interface.KurtosisBackend, error) {
kurtosisRemoteBackendConfigMaybe, err := kurtosisRemoteBackendConfigSupplier.GetOptionalRemoteConfig()
if err != nil {
return nil, stacktrace.Propagate(err, "Error building optional remote Kurtosis backend config")
}
if kurtosisRemoteBackendConfigMaybe != nil {
return nil, stacktrace.NewError("Using Kubernetes as a local cluster connected to a remote" +
"Kurtosis backend is currently not supported. Either switch to a local-only context to use " +
"Kubernetes locally, or switch the cluster to Docker to connect to a remote Kurtosis backend")
}

pluginPath := backend_interface.GetPluginPathForCLI(backend_interface.KubernetesPluginName)
plugin, err := backend_interface.OpenBackendPlugin(pluginPath)
if err != nil {
Expand All @@ -158,11 +192,11 @@ func getSuppliers(clusterId string, clusterType KurtosisClusterType, kubernetesC
engineConfigSupplier = engine_server_launcher.NewKubernetesKurtosisBackendConfigSupplier(storageClass, enclaveDataVolumeSizeInMb)
default:
// This should never happen because we enforce this via unit tests
return nil, nil, stacktrace.NewError(
return nil, nil, nil, stacktrace.NewError(
"Cluster '%v' has unrecognized type '%v'; this is a bug in Kurtosis",
clusterId,
clusterType.String(),
)
}
return backendSupplier, engineConfigSupplier, nil
return backendSupplier, engineConfigSupplier, kurtosisRemoteBackendConfigSupplier, nil
}
1 change: 1 addition & 0 deletions container-engine-lib/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ require (
github.com/sirupsen/logrus v1.8.1
github.com/stretchr/testify v1.7.4
go.etcd.io/bbolt v1.3.6
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c
gopkg.in/yaml.v3 v3.0.1
)

Expand Down
2 changes: 2 additions & 0 deletions container-engine-lib/go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,8 @@ golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c h1:5KslGYwFpkhGh+Q16bwMP3cOontH8FOep7tGV86Y7SQ=
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
Expand Down
Loading

0 comments on commit 595d0bc

Please sign in to comment.