Merge pull request #92 from andrewsykim/conn-lib
external-snapshotter should use CSI connection lib
This commit is contained in:
271
Gopkg.lock
generated
271
Gopkg.lock
generated
@@ -2,51 +2,66 @@
|
|||||||
|
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:93147eb1d6f08d39f2c0efe3d29ee043bda72be7a8b3b367eb08c72c18524638"
|
||||||
name = "github.com/container-storage-interface/spec"
|
name = "github.com/container-storage-interface/spec"
|
||||||
packages = ["lib/go/csi"]
|
packages = ["lib/go/csi"]
|
||||||
|
pruneopts = ""
|
||||||
revision = "ed0bb0e1557548aa028307f48728767cfe8f6345"
|
revision = "ed0bb0e1557548aa028307f48728767cfe8f6345"
|
||||||
version = "v1.0.0"
|
version = "v1.0.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:0deddd908b6b4b768cfc272c16ee61e7088a60f7fe2f06c547bd3d8e1f8b8e77"
|
||||||
name = "github.com/davecgh/go-spew"
|
name = "github.com/davecgh/go-spew"
|
||||||
packages = ["spew"]
|
packages = ["spew"]
|
||||||
|
pruneopts = ""
|
||||||
revision = "8991bc29aa16c548c550c7ff78260e27b9ab7c73"
|
revision = "8991bc29aa16c548c550c7ff78260e27b9ab7c73"
|
||||||
version = "v1.1.1"
|
version = "v1.1.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:4216202f4088a73e2982df875e2f0d1401137bbc248e57391e70547af167a18a"
|
||||||
name = "github.com/evanphx/json-patch"
|
name = "github.com/evanphx/json-patch"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "72bf35d0ff611848c1dc9df0f976c81192392fa5"
|
revision = "72bf35d0ff611848c1dc9df0f976c81192392fa5"
|
||||||
version = "v4.1.0"
|
version = "v4.1.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:6e73003ecd35f4487a5e88270d3ca0a81bc80dc88053ac7e4dcfec5fba30d918"
|
||||||
name = "github.com/gogo/protobuf"
|
name = "github.com/gogo/protobuf"
|
||||||
packages = [
|
packages = [
|
||||||
"proto",
|
"proto",
|
||||||
"sortkeys"
|
"sortkeys",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "636bf0302bc95575d69441b25a2603156ffdddf1"
|
revision = "636bf0302bc95575d69441b25a2603156ffdddf1"
|
||||||
version = "v1.1.1"
|
version = "v1.1.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:107b233e45174dbab5b1324201d092ea9448e58243ab9f039e4c0f332e121e3a"
|
||||||
name = "github.com/golang/glog"
|
name = "github.com/golang/glog"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "23def4e6c14b4da8ac2ed8007337bc5eb5007998"
|
revision = "23def4e6c14b4da8ac2ed8007337bc5eb5007998"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:aa2251148505e561bfa8cd6b69a319b37761da57b0b25529c4af08389559e3b9"
|
||||||
name = "github.com/golang/groupcache"
|
name = "github.com/golang/groupcache"
|
||||||
packages = ["lru"]
|
packages = ["lru"]
|
||||||
|
pruneopts = ""
|
||||||
revision = "c65c006176ff7ff98bb916961c7abbc6b0afc0aa"
|
revision = "c65c006176ff7ff98bb916961c7abbc6b0afc0aa"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:73a7106c799f98af4f3da7552906efc6a2570329f4cd2d2f5fb8f9d6c053ff2f"
|
||||||
name = "github.com/golang/mock"
|
name = "github.com/golang/mock"
|
||||||
packages = ["gomock"]
|
packages = ["gomock"]
|
||||||
|
pruneopts = ""
|
||||||
revision = "c34cdb4725f4c3844d095133c6e40e448b86589b"
|
revision = "c34cdb4725f4c3844d095133c6e40e448b86589b"
|
||||||
version = "v1.1.1"
|
version = "v1.1.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:3dd078fda7500c341bc26cfbc6c6a34614f295a2457149fc1045cab767cbcf18"
|
||||||
name = "github.com/golang/protobuf"
|
name = "github.com/golang/protobuf"
|
||||||
packages = [
|
packages = [
|
||||||
"descriptor",
|
"descriptor",
|
||||||
@@ -56,116 +71,151 @@
|
|||||||
"ptypes/any",
|
"ptypes/any",
|
||||||
"ptypes/duration",
|
"ptypes/duration",
|
||||||
"ptypes/timestamp",
|
"ptypes/timestamp",
|
||||||
"ptypes/wrappers"
|
"ptypes/wrappers",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "aa810b61a9c79d51363740d207bb46cf8e620ed5"
|
revision = "aa810b61a9c79d51363740d207bb46cf8e620ed5"
|
||||||
version = "v1.2.0"
|
version = "v1.2.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:1e5b1e14524ed08301977b7b8e10c719ed853cbf3f24ecb66fae783a46f207a6"
|
||||||
name = "github.com/google/btree"
|
name = "github.com/google/btree"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "4030bb1f1f0c35b30ca7009e9ebd06849dd45306"
|
revision = "4030bb1f1f0c35b30ca7009e9ebd06849dd45306"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:754f77e9c839b24778a4b64422236d38515301d2baeb63113aa3edc42e6af692"
|
||||||
name = "github.com/google/gofuzz"
|
name = "github.com/google/gofuzz"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "24818f796faf91cd76ec7bddd72458fbced7a6c1"
|
revision = "24818f796faf91cd76ec7bddd72458fbced7a6c1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:16b2837c8b3cf045fa2cdc82af0cf78b19582701394484ae76b2c3bc3c99ad73"
|
||||||
name = "github.com/googleapis/gnostic"
|
name = "github.com/googleapis/gnostic"
|
||||||
packages = [
|
packages = [
|
||||||
"OpenAPIv2",
|
"OpenAPIv2",
|
||||||
"compiler",
|
"compiler",
|
||||||
"extensions"
|
"extensions",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "7c663266750e7d82587642f65e60bc4083f1f84e"
|
revision = "7c663266750e7d82587642f65e60bc4083f1f84e"
|
||||||
version = "v0.2.0"
|
version = "v0.2.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:5e345eb75d8bfb2b91cfbfe02a82a79c0b2ea55cf06c5a4d180a9321f36973b4"
|
||||||
name = "github.com/gregjones/httpcache"
|
name = "github.com/gregjones/httpcache"
|
||||||
packages = [
|
packages = [
|
||||||
".",
|
".",
|
||||||
"diskcache"
|
"diskcache",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "c63ab54fda8f77302f8d414e19933f2b6026a089"
|
revision = "c63ab54fda8f77302f8d414e19933f2b6026a089"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:3313a63031ae281e5f6fd7b0bbca733dfa04d2429df86519e3b4d4c016ccb836"
|
||||||
name = "github.com/hashicorp/golang-lru"
|
name = "github.com/hashicorp/golang-lru"
|
||||||
packages = [
|
packages = [
|
||||||
".",
|
".",
|
||||||
"simplelru"
|
"simplelru",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "20f1fb78b0740ba8c3cb143a61e86ba5c8669768"
|
revision = "20f1fb78b0740ba8c3cb143a61e86ba5c8669768"
|
||||||
version = "v0.5.0"
|
version = "v0.5.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:7ab38c15bd21e056e3115c8b526d201eaf74e0308da9370997c6b3c187115d36"
|
||||||
name = "github.com/imdario/mergo"
|
name = "github.com/imdario/mergo"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "9f23e2d6bd2a77f959b2bf6acdbefd708a83a4a4"
|
revision = "9f23e2d6bd2a77f959b2bf6acdbefd708a83a4a4"
|
||||||
version = "v0.3.6"
|
version = "v0.3.6"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:b79fc583e4dc7055ed86742e22164ac41bf8c0940722dbcb600f1a3ace1a8cb5"
|
||||||
name = "github.com/json-iterator/go"
|
name = "github.com/json-iterator/go"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "1624edc4454b8682399def8740d46db5e4362ba4"
|
revision = "1624edc4454b8682399def8740d46db5e4362ba4"
|
||||||
version = "v1.1.5"
|
version = "v1.1.5"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:e733fe02fbb47b16820ad0fc227c2c907e33d066b95003bc22040643fa1f6334"
|
||||||
name = "github.com/kubernetes-csi/csi-lib-utils"
|
name = "github.com/kubernetes-csi/csi-lib-utils"
|
||||||
packages = ["protosanitizer"]
|
packages = [
|
||||||
revision = "1628ab5351eafa4fc89a96862a08a891e601e03a"
|
"connection",
|
||||||
version = "v0.1.0"
|
"protosanitizer",
|
||||||
|
]
|
||||||
|
pruneopts = ""
|
||||||
|
revision = "763b95da1f9f7804ffe5e33f9aee5debf4517adf"
|
||||||
|
version = "v0.3.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:79848f850d0d15b2413a7285441a7fd13ed8a901ebe57d59f1e49759c103b930"
|
||||||
name = "github.com/kubernetes-csi/csi-test"
|
name = "github.com/kubernetes-csi/csi-test"
|
||||||
packages = [
|
packages = [
|
||||||
"driver",
|
"driver",
|
||||||
"utils"
|
"utils",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "619da6853e10bef67ddcc8f1c2b68b73154bf11d"
|
revision = "619da6853e10bef67ddcc8f1c2b68b73154bf11d"
|
||||||
version = "v1.0.0-rc2"
|
version = "v1.0.0-rc2"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:0c0ff2a89c1bb0d01887e1dac043ad7efbf3ec77482ef058ac423d13497e16fd"
|
||||||
name = "github.com/modern-go/concurrent"
|
name = "github.com/modern-go/concurrent"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "bacd9c7ef1dd9b15be4a9909b8ac7a4e313eec94"
|
revision = "bacd9c7ef1dd9b15be4a9909b8ac7a4e313eec94"
|
||||||
version = "1.0.3"
|
version = "1.0.3"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:e32bdbdb7c377a07a9a46378290059822efdce5c8d96fe71940d87cb4f918855"
|
||||||
name = "github.com/modern-go/reflect2"
|
name = "github.com/modern-go/reflect2"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "4b7aa43c6742a2c18fdef89dd197aaae7dac7ccd"
|
revision = "4b7aa43c6742a2c18fdef89dd197aaae7dac7ccd"
|
||||||
version = "1.0.1"
|
version = "1.0.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:c24598ffeadd2762552269271b3b1510df2d83ee6696c1e543a0ff653af494bc"
|
||||||
name = "github.com/petar/GoLLRB"
|
name = "github.com/petar/GoLLRB"
|
||||||
packages = ["llrb"]
|
packages = ["llrb"]
|
||||||
|
pruneopts = ""
|
||||||
revision = "53be0d36a84c2a886ca057d34b6aa4468df9ccb4"
|
revision = "53be0d36a84c2a886ca057d34b6aa4468df9ccb4"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:b46305723171710475f2dd37547edd57b67b9de9f2a6267cafdd98331fd6897f"
|
||||||
name = "github.com/peterbourgon/diskv"
|
name = "github.com/peterbourgon/diskv"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "5f041e8faa004a95c88a202771f4cc3e991971e6"
|
revision = "5f041e8faa004a95c88a202771f4cc3e991971e6"
|
||||||
version = "v2.0.1"
|
version = "v2.0.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:cbaf13cdbfef0e4734ed8a7504f57fe893d471d62a35b982bf6fb3f036449a66"
|
||||||
name = "github.com/spf13/pflag"
|
name = "github.com/spf13/pflag"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "298182f68c66c05229eb03ac171abe6e309ee79a"
|
revision = "298182f68c66c05229eb03ac171abe6e309ee79a"
|
||||||
version = "v1.0.3"
|
version = "v1.0.3"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:f7be435e0ca22e2cd62b2d2542081a231685837170a87a3662abb7cdf9f3f1cd"
|
||||||
name = "golang.org/x/crypto"
|
name = "golang.org/x/crypto"
|
||||||
packages = ["ssh/terminal"]
|
packages = ["ssh/terminal"]
|
||||||
|
pruneopts = ""
|
||||||
revision = "3d3f9f413869b949e48070b5bc593aa22cc2b8f2"
|
revision = "3d3f9f413869b949e48070b5bc593aa22cc2b8f2"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:4ac199b027ed34460ec4e0a92c882156f561e78cd046fef095e50f867462435a"
|
||||||
name = "golang.org/x/net"
|
name = "golang.org/x/net"
|
||||||
packages = [
|
packages = [
|
||||||
"context",
|
"context",
|
||||||
@@ -175,29 +225,35 @@
|
|||||||
"http2/hpack",
|
"http2/hpack",
|
||||||
"idna",
|
"idna",
|
||||||
"internal/timeseries",
|
"internal/timeseries",
|
||||||
"trace"
|
"trace",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "adae6a3d119ae4890b46832a2e88a95adc62b8e7"
|
revision = "adae6a3d119ae4890b46832a2e88a95adc62b8e7"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:51d339a1d79f5c617fba14414aefb7dfd184b8ba0ddbb9f95251430b67c8aab8"
|
||||||
name = "golang.org/x/oauth2"
|
name = "golang.org/x/oauth2"
|
||||||
packages = [
|
packages = [
|
||||||
".",
|
".",
|
||||||
"internal"
|
"internal",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "f42d05182288abf10faef86d16c0d07b8d40ea2d"
|
revision = "f42d05182288abf10faef86d16c0d07b8d40ea2d"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:0ad2730a94694f9968449f91f0311788b58b2822ff5eff299202e02f538c6027"
|
||||||
name = "golang.org/x/sys"
|
name = "golang.org/x/sys"
|
||||||
packages = [
|
packages = [
|
||||||
"unix",
|
"unix",
|
||||||
"windows"
|
"windows",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "ec83556a53fe16b65c452a104ea9d1e86a671852"
|
revision = "ec83556a53fe16b65c452a104ea9d1e86a671852"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:5acd3512b047305d49e8763eef7ba423901e85d5dd2fd1e71778a0ea8de10bd4"
|
||||||
name = "golang.org/x/text"
|
name = "golang.org/x/text"
|
||||||
packages = [
|
packages = [
|
||||||
"collate",
|
"collate",
|
||||||
@@ -213,29 +269,35 @@
|
|||||||
"unicode/bidi",
|
"unicode/bidi",
|
||||||
"unicode/cldr",
|
"unicode/cldr",
|
||||||
"unicode/norm",
|
"unicode/norm",
|
||||||
"unicode/rangetable"
|
"unicode/rangetable",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "f21a4dfb5e38f5895301dc265a8def02365cc3d0"
|
revision = "f21a4dfb5e38f5895301dc265a8def02365cc3d0"
|
||||||
version = "v0.3.0"
|
version = "v0.3.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:14cb1d4240bcbbf1386ae763957e04e2765ec4e4ce7bb2769d05fa6faccd774e"
|
||||||
name = "golang.org/x/time"
|
name = "golang.org/x/time"
|
||||||
packages = ["rate"]
|
packages = ["rate"]
|
||||||
|
pruneopts = ""
|
||||||
revision = "85acf8d2951cb2a3bde7632f9ff273ef0379bcbd"
|
revision = "85acf8d2951cb2a3bde7632f9ff273ef0379bcbd"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:f17543c60083ff4f8fae5ee3e5d51bcd6fece074fd39a49cfd0f29573039dd17"
|
||||||
name = "golang.org/x/tools"
|
name = "golang.org/x/tools"
|
||||||
packages = [
|
packages = [
|
||||||
"go/ast/astutil",
|
"go/ast/astutil",
|
||||||
"imports",
|
"imports",
|
||||||
"internal/fastwalk",
|
"internal/fastwalk",
|
||||||
"internal/gopathwalk"
|
"internal/gopathwalk",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "89e258047f9bd4255fae0d48139e1d5ff0a7b8dd"
|
revision = "89e258047f9bd4255fae0d48139e1d5ff0a7b8dd"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:77d3cff3a451d50be4b52db9c7766c0d8570ba47593f0c9dc72173adb208e788"
|
||||||
name = "google.golang.org/appengine"
|
name = "google.golang.org/appengine"
|
||||||
packages = [
|
packages = [
|
||||||
"internal",
|
"internal",
|
||||||
@@ -244,18 +306,22 @@
|
|||||||
"internal/log",
|
"internal/log",
|
||||||
"internal/remote_api",
|
"internal/remote_api",
|
||||||
"internal/urlfetch",
|
"internal/urlfetch",
|
||||||
"urlfetch"
|
"urlfetch",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "4a4468ece617fc8205e99368fa2200e9d1fad421"
|
revision = "4a4468ece617fc8205e99368fa2200e9d1fad421"
|
||||||
version = "v1.3.0"
|
version = "v1.3.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:212d4045ef941b209a154001718705dc723bd77e0200fcea36d15ec87ed49dec"
|
||||||
name = "google.golang.org/genproto"
|
name = "google.golang.org/genproto"
|
||||||
packages = ["googleapis/rpc/status"]
|
packages = ["googleapis/rpc/status"]
|
||||||
|
pruneopts = ""
|
||||||
revision = "b5d43981345bdb2c233eb4bf3277847b48c6fdc6"
|
revision = "b5d43981345bdb2c233eb4bf3277847b48c6fdc6"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:1293087271e314cfa2b3decededba2ecba0ff327e7b7809e00f73f616449191c"
|
||||||
name = "google.golang.org/grpc"
|
name = "google.golang.org/grpc"
|
||||||
packages = [
|
packages = [
|
||||||
".",
|
".",
|
||||||
@@ -285,24 +351,30 @@
|
|||||||
"resolver/passthrough",
|
"resolver/passthrough",
|
||||||
"stats",
|
"stats",
|
||||||
"status",
|
"status",
|
||||||
"tap"
|
"tap",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "2e463a05d100327ca47ac218281906921038fd95"
|
revision = "2e463a05d100327ca47ac218281906921038fd95"
|
||||||
version = "v1.16.0"
|
version = "v1.16.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:75fb3fcfc73a8c723efde7777b40e8e8ff9babf30d8c56160d01beffea8a95a6"
|
||||||
name = "gopkg.in/inf.v0"
|
name = "gopkg.in/inf.v0"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "d2d2541c53f18d2a059457998ce2876cc8e67cbf"
|
revision = "d2d2541c53f18d2a059457998ce2876cc8e67cbf"
|
||||||
version = "v0.9.1"
|
version = "v0.9.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:f0620375dd1f6251d9973b5f2596228cc8042e887cd7f827e4220bc1ce8c30e2"
|
||||||
name = "gopkg.in/yaml.v2"
|
name = "gopkg.in/yaml.v2"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "5420a8b6744d3b0345ab293f6fcba19c978f1183"
|
revision = "5420a8b6744d3b0345ab293f6fcba19c978f1183"
|
||||||
version = "v2.2.1"
|
version = "v2.2.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:63ada4e68469e695bda7bb2a14f3009c1fc6e78b0f36d53436b38d919a576109"
|
||||||
name = "k8s.io/api"
|
name = "k8s.io/api"
|
||||||
packages = [
|
packages = [
|
||||||
"admissionregistration/v1alpha1",
|
"admissionregistration/v1alpha1",
|
||||||
@@ -336,24 +408,28 @@
|
|||||||
"settings/v1alpha1",
|
"settings/v1alpha1",
|
||||||
"storage/v1",
|
"storage/v1",
|
||||||
"storage/v1alpha1",
|
"storage/v1alpha1",
|
||||||
"storage/v1beta1"
|
"storage/v1beta1",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "d01564359763a39d310efc27866b63d4f5c92f1d"
|
revision = "d01564359763a39d310efc27866b63d4f5c92f1d"
|
||||||
version = "kubernetes-1.13.0-beta.1"
|
version = "kubernetes-1.13.0-beta.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:fdde42c63adc2e1605319b3fe32843c1c33fd70434c9acfaf20e5a465216ceab"
|
||||||
name = "k8s.io/apiextensions-apiserver"
|
name = "k8s.io/apiextensions-apiserver"
|
||||||
packages = [
|
packages = [
|
||||||
"pkg/apis/apiextensions",
|
"pkg/apis/apiextensions",
|
||||||
"pkg/apis/apiextensions/v1beta1",
|
"pkg/apis/apiextensions/v1beta1",
|
||||||
"pkg/client/clientset/clientset",
|
"pkg/client/clientset/clientset",
|
||||||
"pkg/client/clientset/clientset/scheme",
|
"pkg/client/clientset/clientset/scheme",
|
||||||
"pkg/client/clientset/clientset/typed/apiextensions/v1beta1"
|
"pkg/client/clientset/clientset/typed/apiextensions/v1beta1",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "e1ae69ff7b8b6c135578c1892f3781c55d75c69e"
|
revision = "e1ae69ff7b8b6c135578c1892f3781c55d75c69e"
|
||||||
version = "kubernetes-1.13.0-beta.1"
|
version = "kubernetes-1.13.0-beta.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:3166a472475f9904e42f93565fca74f7f20d9a5f3bc1b0ac321aedc5a211e796"
|
||||||
name = "k8s.io/apimachinery"
|
name = "k8s.io/apimachinery"
|
||||||
packages = [
|
packages = [
|
||||||
"pkg/api/errors",
|
"pkg/api/errors",
|
||||||
@@ -398,16 +474,64 @@
|
|||||||
"pkg/version",
|
"pkg/version",
|
||||||
"pkg/watch",
|
"pkg/watch",
|
||||||
"third_party/forked/golang/json",
|
"third_party/forked/golang/json",
|
||||||
"third_party/forked/golang/reflect"
|
"third_party/forked/golang/reflect",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "0028e7a3cc82b29fea214c5793c77c24a23bb3ef"
|
revision = "0028e7a3cc82b29fea214c5793c77c24a23bb3ef"
|
||||||
version = "kubernetes-1.13.0-beta.1"
|
version = "kubernetes-1.13.0-beta.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:c521267e4944f34c38ac078f20b3d485a5ca709d5e53d80586182cc0ef675f65"
|
||||||
name = "k8s.io/client-go"
|
name = "k8s.io/client-go"
|
||||||
packages = [
|
packages = [
|
||||||
"discovery",
|
"discovery",
|
||||||
"discovery/fake",
|
"discovery/fake",
|
||||||
|
"informers",
|
||||||
|
"informers/admissionregistration",
|
||||||
|
"informers/admissionregistration/v1alpha1",
|
||||||
|
"informers/admissionregistration/v1beta1",
|
||||||
|
"informers/apps",
|
||||||
|
"informers/apps/v1",
|
||||||
|
"informers/apps/v1beta1",
|
||||||
|
"informers/apps/v1beta2",
|
||||||
|
"informers/auditregistration",
|
||||||
|
"informers/auditregistration/v1alpha1",
|
||||||
|
"informers/autoscaling",
|
||||||
|
"informers/autoscaling/v1",
|
||||||
|
"informers/autoscaling/v2beta1",
|
||||||
|
"informers/autoscaling/v2beta2",
|
||||||
|
"informers/batch",
|
||||||
|
"informers/batch/v1",
|
||||||
|
"informers/batch/v1beta1",
|
||||||
|
"informers/batch/v2alpha1",
|
||||||
|
"informers/certificates",
|
||||||
|
"informers/certificates/v1beta1",
|
||||||
|
"informers/coordination",
|
||||||
|
"informers/coordination/v1beta1",
|
||||||
|
"informers/core",
|
||||||
|
"informers/core/v1",
|
||||||
|
"informers/events",
|
||||||
|
"informers/events/v1beta1",
|
||||||
|
"informers/extensions",
|
||||||
|
"informers/extensions/v1beta1",
|
||||||
|
"informers/internalinterfaces",
|
||||||
|
"informers/networking",
|
||||||
|
"informers/networking/v1",
|
||||||
|
"informers/policy",
|
||||||
|
"informers/policy/v1beta1",
|
||||||
|
"informers/rbac",
|
||||||
|
"informers/rbac/v1",
|
||||||
|
"informers/rbac/v1alpha1",
|
||||||
|
"informers/rbac/v1beta1",
|
||||||
|
"informers/scheduling",
|
||||||
|
"informers/scheduling/v1alpha1",
|
||||||
|
"informers/scheduling/v1beta1",
|
||||||
|
"informers/settings",
|
||||||
|
"informers/settings/v1alpha1",
|
||||||
|
"informers/storage",
|
||||||
|
"informers/storage/v1",
|
||||||
|
"informers/storage/v1alpha1",
|
||||||
|
"informers/storage/v1beta1",
|
||||||
"kubernetes",
|
"kubernetes",
|
||||||
"kubernetes/fake",
|
"kubernetes/fake",
|
||||||
"kubernetes/scheme",
|
"kubernetes/scheme",
|
||||||
@@ -475,6 +599,34 @@
|
|||||||
"kubernetes/typed/storage/v1alpha1/fake",
|
"kubernetes/typed/storage/v1alpha1/fake",
|
||||||
"kubernetes/typed/storage/v1beta1",
|
"kubernetes/typed/storage/v1beta1",
|
||||||
"kubernetes/typed/storage/v1beta1/fake",
|
"kubernetes/typed/storage/v1beta1/fake",
|
||||||
|
"listers/admissionregistration/v1alpha1",
|
||||||
|
"listers/admissionregistration/v1beta1",
|
||||||
|
"listers/apps/v1",
|
||||||
|
"listers/apps/v1beta1",
|
||||||
|
"listers/apps/v1beta2",
|
||||||
|
"listers/auditregistration/v1alpha1",
|
||||||
|
"listers/autoscaling/v1",
|
||||||
|
"listers/autoscaling/v2beta1",
|
||||||
|
"listers/autoscaling/v2beta2",
|
||||||
|
"listers/batch/v1",
|
||||||
|
"listers/batch/v1beta1",
|
||||||
|
"listers/batch/v2alpha1",
|
||||||
|
"listers/certificates/v1beta1",
|
||||||
|
"listers/coordination/v1beta1",
|
||||||
|
"listers/core/v1",
|
||||||
|
"listers/events/v1beta1",
|
||||||
|
"listers/extensions/v1beta1",
|
||||||
|
"listers/networking/v1",
|
||||||
|
"listers/policy/v1beta1",
|
||||||
|
"listers/rbac/v1",
|
||||||
|
"listers/rbac/v1alpha1",
|
||||||
|
"listers/rbac/v1beta1",
|
||||||
|
"listers/scheduling/v1alpha1",
|
||||||
|
"listers/scheduling/v1beta1",
|
||||||
|
"listers/settings/v1alpha1",
|
||||||
|
"listers/storage/v1",
|
||||||
|
"listers/storage/v1alpha1",
|
||||||
|
"listers/storage/v1beta1",
|
||||||
"pkg/apis/clientauthentication",
|
"pkg/apis/clientauthentication",
|
||||||
"pkg/apis/clientauthentication/v1alpha1",
|
"pkg/apis/clientauthentication/v1alpha1",
|
||||||
"pkg/apis/clientauthentication/v1beta1",
|
"pkg/apis/clientauthentication/v1beta1",
|
||||||
@@ -501,12 +653,14 @@
|
|||||||
"util/homedir",
|
"util/homedir",
|
||||||
"util/integer",
|
"util/integer",
|
||||||
"util/retry",
|
"util/retry",
|
||||||
"util/workqueue"
|
"util/workqueue",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "46a8dc78ec29761d6cb89a9eb50ddde947c84030"
|
revision = "46a8dc78ec29761d6cb89a9eb50ddde947c84030"
|
||||||
version = "kubernetes-1.13.0-beta.1"
|
version = "kubernetes-1.13.0-beta.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:d809e6c8dfa3448ae10f5624eff4ed1ebdc906755e7cea294c44e8b7ac0b077a"
|
||||||
name = "k8s.io/code-generator"
|
name = "k8s.io/code-generator"
|
||||||
packages = [
|
packages = [
|
||||||
"cmd/client-gen",
|
"cmd/client-gen",
|
||||||
@@ -527,13 +681,15 @@
|
|||||||
"cmd/lister-gen",
|
"cmd/lister-gen",
|
||||||
"cmd/lister-gen/args",
|
"cmd/lister-gen/args",
|
||||||
"cmd/lister-gen/generators",
|
"cmd/lister-gen/generators",
|
||||||
"pkg/util"
|
"pkg/util",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "c2090bec4d9b1fb25de3812f868accc2bc9ecbae"
|
revision = "c2090bec4d9b1fb25de3812f868accc2bc9ecbae"
|
||||||
version = "kubernetes-1.13.0-beta.1"
|
version = "kubernetes-1.13.0-beta.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:0cc7d194e005097afad585545a3049ac7b5d1e3a1bfa86aa6bf6f2fb0e0a5063"
|
||||||
name = "k8s.io/gengo"
|
name = "k8s.io/gengo"
|
||||||
packages = [
|
packages = [
|
||||||
"args",
|
"args",
|
||||||
@@ -543,41 +699,108 @@
|
|||||||
"generator",
|
"generator",
|
||||||
"namer",
|
"namer",
|
||||||
"parser",
|
"parser",
|
||||||
"types"
|
"types",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "fd15ee9cc2f77baa4f31e59e6acbf21146455073"
|
revision = "fd15ee9cc2f77baa4f31e59e6acbf21146455073"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:4f5eb833037cc0ba0bf8fe9cae6be9df62c19dd1c869415275c708daa8ccfda5"
|
||||||
name = "k8s.io/klog"
|
name = "k8s.io/klog"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "a5bc97fbc634d635061f3146511332c7e313a55a"
|
revision = "a5bc97fbc634d635061f3146511332c7e313a55a"
|
||||||
version = "v0.1.0"
|
version = "v0.1.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
|
digest = "1:e5d4ca90c0f3862515c98454bb37d4d340f4ceeca60ac3e0a5cb5857360aed7c"
|
||||||
name = "k8s.io/kube-openapi"
|
name = "k8s.io/kube-openapi"
|
||||||
packages = ["pkg/util/proto"]
|
packages = ["pkg/util/proto"]
|
||||||
|
pruneopts = ""
|
||||||
revision = "0317810137be915b9cf888946c6e115c1bfac693"
|
revision = "0317810137be915b9cf888946c6e115c1bfac693"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:6061aa42761235df375f20fa4a1aa6d1845cba3687575f3adb2ef3f3bc540af5"
|
||||||
name = "k8s.io/kubernetes"
|
name = "k8s.io/kubernetes"
|
||||||
packages = [
|
packages = [
|
||||||
"pkg/util/goroutinemap",
|
"pkg/util/goroutinemap",
|
||||||
"pkg/util/goroutinemap/exponentialbackoff",
|
"pkg/util/goroutinemap/exponentialbackoff",
|
||||||
"pkg/util/slice"
|
"pkg/util/slice",
|
||||||
]
|
]
|
||||||
|
pruneopts = ""
|
||||||
revision = "17c77c7898218073f14c8d573582e8d2313dc740"
|
revision = "17c77c7898218073f14c8d573582e8d2313dc740"
|
||||||
version = "v1.12.2"
|
version = "v1.12.2"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
|
digest = "1:321081b4a44256715f2b68411d8eda9a17f17ebfe6f0cc61d2cc52d11c08acfa"
|
||||||
name = "sigs.k8s.io/yaml"
|
name = "sigs.k8s.io/yaml"
|
||||||
packages = ["."]
|
packages = ["."]
|
||||||
|
pruneopts = ""
|
||||||
revision = "fd68e9863619f6ec2fdd8625fe1f02e7c877e480"
|
revision = "fd68e9863619f6ec2fdd8625fe1f02e7c877e480"
|
||||||
version = "v1.1.0"
|
version = "v1.1.0"
|
||||||
|
|
||||||
[solve-meta]
|
[solve-meta]
|
||||||
analyzer-name = "dep"
|
analyzer-name = "dep"
|
||||||
analyzer-version = 1
|
analyzer-version = 1
|
||||||
inputs-digest = "1ffccc02a34124d103d58b579a8e5b8aec657e279f0bfbaaeb3eeeed9c146182"
|
input-imports = [
|
||||||
|
"github.com/container-storage-interface/spec/lib/go/csi",
|
||||||
|
"github.com/golang/glog",
|
||||||
|
"github.com/golang/mock/gomock",
|
||||||
|
"github.com/golang/protobuf/ptypes",
|
||||||
|
"github.com/golang/protobuf/ptypes/timestamp",
|
||||||
|
"github.com/kubernetes-csi/csi-lib-utils/connection",
|
||||||
|
"github.com/kubernetes-csi/csi-lib-utils/protosanitizer",
|
||||||
|
"github.com/kubernetes-csi/csi-test/driver",
|
||||||
|
"google.golang.org/grpc",
|
||||||
|
"google.golang.org/grpc/codes",
|
||||||
|
"google.golang.org/grpc/connectivity",
|
||||||
|
"google.golang.org/grpc/status",
|
||||||
|
"k8s.io/api/core/v1",
|
||||||
|
"k8s.io/api/storage/v1",
|
||||||
|
"k8s.io/api/storage/v1beta1",
|
||||||
|
"k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1beta1",
|
||||||
|
"k8s.io/apiextensions-apiserver/pkg/client/clientset/clientset",
|
||||||
|
"k8s.io/apimachinery/pkg/api/errors",
|
||||||
|
"k8s.io/apimachinery/pkg/api/meta",
|
||||||
|
"k8s.io/apimachinery/pkg/api/resource",
|
||||||
|
"k8s.io/apimachinery/pkg/apis/meta/v1",
|
||||||
|
"k8s.io/apimachinery/pkg/labels",
|
||||||
|
"k8s.io/apimachinery/pkg/runtime",
|
||||||
|
"k8s.io/apimachinery/pkg/runtime/schema",
|
||||||
|
"k8s.io/apimachinery/pkg/runtime/serializer",
|
||||||
|
"k8s.io/apimachinery/pkg/types",
|
||||||
|
"k8s.io/apimachinery/pkg/util/diff",
|
||||||
|
"k8s.io/apimachinery/pkg/util/runtime",
|
||||||
|
"k8s.io/apimachinery/pkg/util/sets",
|
||||||
|
"k8s.io/apimachinery/pkg/util/validation",
|
||||||
|
"k8s.io/apimachinery/pkg/util/wait",
|
||||||
|
"k8s.io/apimachinery/pkg/watch",
|
||||||
|
"k8s.io/client-go/discovery",
|
||||||
|
"k8s.io/client-go/discovery/fake",
|
||||||
|
"k8s.io/client-go/informers",
|
||||||
|
"k8s.io/client-go/informers/core/v1",
|
||||||
|
"k8s.io/client-go/kubernetes",
|
||||||
|
"k8s.io/client-go/kubernetes/fake",
|
||||||
|
"k8s.io/client-go/kubernetes/scheme",
|
||||||
|
"k8s.io/client-go/kubernetes/typed/core/v1",
|
||||||
|
"k8s.io/client-go/listers/core/v1",
|
||||||
|
"k8s.io/client-go/rest",
|
||||||
|
"k8s.io/client-go/testing",
|
||||||
|
"k8s.io/client-go/tools/cache",
|
||||||
|
"k8s.io/client-go/tools/clientcmd",
|
||||||
|
"k8s.io/client-go/tools/record",
|
||||||
|
"k8s.io/client-go/tools/reference",
|
||||||
|
"k8s.io/client-go/util/flowcontrol",
|
||||||
|
"k8s.io/client-go/util/workqueue",
|
||||||
|
"k8s.io/code-generator/cmd/client-gen",
|
||||||
|
"k8s.io/code-generator/cmd/deepcopy-gen",
|
||||||
|
"k8s.io/code-generator/cmd/defaulter-gen",
|
||||||
|
"k8s.io/code-generator/cmd/informer-gen",
|
||||||
|
"k8s.io/code-generator/cmd/lister-gen",
|
||||||
|
"k8s.io/kubernetes/pkg/util/goroutinemap",
|
||||||
|
"k8s.io/kubernetes/pkg/util/goroutinemap/exponentialbackoff",
|
||||||
|
"k8s.io/kubernetes/pkg/util/slice",
|
||||||
|
]
|
||||||
solver-name = "gps-cdcl"
|
solver-name = "gps-cdcl"
|
||||||
solver-version = 1
|
solver-version = 1
|
||||||
|
@@ -55,4 +55,4 @@ required = [
|
|||||||
|
|
||||||
[[constraint]]
|
[[constraint]]
|
||||||
name = "github.com/kubernetes-csi/csi-lib-utils"
|
name = "github.com/kubernetes-csi/csi-lib-utils"
|
||||||
version = "0.1.0"
|
version = "0.3.0"
|
||||||
|
@@ -52,7 +52,7 @@ const (
|
|||||||
var (
|
var (
|
||||||
snapshotter = flag.String("snapshotter", "", "Name of the snapshotter. The snapshotter will only create snapshot content for snapshot that requests a VolumeSnapshotClass with a snapshotter field set equal to this name.")
|
snapshotter = flag.String("snapshotter", "", "Name of the snapshotter. The snapshotter will only create snapshot content for snapshot that requests a VolumeSnapshotClass with a snapshotter field set equal to this name.")
|
||||||
kubeconfig = flag.String("kubeconfig", "", "Absolute path to the kubeconfig file. Required only when running out of cluster.")
|
kubeconfig = flag.String("kubeconfig", "", "Absolute path to the kubeconfig file. Required only when running out of cluster.")
|
||||||
connectionTimeout = flag.Duration("connection-timeout", 1*time.Minute, "Timeout for waiting for CSI driver socket.")
|
connectionTimeout = flag.Duration("connection-timeout", 0, "The --connection-timeout flag is deprecated")
|
||||||
csiAddress = flag.String("csi-address", "/run/csi/socket", "Address of the CSI driver socket.")
|
csiAddress = flag.String("csi-address", "/run/csi/socket", "Address of the CSI driver socket.")
|
||||||
createSnapshotContentRetryCount = flag.Int("create-snapshotcontent-retrycount", 5, "Number of retries when we create a snapshot content object for a snapshot.")
|
createSnapshotContentRetryCount = flag.Int("create-snapshotcontent-retrycount", 5, "Number of retries when we create a snapshot content object for a snapshot.")
|
||||||
createSnapshotContentInterval = flag.Duration("create-snapshotcontent-interval", 10*time.Second, "Interval between retries when we create a snapshot content object for a snapshot.")
|
createSnapshotContentInterval = flag.Duration("create-snapshotcontent-interval", 10*time.Second, "Interval between retries when we create a snapshot content object for a snapshot.")
|
||||||
@@ -76,6 +76,10 @@ func main() {
|
|||||||
}
|
}
|
||||||
glog.Infof("Version: %s", version)
|
glog.Infof("Version: %s", version)
|
||||||
|
|
||||||
|
if *connectionTimeout != 0 {
|
||||||
|
glog.Warning("--connection-timeout is deprecated and will have no effect")
|
||||||
|
}
|
||||||
|
|
||||||
// Create the client config. Use kubeconfig if given, otherwise assume in-cluster.
|
// Create the client config. Use kubeconfig if given, otherwise assume in-cluster.
|
||||||
config, err := buildConfig(*kubeconfig)
|
config, err := buildConfig(*kubeconfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -116,7 +120,7 @@ func main() {
|
|||||||
snapshotscheme.AddToScheme(scheme.Scheme)
|
snapshotscheme.AddToScheme(scheme.Scheme)
|
||||||
|
|
||||||
// Connect to CSI.
|
// Connect to CSI.
|
||||||
csiConn, err := connection.New(*csiAddress, *connectionTimeout)
|
csiConn, err := connection.New(*csiAddress)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
glog.Error(err.Error())
|
glog.Error(err.Error())
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
|
@@ -19,17 +19,14 @@ package connection
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
|
||||||
"strings"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/container-storage-interface/spec/lib/go/csi"
|
"github.com/container-storage-interface/spec/lib/go/csi"
|
||||||
"github.com/golang/glog"
|
"github.com/golang/glog"
|
||||||
"github.com/golang/protobuf/ptypes"
|
"github.com/golang/protobuf/ptypes"
|
||||||
"github.com/golang/protobuf/ptypes/timestamp"
|
"github.com/golang/protobuf/ptypes/timestamp"
|
||||||
|
"github.com/kubernetes-csi/csi-lib-utils/connection"
|
||||||
"github.com/kubernetes-csi/csi-lib-utils/protosanitizer"
|
"github.com/kubernetes-csi/csi-lib-utils/protosanitizer"
|
||||||
"google.golang.org/grpc"
|
"google.golang.org/grpc"
|
||||||
"google.golang.org/grpc/connectivity"
|
|
||||||
"k8s.io/api/core/v1"
|
"k8s.io/api/core/v1"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -73,8 +70,8 @@ var (
|
|||||||
)
|
)
|
||||||
|
|
||||||
// New returns a CSI connection object.
|
// New returns a CSI connection object.
|
||||||
func New(address string, timeout time.Duration) (CSIConnection, error) {
|
func New(address string) (CSIConnection, error) {
|
||||||
conn, err := connect(address, timeout)
|
conn, err := connection.Connect(address)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@@ -83,39 +80,6 @@ func New(address string, timeout time.Duration) (CSIConnection, error) {
|
|||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func connect(address string, timeout time.Duration) (*grpc.ClientConn, error) {
|
|
||||||
glog.V(2).Infof("Connecting to %s", address)
|
|
||||||
dialOptions := []grpc.DialOption{
|
|
||||||
grpc.WithInsecure(),
|
|
||||||
grpc.WithBackoffMaxDelay(time.Second),
|
|
||||||
grpc.WithUnaryInterceptor(logGRPC),
|
|
||||||
}
|
|
||||||
if strings.HasPrefix(address, "/") {
|
|
||||||
dialOptions = append(dialOptions, grpc.WithDialer(func(addr string, timeout time.Duration) (net.Conn, error) {
|
|
||||||
return net.DialTimeout("unix", addr, timeout)
|
|
||||||
}))
|
|
||||||
}
|
|
||||||
conn, err := grpc.Dial(address, dialOptions...)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
ctx, cancel := context.WithTimeout(context.Background(), timeout)
|
|
||||||
defer cancel()
|
|
||||||
for {
|
|
||||||
if !conn.WaitForStateChange(ctx, conn.GetState()) {
|
|
||||||
glog.V(4).Infof("Connection timed out")
|
|
||||||
// subsequent GetPluginInfo will show the real connection error
|
|
||||||
return conn, nil
|
|
||||||
}
|
|
||||||
if conn.GetState() == connectivity.Ready {
|
|
||||||
glog.V(3).Infof("Connected")
|
|
||||||
return conn, nil
|
|
||||||
}
|
|
||||||
glog.V(4).Infof("Still trying, connection is %s", conn.GetState())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *csiConnection) GetDriverName(ctx context.Context) (string, error) {
|
func (c *csiConnection) GetDriverName(ctx context.Context) (string, error) {
|
||||||
client := csi.NewIdentityClient(c.conn)
|
client := csi.NewIdentityClient(c.conn)
|
||||||
|
|
||||||
|
@@ -50,7 +50,7 @@ func createMockServer(t *testing.T) (*gomock.Controller, *driver.MockCSIDriver,
|
|||||||
|
|
||||||
// Create a client connection to it
|
// Create a client connection to it
|
||||||
addr := drv.Address()
|
addr := drv.Address()
|
||||||
csiConn, err := New(addr, 10)
|
csiConn, err := New(addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, nil, nil, nil, nil, err
|
return nil, nil, nil, nil, nil, err
|
||||||
}
|
}
|
||||||
|
234
vendor/github.com/googleapis/gnostic/test/library-example-with-ext.text.out
generated
vendored
Normal file
234
vendor/github.com/googleapis/gnostic/test/library-example-with-ext.text.out
generated
vendored
Normal file
@@ -0,0 +1,234 @@
|
|||||||
|
swagger: "2.0"
|
||||||
|
info: <
|
||||||
|
title: "Google Example Library API"
|
||||||
|
version: "v1"
|
||||||
|
description: "A simple Google Example Library API."
|
||||||
|
>
|
||||||
|
host: "library-example.googleapis.com"
|
||||||
|
paths: <
|
||||||
|
path: <
|
||||||
|
name: "/v1/{sharedParameter}/pets"
|
||||||
|
value: <
|
||||||
|
post: <
|
||||||
|
operation_id: "simpleMethod"
|
||||||
|
parameters: <
|
||||||
|
parameter: <
|
||||||
|
body_parameter: <
|
||||||
|
name: "myBodyRef"
|
||||||
|
in: "body"
|
||||||
|
schema: <
|
||||||
|
properties: <
|
||||||
|
additional_properties: <
|
||||||
|
name: "myStringA"
|
||||||
|
value: <
|
||||||
|
type: <
|
||||||
|
value: "string"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
parameters: <
|
||||||
|
parameter: <
|
||||||
|
non_body_parameter: <
|
||||||
|
query_parameter_sub_schema: <
|
||||||
|
required: true
|
||||||
|
in: "query"
|
||||||
|
description: "New description"
|
||||||
|
name: "paramToOverride"
|
||||||
|
type: "string"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
parameters: <
|
||||||
|
parameter: <
|
||||||
|
non_body_parameter: <
|
||||||
|
query_parameter_sub_schema: <
|
||||||
|
required: true
|
||||||
|
in: "query"
|
||||||
|
description: "test"
|
||||||
|
name: "paramAtSwaggerScope"
|
||||||
|
type: "integer"
|
||||||
|
format: "int32"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
responses: <
|
||||||
|
response_code: <
|
||||||
|
name: "default"
|
||||||
|
value: <
|
||||||
|
response: <
|
||||||
|
description: "successful operation"
|
||||||
|
schema: <
|
||||||
|
schema: <
|
||||||
|
properties: <
|
||||||
|
additional_properties: <
|
||||||
|
name: "myStringA"
|
||||||
|
value: <
|
||||||
|
type: <
|
||||||
|
value: "string"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
parameters: <
|
||||||
|
parameter: <
|
||||||
|
non_body_parameter: <
|
||||||
|
path_parameter_sub_schema: <
|
||||||
|
required: true
|
||||||
|
in: "path"
|
||||||
|
description: "Shared parameter"
|
||||||
|
name: "sharedParameter"
|
||||||
|
type: "string"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
parameters: <
|
||||||
|
parameter: <
|
||||||
|
non_body_parameter: <
|
||||||
|
query_parameter_sub_schema: <
|
||||||
|
required: true
|
||||||
|
in: "query"
|
||||||
|
description: "Description to override"
|
||||||
|
name: "paramToOverride"
|
||||||
|
type: "string"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
definitions: <
|
||||||
|
additional_properties: <
|
||||||
|
name: "SimpleDef"
|
||||||
|
value: <
|
||||||
|
properties: <
|
||||||
|
additional_properties: <
|
||||||
|
name: "myStringA"
|
||||||
|
value: <
|
||||||
|
type: <
|
||||||
|
value: "string"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
parameters: <
|
||||||
|
additional_properties: <
|
||||||
|
name: "paramAtSwaggerScope"
|
||||||
|
value: <
|
||||||
|
non_body_parameter: <
|
||||||
|
query_parameter_sub_schema: <
|
||||||
|
required: true
|
||||||
|
in: "query"
|
||||||
|
description: "test"
|
||||||
|
name: "paramAtSwaggerScope"
|
||||||
|
type: "integer"
|
||||||
|
format: "int32"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
>
|
||||||
|
vendor_extension: <
|
||||||
|
name: "x-sampleone-book"
|
||||||
|
value: <
|
||||||
|
value: <
|
||||||
|
type_url: "type.googleapis.com/sampleone.Book"
|
||||||
|
value: "\010{\020\347\007"
|
||||||
|
>
|
||||||
|
yaml: "code: 123\nmessage: 999\n"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
vendor_extension: <
|
||||||
|
name: "x-sampleone-shelf"
|
||||||
|
value: <
|
||||||
|
value: <
|
||||||
|
type_url: "type.googleapis.com/sampleone.Shelf"
|
||||||
|
value: "\010{\020\347\007"
|
||||||
|
>
|
||||||
|
yaml: "foo1: 123\nbar: 999\n"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
vendor_extension: <
|
||||||
|
name: "x-sampleone-mysimplestring"
|
||||||
|
value: <
|
||||||
|
value: <
|
||||||
|
type_url: "type.googleapis.com/google.protobuf.StringValue"
|
||||||
|
value: "\n\013hello world"
|
||||||
|
>
|
||||||
|
yaml: "hello world\n"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
vendor_extension: <
|
||||||
|
name: "x-sampleone-mysimpleint64"
|
||||||
|
value: <
|
||||||
|
value: <
|
||||||
|
type_url: "type.googleapis.com/google.protobuf.StringValue"
|
||||||
|
value: "\n\00512345"
|
||||||
|
>
|
||||||
|
yaml: "12345\n"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
vendor_extension: <
|
||||||
|
name: "x-sampleone-mysimplenumber"
|
||||||
|
value: <
|
||||||
|
value: <
|
||||||
|
type_url: "type.googleapis.com/google.protobuf.DoubleValue"
|
||||||
|
value: "\t\221\355|?5\316[@"
|
||||||
|
>
|
||||||
|
yaml: "111.222\n"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
vendor_extension: <
|
||||||
|
name: "x-sampleone-mysimpleboolean"
|
||||||
|
value: <
|
||||||
|
value: <
|
||||||
|
type_url: "type.googleapis.com/google.protobuf.BoolValue"
|
||||||
|
value: "\010\001"
|
||||||
|
>
|
||||||
|
yaml: "true\n"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
vendor_extension: <
|
||||||
|
name: "x-sampletwo-book"
|
||||||
|
value: <
|
||||||
|
value: <
|
||||||
|
type_url: "type.googleapis.com/sampletwo.Book"
|
||||||
|
value: "\010{\020\347\007"
|
||||||
|
>
|
||||||
|
yaml: "code: 123\nmessage: 999\n"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
vendor_extension: <
|
||||||
|
name: "x-sampletwo-shelf"
|
||||||
|
value: <
|
||||||
|
value: <
|
||||||
|
type_url: "type.googleapis.com/sampletwo.Shelf"
|
||||||
|
value: "\010{\020\347\007"
|
||||||
|
>
|
||||||
|
yaml: "foo1: 123\nbar: 999\n"
|
||||||
|
>
|
||||||
|
>
|
||||||
|
vendor_extension: <
|
||||||
|
name: "x-unhandled"
|
||||||
|
value: <
|
||||||
|
yaml: "code: 123\nmessage: 999\n"
|
||||||
|
>
|
||||||
|
>
|
13
vendor/github.com/googleapis/gnostic/test/v2.0/yaml/sample-petstore.out
generated
vendored
Normal file
13
vendor/github.com/googleapis/gnostic/test/v2.0/yaml/sample-petstore.out
generated
vendored
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
|
||||||
|
|
||||||
|
summary.txt --------------------
|
||||||
|
Swagger: 2.0
|
||||||
|
Host: petstore.swagger.io
|
||||||
|
BasePath: /v1
|
||||||
|
Info:
|
||||||
|
Title: Swagger Petstore
|
||||||
|
Version: 1.0.0
|
||||||
|
Paths:
|
||||||
|
GET /pets
|
||||||
|
POST /pets
|
||||||
|
GET /pets/{petId}
|
61
vendor/github.com/kubernetes-csi/csi-lib-utils/Gopkg.lock
generated
vendored
61
vendor/github.com/kubernetes-csi/csi-lib-utils/Gopkg.lock
generated
vendored
@@ -1,24 +1,16 @@
|
|||||||
# This file is autogenerated, do not edit; changes may be undone by the next 'dep ensure'.
|
# This file is autogenerated, do not edit; changes may be undone by the next 'dep ensure'.
|
||||||
|
|
||||||
|
|
||||||
[[projects]]
|
|
||||||
digest = "1:94ffc0947c337d618b6ff5ed9abaddc1217b090c1b3a1ae4739b35b7b25851d5"
|
|
||||||
name = "github.com/container-storage-interface/spec"
|
|
||||||
packages = ["lib/go/csi"]
|
|
||||||
pruneopts = "UT"
|
|
||||||
revision = "ed0bb0e1557548aa028307f48728767cfe8f6345"
|
|
||||||
version = "v1.0.0"
|
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
digest = "1:ffe9824d294da03b391f44e1ae8281281b4afc1bdaa9588c9097785e3af10cec"
|
digest = "1:ffe9824d294da03b391f44e1ae8281281b4afc1bdaa9588c9097785e3af10cec"
|
||||||
name = "github.com/davecgh/go-spew"
|
name = "github.com/davecgh/go-spew"
|
||||||
packages = ["spew"]
|
packages = ["spew"]
|
||||||
pruneopts = "UT"
|
pruneopts = "NUT"
|
||||||
revision = "8991bc29aa16c548c550c7ff78260e27b9ab7c73"
|
revision = "8991bc29aa16c548c550c7ff78260e27b9ab7c73"
|
||||||
version = "v1.1.1"
|
version = "v1.1.1"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
digest = "1:9cab16c200148edbdc9f314f69bf71987085f618ec107385bd6634be21d1aae8"
|
digest = "1:bff0ce7c8e3d6357fa5a8549bbe4bdb620bddc13c11ae569aa7248ea92e2139f"
|
||||||
name = "github.com/golang/protobuf"
|
name = "github.com/golang/protobuf"
|
||||||
packages = [
|
packages = [
|
||||||
"descriptor",
|
"descriptor",
|
||||||
@@ -30,7 +22,7 @@
|
|||||||
"ptypes/timestamp",
|
"ptypes/timestamp",
|
||||||
"ptypes/wrappers",
|
"ptypes/wrappers",
|
||||||
]
|
]
|
||||||
pruneopts = "UT"
|
pruneopts = "NUT"
|
||||||
revision = "aa810b61a9c79d51363740d207bb46cf8e620ed5"
|
revision = "aa810b61a9c79d51363740d207bb46cf8e620ed5"
|
||||||
version = "v1.2.0"
|
version = "v1.2.0"
|
||||||
|
|
||||||
@@ -38,21 +30,24 @@
|
|||||||
digest = "1:0028cb19b2e4c3112225cd871870f2d9cf49b9b4276531f03438a88e94be86fe"
|
digest = "1:0028cb19b2e4c3112225cd871870f2d9cf49b9b4276531f03438a88e94be86fe"
|
||||||
name = "github.com/pmezard/go-difflib"
|
name = "github.com/pmezard/go-difflib"
|
||||||
packages = ["difflib"]
|
packages = ["difflib"]
|
||||||
pruneopts = "UT"
|
pruneopts = "NUT"
|
||||||
revision = "792786c7400a136282c1664665ae0a8db921c6c2"
|
revision = "792786c7400a136282c1664665ae0a8db921c6c2"
|
||||||
version = "v1.0.0"
|
version = "v1.0.0"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
digest = "1:18752d0b95816a1b777505a97f71c7467a8445b8ffb55631a7bf779f6ba4fa83"
|
digest = "1:0331452965d8695c0a5633e0f509012987681a654f388f2ad0c3b2d7f7004b1c"
|
||||||
name = "github.com/stretchr/testify"
|
name = "github.com/stretchr/testify"
|
||||||
packages = ["assert"]
|
packages = [
|
||||||
pruneopts = "UT"
|
"assert",
|
||||||
|
"require",
|
||||||
|
]
|
||||||
|
pruneopts = "NUT"
|
||||||
revision = "f35b8ab0b5a2cef36673838d662e249dd9c94686"
|
revision = "f35b8ab0b5a2cef36673838d662e249dd9c94686"
|
||||||
version = "v1.2.2"
|
version = "v1.2.2"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
digest = "1:6ca51c5d8a610b3da56856df7a8f8f3e075eba8d5f7a4acbadd79b2d2a368054"
|
digest = "1:dc5dcbb306af980306fab456d4788e88c880177227bd488a92d5bef7d8743497"
|
||||||
name = "golang.org/x/net"
|
name = "golang.org/x/net"
|
||||||
packages = [
|
packages = [
|
||||||
"context",
|
"context",
|
||||||
@@ -63,19 +58,19 @@
|
|||||||
"internal/timeseries",
|
"internal/timeseries",
|
||||||
"trace",
|
"trace",
|
||||||
]
|
]
|
||||||
pruneopts = "UT"
|
pruneopts = "NUT"
|
||||||
revision = "fae4c4e3ad76c295c3d6d259f898136b4bf833a8"
|
revision = "fae4c4e3ad76c295c3d6d259f898136b4bf833a8"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
branch = "master"
|
branch = "master"
|
||||||
digest = "1:8775d8a768d9e65e8b659172804aac5db1fc8d563ba766470a6c2698c57c61a7"
|
digest = "1:134392bed1074be912a37ea13483f27e6e827f4e4d6cc319f69d3ac3617d5ac0"
|
||||||
name = "golang.org/x/sys"
|
name = "golang.org/x/sys"
|
||||||
packages = ["unix"]
|
packages = ["unix"]
|
||||||
pruneopts = "UT"
|
pruneopts = "NUT"
|
||||||
revision = "4ed8d59d0b35e1e29334a206d1b3f38b1e5dfb31"
|
revision = "4ed8d59d0b35e1e29334a206d1b3f38b1e5dfb31"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
digest = "1:a2ab62866c75542dd18d2b069fec854577a20211d7c0ea6ae746072a1dccdd18"
|
digest = "1:e7071ed636b5422cc51c0e3a6cebc229d6c9fffc528814b519a980641422d619"
|
||||||
name = "golang.org/x/text"
|
name = "golang.org/x/text"
|
||||||
packages = [
|
packages = [
|
||||||
"collate",
|
"collate",
|
||||||
@@ -93,7 +88,7 @@
|
|||||||
"unicode/norm",
|
"unicode/norm",
|
||||||
"unicode/rangetable",
|
"unicode/rangetable",
|
||||||
]
|
]
|
||||||
pruneopts = "UT"
|
pruneopts = "NUT"
|
||||||
revision = "f21a4dfb5e38f5895301dc265a8def02365cc3d0"
|
revision = "f21a4dfb5e38f5895301dc265a8def02365cc3d0"
|
||||||
version = "v0.3.0"
|
version = "v0.3.0"
|
||||||
|
|
||||||
@@ -102,11 +97,11 @@
|
|||||||
digest = "1:56b0bca90b7e5d1facf5fbdacba23e4e0ce069d25381b8e2f70ef1e7ebfb9c1a"
|
digest = "1:56b0bca90b7e5d1facf5fbdacba23e4e0ce069d25381b8e2f70ef1e7ebfb9c1a"
|
||||||
name = "google.golang.org/genproto"
|
name = "google.golang.org/genproto"
|
||||||
packages = ["googleapis/rpc/status"]
|
packages = ["googleapis/rpc/status"]
|
||||||
pruneopts = "UT"
|
pruneopts = "NUT"
|
||||||
revision = "31ac5d88444a9e7ad18077db9a165d793ad06a2e"
|
revision = "31ac5d88444a9e7ad18077db9a165d793ad06a2e"
|
||||||
|
|
||||||
[[projects]]
|
[[projects]]
|
||||||
digest = "1:c3ad9841823db6da420a5625b367913b4ff54bbe60e8e3c98bd20e243e62e2d2"
|
digest = "1:2f91d3e11b666570f8c923912f1cc8cf2f0c6b7371b2687ee67a8f73f08c6272"
|
||||||
name = "google.golang.org/grpc"
|
name = "google.golang.org/grpc"
|
||||||
packages = [
|
packages = [
|
||||||
".",
|
".",
|
||||||
@@ -136,19 +131,35 @@
|
|||||||
"status",
|
"status",
|
||||||
"tap",
|
"tap",
|
||||||
]
|
]
|
||||||
pruneopts = "UT"
|
pruneopts = "NUT"
|
||||||
revision = "2e463a05d100327ca47ac218281906921038fd95"
|
revision = "2e463a05d100327ca47ac218281906921038fd95"
|
||||||
version = "v1.16.0"
|
version = "v1.16.0"
|
||||||
|
|
||||||
|
[[projects]]
|
||||||
|
digest = "1:9cc257b3c9ff6a0158c9c661ab6eebda1fe8a4a4453cd5c4044dc9a2ebfb992b"
|
||||||
|
name = "k8s.io/klog"
|
||||||
|
packages = ["."]
|
||||||
|
pruneopts = "NUT"
|
||||||
|
revision = "a5bc97fbc634d635061f3146511332c7e313a55a"
|
||||||
|
version = "v0.1.0"
|
||||||
|
|
||||||
[solve-meta]
|
[solve-meta]
|
||||||
analyzer-name = "dep"
|
analyzer-name = "dep"
|
||||||
analyzer-version = 1
|
analyzer-version = 1
|
||||||
input-imports = [
|
input-imports = [
|
||||||
"github.com/container-storage-interface/spec/lib/go/csi",
|
|
||||||
"github.com/golang/protobuf/descriptor",
|
"github.com/golang/protobuf/descriptor",
|
||||||
"github.com/golang/protobuf/proto",
|
"github.com/golang/protobuf/proto",
|
||||||
"github.com/golang/protobuf/protoc-gen-go/descriptor",
|
"github.com/golang/protobuf/protoc-gen-go/descriptor",
|
||||||
|
"github.com/golang/protobuf/ptypes/timestamp",
|
||||||
|
"github.com/golang/protobuf/ptypes/wrappers",
|
||||||
"github.com/stretchr/testify/assert",
|
"github.com/stretchr/testify/assert",
|
||||||
|
"github.com/stretchr/testify/require",
|
||||||
|
"golang.org/x/net/context",
|
||||||
|
"google.golang.org/grpc",
|
||||||
|
"google.golang.org/grpc/codes",
|
||||||
|
"google.golang.org/grpc/connectivity",
|
||||||
|
"google.golang.org/grpc/status",
|
||||||
|
"k8s.io/klog",
|
||||||
]
|
]
|
||||||
solver-name = "gps-cdcl"
|
solver-name = "gps-cdcl"
|
||||||
solver-version = 1
|
solver-version = 1
|
||||||
|
1
vendor/github.com/kubernetes-csi/csi-lib-utils/Gopkg.toml
generated
vendored
1
vendor/github.com/kubernetes-csi/csi-lib-utils/Gopkg.toml
generated
vendored
@@ -3,4 +3,5 @@
|
|||||||
|
|
||||||
[prune]
|
[prune]
|
||||||
go-tests = true
|
go-tests = true
|
||||||
|
non-go = true
|
||||||
unused-packages = true
|
unused-packages = true
|
||||||
|
21
vendor/github.com/kubernetes-csi/csi-lib-utils/Makefile
generated
vendored
21
vendor/github.com/kubernetes-csi/csi-lib-utils/Makefile
generated
vendored
@@ -12,24 +12,9 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
.PHONY: all clean test
|
# No individual commands at the moment, just packages.
|
||||||
|
CMDS=
|
||||||
ifdef V
|
|
||||||
TESTARGS = -v
|
|
||||||
else
|
|
||||||
TESTARGS =
|
|
||||||
endif
|
|
||||||
|
|
||||||
all:
|
all:
|
||||||
go build `go list ./... | grep -v 'vendor'`
|
go build `go list ./... | grep -v 'vendor'`
|
||||||
|
|
||||||
clean:
|
include release-tools/build.make
|
||||||
true
|
|
||||||
|
|
||||||
test:
|
|
||||||
go test `go list ./... | grep -v ^vendor` $(TESTARGS)
|
|
||||||
go vet `go list ./... | grep -v ^vendor`
|
|
||||||
diff="$$(gofmt -d $$(find . -name '*.go' | grep -v ^./vendor))" && \
|
|
||||||
( [ -z "$$diff" ] || ( \
|
|
||||||
echo "\nvvvvvv formatting errors, fix with patch -p1 vvvvvvvvvv\n$$diff\n^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n"; \
|
|
||||||
false ) )
|
|
||||||
|
3
vendor/github.com/kubernetes-csi/csi-lib-utils/OWNERS
generated
vendored
3
vendor/github.com/kubernetes-csi/csi-lib-utils/OWNERS
generated
vendored
@@ -2,3 +2,6 @@
|
|||||||
|
|
||||||
approvers:
|
approvers:
|
||||||
- saad-ali
|
- saad-ali
|
||||||
|
- jsafrane
|
||||||
|
- msau42
|
||||||
|
- pohly
|
||||||
|
162
vendor/github.com/kubernetes-csi/csi-lib-utils/connection/connection.go
generated
vendored
Normal file
162
vendor/github.com/kubernetes-csi/csi-lib-utils/connection/connection.go
generated
vendored
Normal file
@@ -0,0 +1,162 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2019 The Kubernetes Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package connection
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"errors"
|
||||||
|
"net"
|
||||||
|
"strings"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/kubernetes-csi/csi-lib-utils/protosanitizer"
|
||||||
|
"google.golang.org/grpc"
|
||||||
|
"k8s.io/klog"
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
// Interval of logging connection errors
|
||||||
|
connectionLoggingInterval = 10 * time.Second
|
||||||
|
)
|
||||||
|
|
||||||
|
// Connect opens insecure gRPC connection to a CSI driver. Address must be either absolute path to UNIX domain socket
|
||||||
|
// file or have format '<protocol>://', following gRPC name resolution mechanism at
|
||||||
|
// https://github.com/grpc/grpc/blob/master/doc/naming.md.
|
||||||
|
//
|
||||||
|
// The function tries to connect indefinitely every second until it connects. The function automatically disables TLS
|
||||||
|
// and adds interceptor for logging of all gRPC messages at level 5.
|
||||||
|
//
|
||||||
|
// For a connection to a Unix Domain socket, the behavior after
|
||||||
|
// loosing the connection is configurable. The default is to
|
||||||
|
// log the connection loss and reestablish a connection. Applications
|
||||||
|
// which need to know about a connection loss can be notified by
|
||||||
|
// passing a callback with OnConnectionLoss and in that callback
|
||||||
|
// can decide what to do:
|
||||||
|
// - exit the application with os.Exit
|
||||||
|
// - invalidate cached information
|
||||||
|
// - disable the reconnect, which will cause all gRPC method calls to fail with status.Unavailable
|
||||||
|
//
|
||||||
|
// For other connections, the default behavior from gRPC is used and
|
||||||
|
// loss of connection is not detected reliably.
|
||||||
|
func Connect(address string, options ...Option) (*grpc.ClientConn, error) {
|
||||||
|
return connect(address, []grpc.DialOption{}, options)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Option is the type of all optional parameters for Connect.
|
||||||
|
type Option func(o *options)
|
||||||
|
|
||||||
|
// OnConnectionLoss registers a callback that will be invoked when the
|
||||||
|
// connection got lost. If that callback returns true, the connection
|
||||||
|
// is restablished. Otherwise the connection is left as it is and
|
||||||
|
// all future gRPC calls using it will fail with status.Unavailable.
|
||||||
|
func OnConnectionLoss(reconnect func() bool) Option {
|
||||||
|
return func(o *options) {
|
||||||
|
o.reconnect = reconnect
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type options struct {
|
||||||
|
reconnect func() bool
|
||||||
|
}
|
||||||
|
|
||||||
|
// connect is the internal implementation of Connect. It has more options to enable testing.
|
||||||
|
func connect(address string, dialOptions []grpc.DialOption, connectOptions []Option) (*grpc.ClientConn, error) {
|
||||||
|
var o options
|
||||||
|
for _, option := range connectOptions {
|
||||||
|
option(&o)
|
||||||
|
}
|
||||||
|
|
||||||
|
dialOptions = append(dialOptions,
|
||||||
|
grpc.WithInsecure(), // Don't use TLS, it's usually local Unix domain socket in a container.
|
||||||
|
grpc.WithBackoffMaxDelay(time.Second), // Retry every second after failure.
|
||||||
|
grpc.WithBlock(), // Block until connection succeeds.
|
||||||
|
grpc.WithUnaryInterceptor(LogGRPC), // Log all messages.
|
||||||
|
)
|
||||||
|
unixPrefix := "unix://"
|
||||||
|
if strings.HasPrefix(address, "/") {
|
||||||
|
// It looks like filesystem path.
|
||||||
|
address = unixPrefix + address
|
||||||
|
}
|
||||||
|
|
||||||
|
if strings.HasPrefix(address, unixPrefix) {
|
||||||
|
// state variables for the custom dialer
|
||||||
|
haveConnected := false
|
||||||
|
lostConnection := false
|
||||||
|
reconnect := true
|
||||||
|
|
||||||
|
dialOptions = append(dialOptions, grpc.WithDialer(func(addr string, timeout time.Duration) (net.Conn, error) {
|
||||||
|
if haveConnected && !lostConnection {
|
||||||
|
// We have detected a loss of connection for the first time. Decide what to do...
|
||||||
|
// Record this once. TODO (?): log at regular time intervals.
|
||||||
|
klog.Errorf("Lost connection to %s.", address)
|
||||||
|
// Inform caller and let it decide? Default is to reconnect.
|
||||||
|
if o.reconnect != nil {
|
||||||
|
reconnect = o.reconnect()
|
||||||
|
}
|
||||||
|
lostConnection = true
|
||||||
|
}
|
||||||
|
if !reconnect {
|
||||||
|
return nil, errors.New("connection lost, reconnecting disabled")
|
||||||
|
}
|
||||||
|
conn, err := net.DialTimeout("unix", address[len(unixPrefix):], timeout)
|
||||||
|
if err == nil {
|
||||||
|
// Connection restablished.
|
||||||
|
haveConnected = true
|
||||||
|
lostConnection = false
|
||||||
|
}
|
||||||
|
return conn, err
|
||||||
|
}))
|
||||||
|
} else if o.reconnect != nil {
|
||||||
|
return nil, errors.New("OnConnectionLoss callback only supported for unix:// addresses")
|
||||||
|
}
|
||||||
|
|
||||||
|
klog.Infof("Connecting to %s", address)
|
||||||
|
|
||||||
|
// Connect in background.
|
||||||
|
var conn *grpc.ClientConn
|
||||||
|
var err error
|
||||||
|
ready := make(chan bool)
|
||||||
|
go func() {
|
||||||
|
conn, err = grpc.Dial(address, dialOptions...)
|
||||||
|
close(ready)
|
||||||
|
}()
|
||||||
|
|
||||||
|
// Log error every connectionLoggingInterval
|
||||||
|
ticker := time.NewTicker(connectionLoggingInterval)
|
||||||
|
defer ticker.Stop()
|
||||||
|
|
||||||
|
// Wait until Dial() succeeds.
|
||||||
|
for {
|
||||||
|
select {
|
||||||
|
case <-ticker.C:
|
||||||
|
klog.Warningf("Still connecting to %s", address)
|
||||||
|
|
||||||
|
case <-ready:
|
||||||
|
return conn, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// LogGRPC is gPRC unary interceptor for logging of CSI messages at level 5. It removes any secrets from the message.
|
||||||
|
func LogGRPC(ctx context.Context, method string, req, reply interface{}, cc *grpc.ClientConn, invoker grpc.UnaryInvoker, opts ...grpc.CallOption) error {
|
||||||
|
klog.V(5).Infof("GRPC call: %s", method)
|
||||||
|
klog.V(5).Infof("GRPC request: %s", protosanitizer.StripSecrets(req))
|
||||||
|
err := invoker(ctx, method, req, reply, cc, opts...)
|
||||||
|
klog.V(5).Infof("GRPC response: %s", protosanitizer.StripSecrets(reply))
|
||||||
|
klog.V(5).Infof("GRPC error: %v", err)
|
||||||
|
return err
|
||||||
|
}
|
308
vendor/github.com/kubernetes-csi/csi-lib-utils/connection/connection_test.go
generated
vendored
Normal file
308
vendor/github.com/kubernetes-csi/csi-lib-utils/connection/connection_test.go
generated
vendored
Normal file
@@ -0,0 +1,308 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2019 The Kubernetes Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package connection
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"io/ioutil"
|
||||||
|
"net"
|
||||||
|
"os"
|
||||||
|
"path"
|
||||||
|
"sync"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"google.golang.org/grpc"
|
||||||
|
"google.golang.org/grpc/codes"
|
||||||
|
"google.golang.org/grpc/connectivity"
|
||||||
|
"google.golang.org/grpc/status"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
)
|
||||||
|
|
||||||
|
func tmpDir(t *testing.T) string {
|
||||||
|
dir, err := ioutil.TempDir("", "connect")
|
||||||
|
require.NoError(t, err, "creating temp directory")
|
||||||
|
return dir
|
||||||
|
}
|
||||||
|
|
||||||
|
const (
|
||||||
|
serverSock = "server.sock"
|
||||||
|
)
|
||||||
|
|
||||||
|
// startServer creates a gRPC server without any registered services.
|
||||||
|
// The returned address can be used to connect to it. The cleanup
|
||||||
|
// function stops it. It can be called multiple times.
|
||||||
|
func startServer(t *testing.T, tmp string) (string, func()) {
|
||||||
|
addr := path.Join(tmp, serverSock)
|
||||||
|
listener, err := net.Listen("unix", addr)
|
||||||
|
require.NoError(t, err, "listening on %s", addr)
|
||||||
|
server := grpc.NewServer()
|
||||||
|
var wg sync.WaitGroup
|
||||||
|
wg.Add(1)
|
||||||
|
go func() {
|
||||||
|
defer wg.Done()
|
||||||
|
if err := server.Serve(listener); err != nil {
|
||||||
|
t.Logf("starting server failed: %s", err)
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
return addr, func() {
|
||||||
|
server.Stop()
|
||||||
|
wg.Wait()
|
||||||
|
if err := os.Remove(addr); err != nil && !os.IsNotExist(err) {
|
||||||
|
t.Logf("remove Unix socket: %s", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConnect(t *testing.T) {
|
||||||
|
tmp := tmpDir(t)
|
||||||
|
defer os.RemoveAll(tmp)
|
||||||
|
addr, stopServer := startServer(t, tmp)
|
||||||
|
defer stopServer()
|
||||||
|
|
||||||
|
conn, err := Connect(addr)
|
||||||
|
if assert.NoError(t, err, "connect via absolute path") &&
|
||||||
|
assert.NotNil(t, conn, "got a connection") {
|
||||||
|
assert.Equal(t, connectivity.Ready, conn.GetState(), "connection ready")
|
||||||
|
err = conn.Close()
|
||||||
|
assert.NoError(t, err, "closing connection")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConnectUnix(t *testing.T) {
|
||||||
|
tmp := tmpDir(t)
|
||||||
|
defer os.RemoveAll(tmp)
|
||||||
|
addr, stopServer := startServer(t, tmp)
|
||||||
|
defer stopServer()
|
||||||
|
|
||||||
|
conn, err := Connect("unix:///" + addr)
|
||||||
|
if assert.NoError(t, err, "connect with unix:/// prefix") &&
|
||||||
|
assert.NotNil(t, conn, "got a connection") {
|
||||||
|
assert.Equal(t, connectivity.Ready, conn.GetState(), "connection ready")
|
||||||
|
err = conn.Close()
|
||||||
|
assert.NoError(t, err, "closing connection")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestWaitForServer(t *testing.T) {
|
||||||
|
tmp := tmpDir(t)
|
||||||
|
defer os.RemoveAll(tmp)
|
||||||
|
|
||||||
|
// We cannot test that Connect() waits forever for the server
|
||||||
|
// to appear, because then we would have to let the test run
|
||||||
|
// forever.... What we can test is that it returns shortly
|
||||||
|
// after the server appears.
|
||||||
|
startTime := time.Now()
|
||||||
|
var startTimeServer time.Time
|
||||||
|
var stopServer func()
|
||||||
|
var wg sync.WaitGroup
|
||||||
|
wg.Add(1)
|
||||||
|
defer func() {
|
||||||
|
wg.Wait()
|
||||||
|
stopServer()
|
||||||
|
}()
|
||||||
|
// Here we pick a relatively long delay before we start the
|
||||||
|
// server. If gRPC did go into an exponential backoff before
|
||||||
|
// retrying the connection attempt, then it probably would
|
||||||
|
// not react promptly to the server becoming ready. Currently
|
||||||
|
// it looks like gRPC tries to connect once per second, with
|
||||||
|
// no exponential backoff.
|
||||||
|
delay := 10 * time.Second
|
||||||
|
go func() {
|
||||||
|
defer wg.Done()
|
||||||
|
t.Logf("sleeping %s before starting server", delay)
|
||||||
|
time.Sleep(delay)
|
||||||
|
startTimeServer = time.Now()
|
||||||
|
_, stopServer = startServer(t, tmp)
|
||||||
|
}()
|
||||||
|
conn, err := Connect(path.Join(tmp, serverSock))
|
||||||
|
if assert.NoError(t, err, "connect via absolute path") {
|
||||||
|
endTime := time.Now()
|
||||||
|
assert.NotNil(t, conn, "got a connection")
|
||||||
|
assert.Equal(t, connectivity.Ready.String(), conn.GetState().String(), "connection ready")
|
||||||
|
if assert.InEpsilon(t, 1*time.Second, endTime.Sub(startTimeServer), 5, "connection established shortly after server starts") {
|
||||||
|
assert.InEpsilon(t, delay, endTime.Sub(startTime), 1)
|
||||||
|
}
|
||||||
|
err = conn.Close()
|
||||||
|
assert.NoError(t, err, "closing connection")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestTimout(t *testing.T) {
|
||||||
|
tmp := tmpDir(t)
|
||||||
|
defer os.RemoveAll(tmp)
|
||||||
|
|
||||||
|
startTime := time.Now()
|
||||||
|
timeout := 5 * time.Second
|
||||||
|
conn, err := connect(path.Join(tmp, "no-such.sock"), []grpc.DialOption{grpc.WithTimeout(timeout)}, nil)
|
||||||
|
endTime := time.Now()
|
||||||
|
if assert.Error(t, err, "connection should fail") {
|
||||||
|
assert.InEpsilon(t, timeout, endTime.Sub(startTime), 1, "connection timeout")
|
||||||
|
} else {
|
||||||
|
err := conn.Close()
|
||||||
|
assert.NoError(t, err, "closing connection")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestReconnect(t *testing.T) {
|
||||||
|
tmp := tmpDir(t)
|
||||||
|
defer os.RemoveAll(tmp)
|
||||||
|
addr, stopServer := startServer(t, tmp)
|
||||||
|
defer func() {
|
||||||
|
stopServer()
|
||||||
|
}()
|
||||||
|
|
||||||
|
// Allow reconnection (the default).
|
||||||
|
conn, err := Connect(addr)
|
||||||
|
if assert.NoError(t, err, "connect via absolute path") &&
|
||||||
|
assert.NotNil(t, conn, "got a connection") {
|
||||||
|
defer conn.Close()
|
||||||
|
assert.Equal(t, connectivity.Ready, conn.GetState(), "connection ready")
|
||||||
|
|
||||||
|
if err := conn.Invoke(context.Background(), "/connect.v0.Test/Ping", nil, nil); assert.Error(t, err) {
|
||||||
|
errStatus, _ := status.FromError(err)
|
||||||
|
assert.Equal(t, codes.Unimplemented, errStatus.Code(), "not implemented")
|
||||||
|
}
|
||||||
|
|
||||||
|
stopServer()
|
||||||
|
startTime := time.Now()
|
||||||
|
if err := conn.Invoke(context.Background(), "/connect.v0.Test/Ping", nil, nil); assert.Error(t, err) {
|
||||||
|
endTime := time.Now()
|
||||||
|
errStatus, _ := status.FromError(err)
|
||||||
|
assert.Equal(t, codes.Unavailable, errStatus.Code(), "connection lost")
|
||||||
|
assert.InEpsilon(t, time.Second, endTime.Sub(startTime), 1, "connection loss should be detected quickly")
|
||||||
|
}
|
||||||
|
|
||||||
|
// No reconnection either when the server comes back.
|
||||||
|
_, stopServer = startServer(t, tmp)
|
||||||
|
// We need to give gRPC some time. It does not attempt to reconnect
|
||||||
|
// immediately. If we send the method call too soon, the test passes
|
||||||
|
// even though a later method call will go through again.
|
||||||
|
time.Sleep(5 * time.Second)
|
||||||
|
startTime = time.Now()
|
||||||
|
if err := conn.Invoke(context.Background(), "/connect.v0.Test/Ping", nil, nil); assert.Error(t, err) {
|
||||||
|
endTime := time.Now()
|
||||||
|
errStatus, _ := status.FromError(err)
|
||||||
|
assert.Equal(t, codes.Unimplemented, errStatus.Code(), "not implemented")
|
||||||
|
assert.InEpsilon(t, time.Second, endTime.Sub(startTime), 1, "connection loss should be covered from quickly")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestDisconnect(t *testing.T) {
|
||||||
|
tmp := tmpDir(t)
|
||||||
|
defer os.RemoveAll(tmp)
|
||||||
|
addr, stopServer := startServer(t, tmp)
|
||||||
|
defer func() {
|
||||||
|
stopServer()
|
||||||
|
}()
|
||||||
|
|
||||||
|
reconnectCount := 0
|
||||||
|
conn, err := Connect(addr, OnConnectionLoss(func() bool {
|
||||||
|
reconnectCount++
|
||||||
|
// Don't reconnect.
|
||||||
|
return false
|
||||||
|
}))
|
||||||
|
if assert.NoError(t, err, "connect via absolute path") &&
|
||||||
|
assert.NotNil(t, conn, "got a connection") {
|
||||||
|
defer conn.Close()
|
||||||
|
assert.Equal(t, connectivity.Ready, conn.GetState(), "connection ready")
|
||||||
|
|
||||||
|
if err := conn.Invoke(context.Background(), "/connect.v0.Test/Ping", nil, nil); assert.Error(t, err) {
|
||||||
|
errStatus, _ := status.FromError(err)
|
||||||
|
assert.Equal(t, codes.Unimplemented, errStatus.Code(), "not implemented")
|
||||||
|
}
|
||||||
|
|
||||||
|
stopServer()
|
||||||
|
startTime := time.Now()
|
||||||
|
if err := conn.Invoke(context.Background(), "/connect.v0.Test/Ping", nil, nil); assert.Error(t, err) {
|
||||||
|
endTime := time.Now()
|
||||||
|
errStatus, _ := status.FromError(err)
|
||||||
|
assert.Equal(t, codes.Unavailable, errStatus.Code(), "connection lost")
|
||||||
|
assert.InEpsilon(t, time.Second, endTime.Sub(startTime), 1, "connection loss should be detected quickly")
|
||||||
|
}
|
||||||
|
|
||||||
|
// No reconnection either when the server comes back.
|
||||||
|
_, stopServer = startServer(t, tmp)
|
||||||
|
// We need to give gRPC some time. It does not attempt to reconnect
|
||||||
|
// immediately. If we send the method call too soon, the test passes
|
||||||
|
// even though a later method call will go through again.
|
||||||
|
time.Sleep(5 * time.Second)
|
||||||
|
startTime = time.Now()
|
||||||
|
if err := conn.Invoke(context.Background(), "/connect.v0.Test/Ping", nil, nil); assert.Error(t, err) {
|
||||||
|
endTime := time.Now()
|
||||||
|
errStatus, _ := status.FromError(err)
|
||||||
|
assert.Equal(t, codes.Unavailable, errStatus.Code(), "connection still lost")
|
||||||
|
assert.InEpsilon(t, time.Second, endTime.Sub(startTime), 1, "connection loss should be detected quickly")
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.Equal(t, 1, reconnectCount, "connection loss callback should be called once")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestExplicitReconnect(t *testing.T) {
|
||||||
|
tmp := tmpDir(t)
|
||||||
|
defer os.RemoveAll(tmp)
|
||||||
|
addr, stopServer := startServer(t, tmp)
|
||||||
|
defer func() {
|
||||||
|
stopServer()
|
||||||
|
}()
|
||||||
|
|
||||||
|
reconnectCount := 0
|
||||||
|
conn, err := Connect(addr, OnConnectionLoss(func() bool {
|
||||||
|
reconnectCount++
|
||||||
|
// Reconnect.
|
||||||
|
return true
|
||||||
|
}))
|
||||||
|
if assert.NoError(t, err, "connect via absolute path") &&
|
||||||
|
assert.NotNil(t, conn, "got a connection") {
|
||||||
|
defer conn.Close()
|
||||||
|
assert.Equal(t, connectivity.Ready, conn.GetState(), "connection ready")
|
||||||
|
|
||||||
|
if err := conn.Invoke(context.Background(), "/connect.v0.Test/Ping", nil, nil); assert.Error(t, err) {
|
||||||
|
errStatus, _ := status.FromError(err)
|
||||||
|
assert.Equal(t, codes.Unimplemented, errStatus.Code(), "not implemented")
|
||||||
|
}
|
||||||
|
|
||||||
|
stopServer()
|
||||||
|
startTime := time.Now()
|
||||||
|
if err := conn.Invoke(context.Background(), "/connect.v0.Test/Ping", nil, nil); assert.Error(t, err) {
|
||||||
|
endTime := time.Now()
|
||||||
|
errStatus, _ := status.FromError(err)
|
||||||
|
assert.Equal(t, codes.Unavailable, errStatus.Code(), "connection lost")
|
||||||
|
assert.InEpsilon(t, time.Second, endTime.Sub(startTime), 1, "connection loss should be detected quickly")
|
||||||
|
}
|
||||||
|
|
||||||
|
// No reconnection either when the server comes back.
|
||||||
|
_, stopServer = startServer(t, tmp)
|
||||||
|
// We need to give gRPC some time. It does not attempt to reconnect
|
||||||
|
// immediately. If we send the method call too soon, the test passes
|
||||||
|
// even though a later method call will go through again.
|
||||||
|
time.Sleep(5 * time.Second)
|
||||||
|
startTime = time.Now()
|
||||||
|
if err := conn.Invoke(context.Background(), "/connect.v0.Test/Ping", nil, nil); assert.Error(t, err) {
|
||||||
|
endTime := time.Now()
|
||||||
|
errStatus, _ := status.FromError(err)
|
||||||
|
assert.Equal(t, codes.Unimplemented, errStatus.Code(), "connection still lost")
|
||||||
|
assert.InEpsilon(t, time.Second, endTime.Sub(startTime), 1, "connection loss should be recovered from quickly")
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.Equal(t, 1, reconnectCount, "connection loss callback should be called once")
|
||||||
|
}
|
||||||
|
}
|
55
vendor/github.com/kubernetes-csi/csi-lib-utils/protosanitizer/protosanitizer.go
generated
vendored
55
vendor/github.com/kubernetes-csi/csi-lib-utils/protosanitizer/protosanitizer.go
generated
vendored
@@ -24,10 +24,10 @@ import (
|
|||||||
"reflect"
|
"reflect"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/container-storage-interface/spec/lib/go/csi"
|
|
||||||
"github.com/golang/protobuf/descriptor"
|
"github.com/golang/protobuf/descriptor"
|
||||||
"github.com/golang/protobuf/proto"
|
"github.com/golang/protobuf/proto"
|
||||||
protobuf "github.com/golang/protobuf/protoc-gen-go/descriptor"
|
protobuf "github.com/golang/protobuf/protoc-gen-go/descriptor"
|
||||||
|
protobufdescriptor "github.com/golang/protobuf/protoc-gen-go/descriptor"
|
||||||
)
|
)
|
||||||
|
|
||||||
// StripSecrets returns a wrapper around the original CSI gRPC message
|
// StripSecrets returns a wrapper around the original CSI gRPC message
|
||||||
@@ -36,15 +36,27 @@ import (
|
|||||||
// Instead of the secret value(s), the string "***stripped***" is
|
// Instead of the secret value(s), the string "***stripped***" is
|
||||||
// included in the result.
|
// included in the result.
|
||||||
//
|
//
|
||||||
|
// StripSecrets relies on an extension in CSI 1.0 and thus can only
|
||||||
|
// be used for messages based on that or a more recent spec!
|
||||||
|
//
|
||||||
// StripSecrets itself is fast and therefore it is cheap to pass the
|
// StripSecrets itself is fast and therefore it is cheap to pass the
|
||||||
// result to logging functions which may or may not end up serializing
|
// result to logging functions which may or may not end up serializing
|
||||||
// the parameter depending on the current log level.
|
// the parameter depending on the current log level.
|
||||||
func StripSecrets(msg interface{}) fmt.Stringer {
|
func StripSecrets(msg interface{}) fmt.Stringer {
|
||||||
return &stripSecrets{msg}
|
return &stripSecrets{msg, isCSI1Secret}
|
||||||
|
}
|
||||||
|
|
||||||
|
// StripSecretsCSI03 is like StripSecrets, except that it works
|
||||||
|
// for messages based on CSI 0.3 and older. It does not work
|
||||||
|
// for CSI 1.0, use StripSecrets for that.
|
||||||
|
func StripSecretsCSI03(msg interface{}) fmt.Stringer {
|
||||||
|
return &stripSecrets{msg, isCSI03Secret}
|
||||||
}
|
}
|
||||||
|
|
||||||
type stripSecrets struct {
|
type stripSecrets struct {
|
||||||
msg interface{}
|
msg interface{}
|
||||||
|
|
||||||
|
isSecretField func(field *protobuf.FieldDescriptorProto) bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *stripSecrets) String() string {
|
func (s *stripSecrets) String() string {
|
||||||
@@ -60,7 +72,7 @@ func (s *stripSecrets) String() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Now remove secrets from the generic representation of the message.
|
// Now remove secrets from the generic representation of the message.
|
||||||
strip(parsed, s.msg)
|
s.strip(parsed, s.msg)
|
||||||
|
|
||||||
// Re-encoded the stripped representation and return that.
|
// Re-encoded the stripped representation and return that.
|
||||||
b, err = json.Marshal(parsed)
|
b, err = json.Marshal(parsed)
|
||||||
@@ -70,7 +82,7 @@ func (s *stripSecrets) String() string {
|
|||||||
return string(b)
|
return string(b)
|
||||||
}
|
}
|
||||||
|
|
||||||
func strip(parsed interface{}, msg interface{}) {
|
func (s *stripSecrets) strip(parsed interface{}, msg interface{}) {
|
||||||
protobufMsg, ok := msg.(descriptor.Message)
|
protobufMsg, ok := msg.(descriptor.Message)
|
||||||
if !ok {
|
if !ok {
|
||||||
// Not a protobuf message, so we are done.
|
// Not a protobuf message, so we are done.
|
||||||
@@ -93,8 +105,7 @@ func strip(parsed interface{}, msg interface{}) {
|
|||||||
fields := md.GetField()
|
fields := md.GetField()
|
||||||
if fields != nil {
|
if fields != nil {
|
||||||
for _, field := range fields {
|
for _, field := range fields {
|
||||||
ex, err := proto.GetExtension(field.Options, csi.E_CsiSecret)
|
if s.isSecretField(field) {
|
||||||
if err == nil && ex != nil && *ex.(*bool) {
|
|
||||||
// Overwrite only if already set.
|
// Overwrite only if already set.
|
||||||
if _, ok := parsedFields[field.GetName()]; ok {
|
if _, ok := parsedFields[field.GetName()]; ok {
|
||||||
parsedFields[field.GetName()] = "***stripped***"
|
parsedFields[field.GetName()] = "***stripped***"
|
||||||
@@ -126,13 +137,41 @@ func strip(parsed interface{}, msg interface{}) {
|
|||||||
if slice, ok := entry.([]interface{}); ok {
|
if slice, ok := entry.([]interface{}); ok {
|
||||||
// Array of values, like VolumeCapabilities in CreateVolumeRequest.
|
// Array of values, like VolumeCapabilities in CreateVolumeRequest.
|
||||||
for _, entry := range slice {
|
for _, entry := range slice {
|
||||||
strip(entry, i)
|
s.strip(entry, i)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Single value.
|
// Single value.
|
||||||
strip(entry, i)
|
s.strip(entry, i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// isCSI1Secret uses the csi.E_CsiSecret extension from CSI 1.0 to
|
||||||
|
// determine whether a field contains secrets.
|
||||||
|
func isCSI1Secret(field *protobuf.FieldDescriptorProto) bool {
|
||||||
|
ex, err := proto.GetExtension(field.Options, e_CsiSecret)
|
||||||
|
return err == nil && ex != nil && *ex.(*bool)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Copied from the CSI 1.0 spec (https://github.com/container-storage-interface/spec/blob/37e74064635d27c8e33537c863b37ccb1182d4f8/lib/go/csi/csi.pb.go#L4520-L4527)
|
||||||
|
// to avoid a package dependency that would prevent usage of this package
|
||||||
|
// in repos using an older version of the spec.
|
||||||
|
//
|
||||||
|
// Future revision of the CSI spec must not change this extensions, otherwise
|
||||||
|
// they will break filtering in binaries based on the 1.0 version of the spec.
|
||||||
|
var e_CsiSecret = &proto.ExtensionDesc{
|
||||||
|
ExtendedType: (*protobufdescriptor.FieldOptions)(nil),
|
||||||
|
ExtensionType: (*bool)(nil),
|
||||||
|
Field: 1059,
|
||||||
|
Name: "csi.v1.csi_secret",
|
||||||
|
Tag: "varint,1059,opt,name=csi_secret,json=csiSecret",
|
||||||
|
Filename: "github.com/container-storage-interface/spec/csi.proto",
|
||||||
|
}
|
||||||
|
|
||||||
|
// isCSI03Secret relies on the naming convention in CSI <= 0.3
|
||||||
|
// to determine whether a field contains secrets.
|
||||||
|
func isCSI03Secret(field *protobuf.FieldDescriptorProto) bool {
|
||||||
|
return strings.HasSuffix(field.GetName(), "_secrets")
|
||||||
|
}
|
||||||
|
148
vendor/github.com/kubernetes-csi/csi-lib-utils/protosanitizer/protosanitizer_test.go
generated
vendored
148
vendor/github.com/kubernetes-csi/csi-lib-utils/protosanitizer/protosanitizer_test.go
generated
vendored
@@ -20,7 +20,9 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/container-storage-interface/spec/lib/go/csi"
|
"github.com/golang/protobuf/proto"
|
||||||
|
csi03 "github.com/kubernetes-csi/csi-lib-utils/protosanitizer/test/csi03"
|
||||||
|
csi "github.com/kubernetes-csi/csi-lib-utils/protosanitizer/test/csi10"
|
||||||
"github.com/kubernetes-csi/csi-lib-utils/protosanitizer/test/csitest"
|
"github.com/kubernetes-csi/csi-lib-utils/protosanitizer/test/csitest"
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
@@ -28,6 +30,44 @@ import (
|
|||||||
func TestStripSecrets(t *testing.T) {
|
func TestStripSecrets(t *testing.T) {
|
||||||
secretName := "secret-abc"
|
secretName := "secret-abc"
|
||||||
secretValue := "123"
|
secretValue := "123"
|
||||||
|
|
||||||
|
// CSI 0.3.0.
|
||||||
|
createVolumeCSI03 := &csi03.CreateVolumeRequest{
|
||||||
|
AccessibilityRequirements: &csi03.TopologyRequirement{
|
||||||
|
Requisite: []*csi03.Topology{
|
||||||
|
&csi03.Topology{
|
||||||
|
Segments: map[string]string{
|
||||||
|
"foo": "bar",
|
||||||
|
"x": "y",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
&csi03.Topology{
|
||||||
|
Segments: map[string]string{
|
||||||
|
"a": "b",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Name: "foo",
|
||||||
|
VolumeCapabilities: []*csi03.VolumeCapability{
|
||||||
|
&csi03.VolumeCapability{
|
||||||
|
AccessType: &csi03.VolumeCapability_Mount{
|
||||||
|
Mount: &csi03.VolumeCapability_MountVolume{
|
||||||
|
FsType: "ext4",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
CapacityRange: &csi03.CapacityRange{
|
||||||
|
RequiredBytes: 1024,
|
||||||
|
},
|
||||||
|
ControllerCreateSecrets: map[string]string{
|
||||||
|
secretName: secretValue,
|
||||||
|
"secret-xyz": "987",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
// Current spec.
|
||||||
createVolume := &csi.CreateVolumeRequest{
|
createVolume := &csi.CreateVolumeRequest{
|
||||||
AccessibilityRequirements: &csi.TopologyRequirement{
|
AccessibilityRequirements: &csi.TopologyRequirement{
|
||||||
Requisite: []*csi.Topology{
|
Requisite: []*csi.Topology{
|
||||||
@@ -63,9 +103,50 @@ func TestStripSecrets(t *testing.T) {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
cases := []struct {
|
// Revised spec with more secret fields.
|
||||||
|
createVolumeFuture := &csitest.CreateVolumeRequest{
|
||||||
|
CapacityRange: &csitest.CapacityRange{
|
||||||
|
RequiredBytes: 1024,
|
||||||
|
},
|
||||||
|
MaybeSecretMap: map[int64]*csitest.VolumeCapability{
|
||||||
|
1: &csitest.VolumeCapability{ArraySecret: "aaa"},
|
||||||
|
2: &csitest.VolumeCapability{ArraySecret: "bbb"},
|
||||||
|
},
|
||||||
|
Name: "foo",
|
||||||
|
NewSecretInt: 42,
|
||||||
|
Seecreets: map[string]string{
|
||||||
|
secretName: secretValue,
|
||||||
|
"secret-xyz": "987",
|
||||||
|
},
|
||||||
|
VolumeCapabilities: []*csitest.VolumeCapability{
|
||||||
|
&csitest.VolumeCapability{
|
||||||
|
AccessType: &csitest.VolumeCapability_Mount{
|
||||||
|
Mount: &csitest.VolumeCapability_MountVolume{
|
||||||
|
FsType: "ext4",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
ArraySecret: "knock knock",
|
||||||
|
},
|
||||||
|
&csitest.VolumeCapability{
|
||||||
|
ArraySecret: "Who's there?",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
VolumeContentSource: &csitest.VolumeContentSource{
|
||||||
|
Type: &csitest.VolumeContentSource_Volume{
|
||||||
|
Volume: &csitest.VolumeContentSource_VolumeSource{
|
||||||
|
VolumeId: "abc",
|
||||||
|
OneofSecretField: "hello",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
NestedSecretField: "world",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
type testcase struct {
|
||||||
original, stripped interface{}
|
original, stripped interface{}
|
||||||
}{
|
}
|
||||||
|
|
||||||
|
cases := []testcase{
|
||||||
{nil, "null"},
|
{nil, "null"},
|
||||||
{1, "1"},
|
{1, "1"},
|
||||||
{"hello world", `"hello world"`},
|
{"hello world", `"hello world"`},
|
||||||
@@ -98,44 +179,9 @@ func TestStripSecrets(t *testing.T) {
|
|||||||
AccessibilityRequirements: &csi.TopologyRequirement{},
|
AccessibilityRequirements: &csi.TopologyRequirement{},
|
||||||
}, `{"accessibility_requirements":{},"capacity_range":{"limit_bytes":1024,"required_bytes":1024},"name":"test-volume","parameters":{"param1":"param1","param2":"param2"},"secrets":"***stripped***","volume_capabilities":[{"AccessType":{"Mount":{"fs_type":"ext4","mount_flags":["flag1","flag2","flag3"]}},"access_mode":{"mode":5}}],"volume_content_source":{"Type":null}}`},
|
}, `{"accessibility_requirements":{},"capacity_range":{"limit_bytes":1024,"required_bytes":1024},"name":"test-volume","parameters":{"param1":"param1","param2":"param2"},"secrets":"***stripped***","volume_capabilities":[{"AccessType":{"Mount":{"fs_type":"ext4","mount_flags":["flag1","flag2","flag3"]}},"access_mode":{"mode":5}}],"volume_content_source":{"Type":null}}`},
|
||||||
{createVolume, `{"accessibility_requirements":{"requisite":[{"segments":{"foo":"bar","x":"y"}},{"segments":{"a":"b"}}]},"capacity_range":{"required_bytes":1024},"name":"foo","secrets":"***stripped***","volume_capabilities":[{"AccessType":{"Mount":{"fs_type":"ext4"}}}]}`},
|
{createVolume, `{"accessibility_requirements":{"requisite":[{"segments":{"foo":"bar","x":"y"}},{"segments":{"a":"b"}}]},"capacity_range":{"required_bytes":1024},"name":"foo","secrets":"***stripped***","volume_capabilities":[{"AccessType":{"Mount":{"fs_type":"ext4"}}}]}`},
|
||||||
|
{createVolumeCSI03, `{"accessibility_requirements":{"requisite":[{"segments":{"foo":"bar","x":"y"}},{"segments":{"a":"b"}}]},"capacity_range":{"required_bytes":1024},"controller_create_secrets":"***stripped***","name":"foo","volume_capabilities":[{"AccessType":{"Mount":{"fs_type":"ext4"}}}]}`},
|
||||||
{&csitest.CreateVolumeRequest{}, `{}`},
|
{&csitest.CreateVolumeRequest{}, `{}`},
|
||||||
{&csitest.CreateVolumeRequest{
|
{createVolumeFuture,
|
||||||
CapacityRange: &csitest.CapacityRange{
|
|
||||||
RequiredBytes: 1024,
|
|
||||||
},
|
|
||||||
MaybeSecretMap: map[int64]*csitest.VolumeCapability{
|
|
||||||
1: &csitest.VolumeCapability{ArraySecret: "aaa"},
|
|
||||||
2: &csitest.VolumeCapability{ArraySecret: "bbb"},
|
|
||||||
},
|
|
||||||
Name: "foo",
|
|
||||||
NewSecretInt: 42,
|
|
||||||
Seecreets: map[string]string{
|
|
||||||
secretName: secretValue,
|
|
||||||
"secret-xyz": "987",
|
|
||||||
},
|
|
||||||
VolumeCapabilities: []*csitest.VolumeCapability{
|
|
||||||
&csitest.VolumeCapability{
|
|
||||||
AccessType: &csitest.VolumeCapability_Mount{
|
|
||||||
Mount: &csitest.VolumeCapability_MountVolume{
|
|
||||||
FsType: "ext4",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
ArraySecret: "knock knock",
|
|
||||||
},
|
|
||||||
&csitest.VolumeCapability{
|
|
||||||
ArraySecret: "Who's there?",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
VolumeContentSource: &csitest.VolumeContentSource{
|
|
||||||
Type: &csitest.VolumeContentSource_Volume{
|
|
||||||
Volume: &csitest.VolumeContentSource_VolumeSource{
|
|
||||||
VolumeId: "abc",
|
|
||||||
OneofSecretField: "hello",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
NestedSecretField: "world",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
// Secrets are *not* removed from all fields yet. This will have to be fixed one way or another
|
// Secrets are *not* removed from all fields yet. This will have to be fixed one way or another
|
||||||
// before the CSI spec can start using secrets there (currently it doesn't).
|
// before the CSI spec can start using secrets there (currently it doesn't).
|
||||||
// The test is still useful because it shows that also complicated fields get serialized.
|
// The test is still useful because it shows that also complicated fields get serialized.
|
||||||
@@ -144,11 +190,29 @@ func TestStripSecrets(t *testing.T) {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Message from revised spec as received by a sidecar based on the current spec.
|
||||||
|
// The XXX_unrecognized field contains secrets and must not get logged.
|
||||||
|
unknownFields := &csi.CreateVolumeRequest{}
|
||||||
|
data, err := proto.Marshal(createVolumeFuture)
|
||||||
|
if assert.NoError(t, err, "marshall future message") &&
|
||||||
|
assert.NoError(t, proto.Unmarshal(data, unknownFields), "unmarshal with unknown fields") {
|
||||||
|
cases = append(cases, testcase{unknownFields,
|
||||||
|
`{"capacity_range":{"required_bytes":1024},"name":"foo","secrets":"***stripped***","volume_capabilities":[{"AccessType":{"Mount":{"fs_type":"ext4"}}},{"AccessType":null}],"volume_content_source":{"Type":{"Volume":{"volume_id":"abc"}}}}`,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
before := fmt.Sprint(c.original)
|
before := fmt.Sprint(c.original)
|
||||||
stripped := StripSecrets(c.original)
|
var stripped fmt.Stringer
|
||||||
|
if _, ok := c.original.(*csi03.CreateVolumeRequest); ok {
|
||||||
|
stripped = StripSecretsCSI03(c.original)
|
||||||
|
} else {
|
||||||
|
stripped = StripSecrets(c.original)
|
||||||
|
}
|
||||||
if assert.Equal(t, c.stripped, fmt.Sprintf("%s", stripped), "unexpected result for fmt s of %s", c.original) {
|
if assert.Equal(t, c.stripped, fmt.Sprintf("%s", stripped), "unexpected result for fmt s of %s", c.original) {
|
||||||
assert.Equal(t, c.stripped, fmt.Sprintf("%v", stripped), "unexpected result for fmt v of %s", c.original)
|
if assert.Equal(t, c.stripped, fmt.Sprintf("%v", stripped), "unexpected result for fmt v of %s", c.original) {
|
||||||
|
assert.Equal(t, c.stripped, fmt.Sprintf("%+v", stripped), "unexpected result for fmt +v of %s", c.original)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
assert.Equal(t, before, fmt.Sprint(c.original), "original value modified")
|
assert.Equal(t, before, fmt.Sprint(c.original), "original value modified")
|
||||||
}
|
}
|
||||||
|
4991
vendor/github.com/kubernetes-csi/csi-lib-utils/protosanitizer/test/csi03/csi.pb.go
generated
vendored
Normal file
4991
vendor/github.com/kubernetes-csi/csi-lib-utils/protosanitizer/test/csi03/csi.pb.go
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
5277
vendor/github.com/kubernetes-csi/csi-lib-utils/protosanitizer/test/csi10/csi.pb.go
generated
vendored
Normal file
5277
vendor/github.com/kubernetes-csi/csi-lib-utils/protosanitizer/test/csi10/csi.pb.go
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
31
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/CONTRIBUTING.md
generated
vendored
Normal file
31
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/CONTRIBUTING.md
generated
vendored
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
# Contributing Guidelines
|
||||||
|
|
||||||
|
Welcome to Kubernetes. We are excited about the prospect of you joining our [community](https://github.com/kubernetes/community)! The Kubernetes community abides by the CNCF [code of conduct](code-of-conduct.md). Here is an excerpt:
|
||||||
|
|
||||||
|
_As contributors and maintainers of this project, and in the interest of fostering an open and welcoming community, we pledge to respect all people who contribute through reporting issues, posting feature requests, updating documentation, submitting pull requests or patches, and other activities._
|
||||||
|
|
||||||
|
## Getting Started
|
||||||
|
|
||||||
|
We have full documentation on how to get started contributing here:
|
||||||
|
|
||||||
|
<!---
|
||||||
|
If your repo has certain guidelines for contribution, put them here ahead of the general k8s resources
|
||||||
|
-->
|
||||||
|
|
||||||
|
- [Contributor License Agreement](https://git.k8s.io/community/CLA.md) Kubernetes projects require that you sign a Contributor License Agreement (CLA) before we can accept your pull requests
|
||||||
|
- [Kubernetes Contributor Guide](http://git.k8s.io/community/contributors/guide) - Main contributor documentation, or you can just jump directly to the [contributing section](http://git.k8s.io/community/contributors/guide#contributing)
|
||||||
|
- [Contributor Cheat Sheet](https://git.k8s.io/community/contributors/guide/contributor-cheatsheet.md) - Common resources for existing developers
|
||||||
|
|
||||||
|
## Mentorship
|
||||||
|
|
||||||
|
- [Mentoring Initiatives](https://git.k8s.io/community/mentoring) - We have a diverse set of mentorship programs available that are always looking for volunteers!
|
||||||
|
|
||||||
|
<!---
|
||||||
|
Custom Information - if you're copying this template for the first time you can add custom content here, for example:
|
||||||
|
|
||||||
|
## Contact Information
|
||||||
|
|
||||||
|
- [Slack channel](https://kubernetes.slack.com/messages/kubernetes-users) - Replace `kubernetes-users` with your slack channel string, this will send users directly to your channel.
|
||||||
|
- [Mailing list](URL)
|
||||||
|
|
||||||
|
-->
|
201
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/LICENSE
generated
vendored
Normal file
201
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/LICENSE
generated
vendored
Normal file
@@ -0,0 +1,201 @@
|
|||||||
|
Apache License
|
||||||
|
Version 2.0, January 2004
|
||||||
|
http://www.apache.org/licenses/
|
||||||
|
|
||||||
|
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||||
|
|
||||||
|
1. Definitions.
|
||||||
|
|
||||||
|
"License" shall mean the terms and conditions for use, reproduction,
|
||||||
|
and distribution as defined by Sections 1 through 9 of this document.
|
||||||
|
|
||||||
|
"Licensor" shall mean the copyright owner or entity authorized by
|
||||||
|
the copyright owner that is granting the License.
|
||||||
|
|
||||||
|
"Legal Entity" shall mean the union of the acting entity and all
|
||||||
|
other entities that control, are controlled by, or are under common
|
||||||
|
control with that entity. For the purposes of this definition,
|
||||||
|
"control" means (i) the power, direct or indirect, to cause the
|
||||||
|
direction or management of such entity, whether by contract or
|
||||||
|
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||||
|
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||||
|
|
||||||
|
"You" (or "Your") shall mean an individual or Legal Entity
|
||||||
|
exercising permissions granted by this License.
|
||||||
|
|
||||||
|
"Source" form shall mean the preferred form for making modifications,
|
||||||
|
including but not limited to software source code, documentation
|
||||||
|
source, and configuration files.
|
||||||
|
|
||||||
|
"Object" form shall mean any form resulting from mechanical
|
||||||
|
transformation or translation of a Source form, including but
|
||||||
|
not limited to compiled object code, generated documentation,
|
||||||
|
and conversions to other media types.
|
||||||
|
|
||||||
|
"Work" shall mean the work of authorship, whether in Source or
|
||||||
|
Object form, made available under the License, as indicated by a
|
||||||
|
copyright notice that is included in or attached to the work
|
||||||
|
(an example is provided in the Appendix below).
|
||||||
|
|
||||||
|
"Derivative Works" shall mean any work, whether in Source or Object
|
||||||
|
form, that is based on (or derived from) the Work and for which the
|
||||||
|
editorial revisions, annotations, elaborations, or other modifications
|
||||||
|
represent, as a whole, an original work of authorship. For the purposes
|
||||||
|
of this License, Derivative Works shall not include works that remain
|
||||||
|
separable from, or merely link (or bind by name) to the interfaces of,
|
||||||
|
the Work and Derivative Works thereof.
|
||||||
|
|
||||||
|
"Contribution" shall mean any work of authorship, including
|
||||||
|
the original version of the Work and any modifications or additions
|
||||||
|
to that Work or Derivative Works thereof, that is intentionally
|
||||||
|
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||||
|
or by an individual or Legal Entity authorized to submit on behalf of
|
||||||
|
the copyright owner. For the purposes of this definition, "submitted"
|
||||||
|
means any form of electronic, verbal, or written communication sent
|
||||||
|
to the Licensor or its representatives, including but not limited to
|
||||||
|
communication on electronic mailing lists, source code control systems,
|
||||||
|
and issue tracking systems that are managed by, or on behalf of, the
|
||||||
|
Licensor for the purpose of discussing and improving the Work, but
|
||||||
|
excluding communication that is conspicuously marked or otherwise
|
||||||
|
designated in writing by the copyright owner as "Not a Contribution."
|
||||||
|
|
||||||
|
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||||
|
on behalf of whom a Contribution has been received by Licensor and
|
||||||
|
subsequently incorporated within the Work.
|
||||||
|
|
||||||
|
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
copyright license to reproduce, prepare Derivative Works of,
|
||||||
|
publicly display, publicly perform, sublicense, and distribute the
|
||||||
|
Work and such Derivative Works in Source or Object form.
|
||||||
|
|
||||||
|
3. Grant of Patent License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
(except as stated in this section) patent license to make, have made,
|
||||||
|
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||||
|
where such license applies only to those patent claims licensable
|
||||||
|
by such Contributor that are necessarily infringed by their
|
||||||
|
Contribution(s) alone or by combination of their Contribution(s)
|
||||||
|
with the Work to which such Contribution(s) was submitted. If You
|
||||||
|
institute patent litigation against any entity (including a
|
||||||
|
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||||
|
or a Contribution incorporated within the Work constitutes direct
|
||||||
|
or contributory patent infringement, then any patent licenses
|
||||||
|
granted to You under this License for that Work shall terminate
|
||||||
|
as of the date such litigation is filed.
|
||||||
|
|
||||||
|
4. Redistribution. You may reproduce and distribute copies of the
|
||||||
|
Work or Derivative Works thereof in any medium, with or without
|
||||||
|
modifications, and in Source or Object form, provided that You
|
||||||
|
meet the following conditions:
|
||||||
|
|
||||||
|
(a) You must give any other recipients of the Work or
|
||||||
|
Derivative Works a copy of this License; and
|
||||||
|
|
||||||
|
(b) You must cause any modified files to carry prominent notices
|
||||||
|
stating that You changed the files; and
|
||||||
|
|
||||||
|
(c) You must retain, in the Source form of any Derivative Works
|
||||||
|
that You distribute, all copyright, patent, trademark, and
|
||||||
|
attribution notices from the Source form of the Work,
|
||||||
|
excluding those notices that do not pertain to any part of
|
||||||
|
the Derivative Works; and
|
||||||
|
|
||||||
|
(d) If the Work includes a "NOTICE" text file as part of its
|
||||||
|
distribution, then any Derivative Works that You distribute must
|
||||||
|
include a readable copy of the attribution notices contained
|
||||||
|
within such NOTICE file, excluding those notices that do not
|
||||||
|
pertain to any part of the Derivative Works, in at least one
|
||||||
|
of the following places: within a NOTICE text file distributed
|
||||||
|
as part of the Derivative Works; within the Source form or
|
||||||
|
documentation, if provided along with the Derivative Works; or,
|
||||||
|
within a display generated by the Derivative Works, if and
|
||||||
|
wherever such third-party notices normally appear. The contents
|
||||||
|
of the NOTICE file are for informational purposes only and
|
||||||
|
do not modify the License. You may add Your own attribution
|
||||||
|
notices within Derivative Works that You distribute, alongside
|
||||||
|
or as an addendum to the NOTICE text from the Work, provided
|
||||||
|
that such additional attribution notices cannot be construed
|
||||||
|
as modifying the License.
|
||||||
|
|
||||||
|
You may add Your own copyright statement to Your modifications and
|
||||||
|
may provide additional or different license terms and conditions
|
||||||
|
for use, reproduction, or distribution of Your modifications, or
|
||||||
|
for any such Derivative Works as a whole, provided Your use,
|
||||||
|
reproduction, and distribution of the Work otherwise complies with
|
||||||
|
the conditions stated in this License.
|
||||||
|
|
||||||
|
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||||
|
any Contribution intentionally submitted for inclusion in the Work
|
||||||
|
by You to the Licensor shall be under the terms and conditions of
|
||||||
|
this License, without any additional terms or conditions.
|
||||||
|
Notwithstanding the above, nothing herein shall supersede or modify
|
||||||
|
the terms of any separate license agreement you may have executed
|
||||||
|
with Licensor regarding such Contributions.
|
||||||
|
|
||||||
|
6. Trademarks. This License does not grant permission to use the trade
|
||||||
|
names, trademarks, service marks, or product names of the Licensor,
|
||||||
|
except as required for reasonable and customary use in describing the
|
||||||
|
origin of the Work and reproducing the content of the NOTICE file.
|
||||||
|
|
||||||
|
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||||
|
agreed to in writing, Licensor provides the Work (and each
|
||||||
|
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
implied, including, without limitation, any warranties or conditions
|
||||||
|
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||||
|
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||||
|
appropriateness of using or redistributing the Work and assume any
|
||||||
|
risks associated with Your exercise of permissions under this License.
|
||||||
|
|
||||||
|
8. Limitation of Liability. In no event and under no legal theory,
|
||||||
|
whether in tort (including negligence), contract, or otherwise,
|
||||||
|
unless required by applicable law (such as deliberate and grossly
|
||||||
|
negligent acts) or agreed to in writing, shall any Contributor be
|
||||||
|
liable to You for damages, including any direct, indirect, special,
|
||||||
|
incidental, or consequential damages of any character arising as a
|
||||||
|
result of this License or out of the use or inability to use the
|
||||||
|
Work (including but not limited to damages for loss of goodwill,
|
||||||
|
work stoppage, computer failure or malfunction, or any and all
|
||||||
|
other commercial damages or losses), even if such Contributor
|
||||||
|
has been advised of the possibility of such damages.
|
||||||
|
|
||||||
|
9. Accepting Warranty or Additional Liability. While redistributing
|
||||||
|
the Work or Derivative Works thereof, You may choose to offer,
|
||||||
|
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||||
|
or other liability obligations and/or rights consistent with this
|
||||||
|
License. However, in accepting such obligations, You may act only
|
||||||
|
on Your own behalf and on Your sole responsibility, not on behalf
|
||||||
|
of any other Contributor, and only if You agree to indemnify,
|
||||||
|
defend, and hold each Contributor harmless for any liability
|
||||||
|
incurred by, or claims asserted against, such Contributor by reason
|
||||||
|
of your accepting any such warranty or additional liability.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
APPENDIX: How to apply the Apache License to your work.
|
||||||
|
|
||||||
|
To apply the Apache License to your work, attach the following
|
||||||
|
boilerplate notice, with the fields enclosed by brackets "{}"
|
||||||
|
replaced with your own identifying information. (Don't include
|
||||||
|
the brackets!) The text should be enclosed in the appropriate
|
||||||
|
comment syntax for the file format. We also recommend that a
|
||||||
|
file or class name and description of purpose be included on the
|
||||||
|
same "printed page" as the copyright notice for easier
|
||||||
|
identification within third-party archives.
|
||||||
|
|
||||||
|
Copyright {yyyy} {name of copyright owner}
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
11
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/OWNERS
generated
vendored
Normal file
11
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/OWNERS
generated
vendored
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
# See the OWNERS docs: https://git.k8s.io/community/contributors/guide/owners.md
|
||||||
|
|
||||||
|
approvers:
|
||||||
|
- saad-ali
|
||||||
|
- msau42
|
||||||
|
- pohly
|
||||||
|
|
||||||
|
reviewers:
|
||||||
|
- saad-ali
|
||||||
|
- msau42
|
||||||
|
- pohly
|
51
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/README.md
generated
vendored
Normal file
51
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/README.md
generated
vendored
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
# [csi-release-tools](https://github.com/kubernetes-csi/csi-release-tools)
|
||||||
|
|
||||||
|
These build and test rules can be shared between different Go projects
|
||||||
|
without modifications. Customization for the different projects happen
|
||||||
|
in the top-level Makefile.
|
||||||
|
|
||||||
|
The rules include support for building and pushing Docker images, with
|
||||||
|
the following features:
|
||||||
|
- one or more command and image per project
|
||||||
|
- push canary and/or tagged release images
|
||||||
|
- automatically derive the image tag(s) from repo tags
|
||||||
|
- the source code revision is stored in a "revision" image label
|
||||||
|
- never overwrites an existing release image
|
||||||
|
|
||||||
|
Usage
|
||||||
|
-----
|
||||||
|
|
||||||
|
The expected repository layout is:
|
||||||
|
- `cmd/*/*.go` - source code for each command
|
||||||
|
- `cmd/*/Dockerfile` - docker file for each command or
|
||||||
|
Dockerfile in the root when only building a single command
|
||||||
|
- `Makefile` - includes `release-tools/build.make` and sets
|
||||||
|
configuration variables
|
||||||
|
- `.travis.yml` - a symlink to `release-tools/.travis.yml`
|
||||||
|
|
||||||
|
To create a release, tag a certain revision with a name that
|
||||||
|
starts with `v`, for example `v1.0.0`, then `make push`
|
||||||
|
while that commit is checked out.
|
||||||
|
|
||||||
|
It does not matter on which branch that revision exists, i.e. it is
|
||||||
|
possible to create releases directly from master. A release branch can
|
||||||
|
still be created for maintenance releases later if needed.
|
||||||
|
|
||||||
|
Release branches are expected to be named `release-x.y` for releases
|
||||||
|
`x.y.z`. Building from such a branch creates `x.y-canary`
|
||||||
|
images. Building from master creates the main `canary` image.
|
||||||
|
|
||||||
|
Sharing and updating
|
||||||
|
--------------------
|
||||||
|
|
||||||
|
[`git subtree`](https://github.com/git/git/blob/master/contrib/subtree/git-subtree.txt)
|
||||||
|
is the recommended way of maintaining a copy of the rules inside the
|
||||||
|
`release-tools` directory of a project. This way, it is possible to make
|
||||||
|
changes also locally, test them and then push them back to the shared
|
||||||
|
repository at a later time.
|
||||||
|
|
||||||
|
Cheat sheet:
|
||||||
|
|
||||||
|
- `git subtree add --prefix=release-tools https://github.com/kubernetes-csi/csi-release-tools.git master` - add release tools to a repo which does not have them yet (only once)
|
||||||
|
- `git subtree pull --prefix=release-tools https://github.com/kubernetes-csi/csi-release-tools.git master` - update local copy to latest upstream (whenever upstream changes)
|
||||||
|
- edit, `git commit`, `git subtree push --prefix=release-tools git@github.com:<user>/csi-release-tools.git <my-new-or-existing-branch>` - push to a new branch before submitting a PR
|
5
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/RELEASE.md
generated
vendored
Normal file
5
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/RELEASE.md
generated
vendored
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
# Release Process
|
||||||
|
|
||||||
|
No tagged releases are planned at this point. The intention is to keep
|
||||||
|
the master branch in a state such that it can be used for all
|
||||||
|
supported branches in downstream repos which use these files.
|
14
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/SECURITY_CONTACTS
generated
vendored
Normal file
14
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/SECURITY_CONTACTS
generated
vendored
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
# Defined below are the security contacts for this repo.
|
||||||
|
#
|
||||||
|
# They are the contact point for the Product Security Team to reach out
|
||||||
|
# to for triaging and handling of incoming issues.
|
||||||
|
#
|
||||||
|
# The below names agree to abide by the
|
||||||
|
# [Embargo Policy](https://github.com/kubernetes/sig-release/blob/master/security-release-process-documentation/security-release-process.md#embargo-policy)
|
||||||
|
# and will be removed and replaced if they violate that agreement.
|
||||||
|
#
|
||||||
|
# DO NOT REPORT SECURITY VULNERABILITIES DIRECTLY TO THESE NAMES, FOLLOW THE
|
||||||
|
# INSTRUCTIONS AT https://kubernetes.io/security/
|
||||||
|
|
||||||
|
saad-ali
|
||||||
|
msau42
|
124
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/build.make
generated
vendored
Normal file
124
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/build.make
generated
vendored
Normal file
@@ -0,0 +1,124 @@
|
|||||||
|
# Copyright 2019 The Kubernetes Authors.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
.PHONY: build-% build container-% container push-% push clean test
|
||||||
|
|
||||||
|
# A space-separated list of all commands in the repository, must be
|
||||||
|
# set in main Makefile of a repository.
|
||||||
|
# CMDS=
|
||||||
|
|
||||||
|
# This is the default. It can be overridden in the main Makefile after
|
||||||
|
# including build.make.
|
||||||
|
REGISTRY_NAME=quay.io/k8scsi
|
||||||
|
|
||||||
|
# Revision that gets built into each binary via the main.version
|
||||||
|
# string. Uses the `git describe` output based on the most recent
|
||||||
|
# version tag with a short revision suffix or, if nothing has been
|
||||||
|
# tagged yet, just the revision.
|
||||||
|
#
|
||||||
|
# Beware that tags may also be missing in shallow clones as done by
|
||||||
|
# some CI systems (like TravisCI, which pulls only 50 commits).
|
||||||
|
REV=$(shell git describe --long --tags --match='v*' --dirty 2>/dev/null || git rev-list -n1 HEAD)
|
||||||
|
|
||||||
|
# A space-separated list of image tags under which the current build is to be pushed.
|
||||||
|
# Determined dynamically.
|
||||||
|
IMAGE_TAGS=
|
||||||
|
|
||||||
|
# A "canary" image gets built if the current commit is the head of the remote "master" branch.
|
||||||
|
# That branch does not exist when building some other branch in TravisCI.
|
||||||
|
IMAGE_TAGS+=$(shell if [ "$$(git rev-list -n1 HEAD)" = "$$(git rev-list -n1 origin/master 2>/dev/null)" ]; then echo "canary"; fi)
|
||||||
|
|
||||||
|
# A "X.Y.Z-canary" image gets built if the current commit is the head of a "origin/release-X.Y.Z" branch.
|
||||||
|
# The actual suffix does not matter, only the "release-" prefix is checked.
|
||||||
|
IMAGE_TAGS+=$(shell git branch -r --points-at=HEAD | grep 'origin/release-' | grep -v -e ' -> ' | sed -e 's;.*/release-\(.*\);\1-canary;')
|
||||||
|
|
||||||
|
# A release image "vX.Y.Z" gets built if there is a tag of that format for the current commit.
|
||||||
|
# --abbrev=0 suppresses long format, only showing the closest tag.
|
||||||
|
IMAGE_TAGS+=$(shell tagged="$$(git describe --tags --match='v*' --abbrev=0)"; if [ "$$tagged" ] && [ "$$(git rev-list -n1 HEAD)" = "$$(git rev-list -n1 $$tagged)" ]; then echo $$tagged; fi)
|
||||||
|
|
||||||
|
# Images are named after the command contained in them.
|
||||||
|
IMAGE_NAME=$(REGISTRY_NAME)/$*
|
||||||
|
|
||||||
|
ifdef V
|
||||||
|
# Adding "-alsologtostderr" assumes that all test binaries contain glog. This is not guaranteed.
|
||||||
|
TESTARGS = -v -args -alsologtostderr -v 5
|
||||||
|
else
|
||||||
|
TESTARGS =
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Specific packages can be excluded from each of the tests below by setting the *_FILTER_CMD variables
|
||||||
|
# to something like "| grep -v 'github.com/kubernetes-csi/project/pkg/foobar'". See usage below.
|
||||||
|
|
||||||
|
build-%:
|
||||||
|
mkdir -p bin
|
||||||
|
CGO_ENABLED=0 GOOS=linux go build -a -ldflags '-X main.version=$(REV) -extldflags "-static"' -o ./bin/$* ./cmd/$*
|
||||||
|
|
||||||
|
container-%: build-%
|
||||||
|
docker build -t $*:latest -f $(shell if [ -e ./cmd/$*/Dockerfile ]; then echo ./cmd/$*/Dockerfile; else echo Dockerfile; fi) --label revision=$(REV) .
|
||||||
|
|
||||||
|
push-%: container-%
|
||||||
|
set -ex; \
|
||||||
|
push_image () { \
|
||||||
|
docker tag $*:latest $(IMAGE_NAME):$$tag; \
|
||||||
|
docker push $(IMAGE_NAME):$$tag; \
|
||||||
|
}; \
|
||||||
|
for tag in $(IMAGE_TAGS); do \
|
||||||
|
if [ "$$tag" = "canary" ] || echo "$$tag" | grep -q -e '-canary$$'; then \
|
||||||
|
: "creating or overwriting canary image"; \
|
||||||
|
push_image; \
|
||||||
|
elif docker pull $(IMAGE_NAME):$$tag 2>&1 | tee /dev/stderr | grep -q "manifest for $(IMAGE_NAME):$$tag not found"; then \
|
||||||
|
: "creating release image"; \
|
||||||
|
push_image; \
|
||||||
|
else \
|
||||||
|
: "release image $(IMAGE_NAME):$$tag already exists, skipping push"; \
|
||||||
|
fi; \
|
||||||
|
done
|
||||||
|
|
||||||
|
build: $(CMDS:%=build-%)
|
||||||
|
container: $(CMDS:%=container-%)
|
||||||
|
push: $(CMDS:%=push-%)
|
||||||
|
|
||||||
|
clean:
|
||||||
|
-rm -rf bin
|
||||||
|
|
||||||
|
test:
|
||||||
|
|
||||||
|
.PHONY: test-go
|
||||||
|
test: test-go
|
||||||
|
test-go:
|
||||||
|
@ echo; echo "### $@:"
|
||||||
|
go test `go list ./... | grep -v 'vendor' $(TEST_GO_FILTER_CMD)` $(TESTARGS)
|
||||||
|
|
||||||
|
.PHONY: test-vet
|
||||||
|
test: test-vet
|
||||||
|
test-vet:
|
||||||
|
@ echo; echo "### $@:"
|
||||||
|
go vet `go list ./... | grep -v vendor $(TEST_VET_FILTER_CMD)`
|
||||||
|
|
||||||
|
.PHONY: test-fmt
|
||||||
|
test: test-fmt
|
||||||
|
test-fmt:
|
||||||
|
@ echo; echo "### $@:"
|
||||||
|
files=$$(find . -name '*.go' | grep -v './vendor' $(TEST_FMT_FILTER_CMD)); \
|
||||||
|
if [ $$(gofmt -d $$files | wc -l) -ne 0 ]; then \
|
||||||
|
echo "formatting errors:"; \
|
||||||
|
gofmt -d $$files; \
|
||||||
|
false; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
.PHONY: test-subtree
|
||||||
|
test: test-subtree
|
||||||
|
test-subtree:
|
||||||
|
@ echo; echo "### $@:"
|
||||||
|
./release-tools/verify-subtree.sh release-tools
|
3
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/code-of-conduct.md
generated
vendored
Normal file
3
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/code-of-conduct.md
generated
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
# Kubernetes Community Code of Conduct
|
||||||
|
|
||||||
|
Please refer to our [Kubernetes Community Code of Conduct](https://git.k8s.io/community/code-of-conduct.md)
|
14
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/travis.yml
generated
vendored
Normal file
14
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/travis.yml
generated
vendored
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
language: go
|
||||||
|
sudo: required
|
||||||
|
services:
|
||||||
|
- docker
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- go: 1.11.1
|
||||||
|
script:
|
||||||
|
- make -k all test
|
||||||
|
after_success:
|
||||||
|
- if [ "${TRAVIS_PULL_REQUEST}" == "false" ]; then
|
||||||
|
docker login -u "${DOCKER_USERNAME}" -p "${DOCKER_PASSWORD}" quay.io;
|
||||||
|
make push;
|
||||||
|
fi
|
41
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/verify-subtree.sh
generated
vendored
Executable file
41
vendor/github.com/kubernetes-csi/csi-lib-utils/release-tools/verify-subtree.sh
generated
vendored
Executable file
@@ -0,0 +1,41 @@
|
|||||||
|
#! /bin/sh -e
|
||||||
|
#
|
||||||
|
# Copyright 2019 The Kubernetes Authors.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
# This script verifies that the content of a directory managed
|
||||||
|
# by "git subtree" has not been modified locally. It does that
|
||||||
|
# by looking for commits that modify the files with the
|
||||||
|
# subtree prefix (aka directory) while ignoring merge
|
||||||
|
# commits. Merge commits are where "git subtree" pulls the
|
||||||
|
# upstream files into the directory.
|
||||||
|
#
|
||||||
|
# Theoretically a developer can subvert this check by modifying files
|
||||||
|
# in a merge commit, but in practice that shouldn't happen.
|
||||||
|
|
||||||
|
DIR="$1"
|
||||||
|
if [ ! "$DIR" ]; then
|
||||||
|
echo "usage: $0 <directory>" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
REV=$(git log -n1 --format=format:%H --no-merges -- "$DIR")
|
||||||
|
if [ "$REV" ]; then
|
||||||
|
echo "Directory '$DIR' contains non-upstream changes:"
|
||||||
|
echo
|
||||||
|
git log --no-merges -- "$DIR"
|
||||||
|
exit 1
|
||||||
|
else
|
||||||
|
echo "$DIR is a clean copy of upstream."
|
||||||
|
fi
|
Reference in New Issue
Block a user