ci/cd: unit test hangs for a long time intermittently closes #286

Signed-off-by: Alexei Dodon <adodon@cisco.com>
This commit is contained in:
Alexei Dodon 2021-11-22 10:12:01 +02:00 committed by Ramkumar Chinchani
parent fff6107310
commit f99fa37623
6 changed files with 112 additions and 495 deletions

View File

@ -32,7 +32,7 @@ test:
$(shell mkdir -p test/data; cd test/data; ../scripts/gen_certs.sh; cd ${TOP_LEVEL}; sudo skopeo --insecure-policy copy -q docker://public.ecr.aws/t0x7q1g8/centos:7 oci:${TOP_LEVEL}/test/data/zot-test:0.0.1;sudo skopeo --insecure-policy copy -q docker://public.ecr.aws/t0x7q1g8/centos:8 oci:${TOP_LEVEL}/test/data/zot-cve-test:0.0.1) $(shell mkdir -p test/data; cd test/data; ../scripts/gen_certs.sh; cd ${TOP_LEVEL}; sudo skopeo --insecure-policy copy -q docker://public.ecr.aws/t0x7q1g8/centos:7 oci:${TOP_LEVEL}/test/data/zot-test:0.0.1;sudo skopeo --insecure-policy copy -q docker://public.ecr.aws/t0x7q1g8/centos:8 oci:${TOP_LEVEL}/test/data/zot-cve-test:0.0.1)
$(shell sudo mkdir -p /etc/containers/certs.d/127.0.0.1:8089/; sudo cp test/data/client.* /etc/containers/certs.d/127.0.0.1:8089/; sudo cp test/data/ca.* /etc/containers/certs.d/127.0.0.1:8089/;) $(shell sudo mkdir -p /etc/containers/certs.d/127.0.0.1:8089/; sudo cp test/data/client.* /etc/containers/certs.d/127.0.0.1:8089/; sudo cp test/data/ca.* /etc/containers/certs.d/127.0.0.1:8089/;)
$(shell sudo chmod a=rwx /etc/containers/certs.d/127.0.0.1:8089/*.key) $(shell sudo chmod a=rwx /etc/containers/certs.d/127.0.0.1:8089/*.key)
go test -tags extended,containers_image_openpgp -v -trimpath -race -cover -coverpkg ./... -coverprofile=coverage-extended.txt -covermode=atomic ./... go test -tags extended,containers_image_openpgp -v -trimpath -race -timeout 15m -cover -coverpkg ./... -coverprofile=coverage-extended.txt -covermode=atomic ./...
go test -tags minimal,containers_image_openpgp -v -trimpath -race -cover -coverpkg ./... -coverprofile=coverage-minimal.txt -covermode=atomic ./... go test -tags minimal,containers_image_openpgp -v -trimpath -race -cover -coverpkg ./... -coverprofile=coverage-minimal.txt -covermode=atomic ./...
.PHONY: test-clean .PHONY: test-clean

View File

@ -131,26 +131,9 @@ func TestObjectStorageController(t *testing.T) {
c.Config.Storage.RootDirectory = "/" c.Config.Storage.RootDirectory = "/"
go func(controller *api.Controller) { go startServer(c)
// this blocks defer stopServer(c)
if err := controller.Run(); err != nil { WaitTillServerReady(baseURL)
return
}
}(c)
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func(controller *api.Controller) {
ctx := context.Background()
_ = controller.Server.Shutdown(ctx)
}(c)
}) })
} }
@ -186,24 +169,9 @@ func TestObjectStorageControllerSubPaths(t *testing.T) {
} }
c.Config.Storage.SubPaths = subPathMap c.Config.Storage.SubPaths = subPathMap
go func(controller *api.Controller) { go startServer(c)
// this blocks defer stopServer(c)
if err := controller.Run(); err != nil { WaitTillServerReady(baseURL)
return
}
}(c)
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func(controller *api.Controller) {
ctx := context.Background()
_ = controller.Server.Shutdown(ctx)
}(c)
}) })
} }
@ -236,24 +204,11 @@ func TestHtpasswdSingleCred(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func(controller *api.Controller) {
// this blocks go startServer(c)
if err := controller.Run(); err != nil { defer stopServer(c)
return WaitTillServerReady(baseURL)
}
}(c)
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func(controller *api.Controller) {
ctx := context.Background()
_ = controller.Server.Shutdown(ctx)
}(c)
// with creds, should get expected status code // with creds, should get expected status code
resp, _ := resty.R().SetBasicAuth(user, password).Get(baseURL + "/v2/") resp, _ := resty.R().SetBasicAuth(user, password).Get(baseURL + "/v2/")
So(resp, ShouldNotBeNil) So(resp, ShouldNotBeNil)
@ -304,25 +259,11 @@ func TestHtpasswdTwoCreds(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func(controller *api.Controller) {
// this blocks
if err := controller.Run(); err != nil {
return
}
}(c)
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func(controller *api.Controller) { go startServer(c)
ctx := context.Background() defer stopServer(c)
_ = controller.Server.Shutdown(ctx) WaitTillServerReady(baseURL)
}(c)
// with creds, should get expected status code // with creds, should get expected status code
resp, _ := resty.R().SetBasicAuth(user1, password1).Get(baseURL + "/v2/") resp, _ := resty.R().SetBasicAuth(user1, password1).Get(baseURL + "/v2/")
So(resp, ShouldNotBeNil) So(resp, ShouldNotBeNil)
@ -373,25 +314,11 @@ func TestHtpasswdFiveCreds(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func(controller *api.Controller) {
// this blocks
if err := controller.Run(); err != nil {
return
}
}(c)
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func(controller *api.Controller) { go startServer(c)
ctx := context.Background() defer stopServer(c)
_ = controller.Server.Shutdown(ctx) WaitTillServerReady(baseURL)
}(c)
// with creds, should get expected status code // with creds, should get expected status code
for key, val := range tests { for key, val := range tests {
resp, _ := resty.R().SetBasicAuth(key, val).Get(baseURL + "/v2/") resp, _ := resty.R().SetBasicAuth(key, val).Get(baseURL + "/v2/")
@ -427,26 +354,10 @@ func TestBasicAuth(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
// without creds, should get access error // without creds, should get access error
resp, err := resty.R().Get(baseURL + "/v2/") resp, err := resty.R().Get(baseURL + "/v2/")
@ -483,31 +394,13 @@ func TestInterruptedBlobUpload(t *testing.T) {
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks go startServer(c)
if err := c.Run(); err != nil { defer stopServer(c)
return WaitTillServerReady(baseURL)
}
}()
client := resty.New() client := resty.New()
// wait till ready
for {
_, err := client.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
blob := make([]byte, 50*1024*1024) blob := make([]byte, 50*1024*1024)
digest := godigest.FromBytes(blob).String() digest := godigest.FromBytes(blob).String()
// nolint: dupl // nolint: dupl
@ -743,25 +636,9 @@ func TestMultipleInstance(t *testing.T) {
subPathMap["/a"] = config.StorageConfig{RootDirectory: subDir} subPathMap["/a"] = config.StorageConfig{RootDirectory: subDir}
go func() { go startServer(c)
if err := c.Run(); err != nil { defer stopServer(c)
return WaitTillServerReady(baseURL)
}
}()
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
client := resty.New() client := resty.New()
@ -799,28 +676,11 @@ func TestMultipleInstance(t *testing.T) {
c.Config.Storage.RootDirectory = globalDir c.Config.Storage.RootDirectory = globalDir
subPathMap := make(map[string]config.StorageConfig) subPathMap := make(map[string]config.StorageConfig)
subPathMap["/a"] = config.StorageConfig{RootDirectory: subDir} subPathMap["/a"] = config.StorageConfig{RootDirectory: subDir}
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
// without creds, should get access error // without creds, should get access error
resp, err := resty.R().Get(baseURL + "/v2/") resp, err := resty.R().Get(baseURL + "/v2/")
@ -876,26 +736,10 @@ func TestTLSWithBasicAuth(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
// accessing insecure HTTP site should fail // accessing insecure HTTP site should fail
resp, err := resty.R().Get(baseURL) resp, err := resty.R().Get(baseURL)
@ -958,26 +802,10 @@ func TestTLSWithBasicAuthAllowReadAccess(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
// accessing insecure HTTP site should fail // accessing insecure HTTP site should fail
resp, err := resty.R().Get(baseURL) resp, err := resty.R().Get(baseURL)
@ -1034,26 +862,10 @@ func TestTLSMutualAuth(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
// accessing insecure HTTP site should fail // accessing insecure HTTP site should fail
resp, err := resty.R().Get(baseURL) resp, err := resty.R().Get(baseURL)
@ -1123,26 +935,10 @@ func TestTLSMutualAuthAllowReadAccess(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
// accessing insecure HTTP site should fail // accessing insecure HTTP site should fail
resp, err := resty.R().Get(baseURL) resp, err := resty.R().Get(baseURL)
@ -1225,26 +1021,10 @@ func TestTLSMutualAndBasicAuth(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
// accessing insecure HTTP site should fail // accessing insecure HTTP site should fail
resp, err := resty.R().Get(baseURL) resp, err := resty.R().Get(baseURL)
@ -1324,26 +1104,10 @@ func TestTLSMutualAndBasicAuthAllowReadAccess(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
// accessing insecure HTTP site should fail // accessing insecure HTTP site should fail
resp, err := resty.R().Get(baseURL) resp, err := resty.R().Get(baseURL)
@ -1497,26 +1261,10 @@ func TestBasicAuthWithLDAP(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
// without creds, should get access error // without creds, should get access error
resp, err := resty.R().Get(baseURL + "/v2/") resp, err := resty.R().Get(baseURL + "/v2/")
@ -1564,26 +1312,10 @@ func TestBearerAuth(t *testing.T) {
So(err, ShouldBeNil) So(err, ShouldBeNil)
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
blob := []byte("hello, blob!") blob := []byte("hello, blob!")
digest := godigest.FromBytes(blob).String() digest := godigest.FromBytes(blob).String()
@ -1747,26 +1479,10 @@ func TestBearerAuthWithAllowReadAccess(t *testing.T) {
So(err, ShouldBeNil) So(err, ShouldBeNil)
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
blob := []byte("hello, blob!") blob := []byte("hello, blob!")
digest := godigest.FromBytes(blob).String() digest := godigest.FromBytes(blob).String()
@ -2001,26 +1717,10 @@ func TestAuthorizationWithBasicAuth(t *testing.T) {
panic(err) panic(err)
} }
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() {
// this blocks
if err := c.Run(); err != nil {
return
}
}()
// wait till ready go startServer(c)
for { defer stopServer(c)
_, err := resty.R().Get(baseURL) WaitTillServerReady(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func() {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}()
blob := []byte("hello, blob!") blob := []byte("hello, blob!")
digest := godigest.FromBytes(blob).String() digest := godigest.FromBytes(blob).String()
@ -2370,26 +2070,21 @@ func TestInvalidCases(t *testing.T) {
panic(err) panic(err)
} }
defer stopServer(c)
c.Config.Storage.RootDirectory = "oci-repo-test" c.Config.Storage.RootDirectory = "oci-repo-test"
go func() { go startServer(c)
// this blocks defer func(ctrl *api.Controller) {
if err := c.Run(); err != nil { err := ctrl.Server.Shutdown(context.Background())
return if err != nil {
} panic(err)
}()
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
} }
time.Sleep(100 * time.Millisecond) err = os.RemoveAll(ctrl.Config.Storage.RootDirectory)
} if err != nil {
panic(err)
}
}(c)
WaitTillServerReady(baseURL)
digest := "sha256:8dd57e171a61368ffcfde38045ddb6ed74a32950c271c1da93eaddfb66a77e78" digest := "sha256:8dd57e171a61368ffcfde38045ddb6ed74a32950c271c1da93eaddfb66a77e78"
name := "zot-c-test" name := "zot-c-test"
@ -2439,25 +2134,10 @@ func TestHTTPReadOnly(t *testing.T) {
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func(controller *api.Controller) {
// this blocks
if err := controller.Run(); err != nil {
return
}
}(c)
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
defer func(controller *api.Controller) { go startServer(c)
ctx := context.Background() defer stopServer(c)
_ = controller.Server.Shutdown(ctx) WaitTillServerReady(baseURL)
}(c)
// with creds, should get expected status code // with creds, should get expected status code
resp, _ := resty.R().SetBasicAuth(user, password).Get(baseURL + "/v2/") resp, _ := resty.R().SetBasicAuth(user, password).Get(baseURL + "/v2/")
@ -2508,36 +2188,17 @@ func TestCrossRepoMount(t *testing.T) {
if err != nil { if err != nil {
panic(err) panic(err)
} }
defer os.RemoveAll(dir) defer os.RemoveAll(dir)
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() { go startServer(c)
// this blocks defer stopServer(c)
if err := c.Run(); err != nil { WaitTillServerReady(baseURL)
return
}
}()
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
params := make(map[string]string) params := make(map[string]string)
digest := "sha256:63a795ca90aa6e7cca60941e826810a4cd0a2e73ea02bf458241df2a5c973e29" digest := "sha256:63a795ca90aa6e7cca60941e826810a4cd0a2e73ea02bf458241df2a5c973e29"
d := godigest.Digest(digest) d := godigest.Digest(digest)
name := "zot-cve-test" name := "zot-cve-test"
params["mount"] = digest params["mount"] = digest
params["from"] = name params["from"] = name
@ -2702,8 +2363,6 @@ func TestCrossRepoMount(t *testing.T) {
c := api.NewController(conf) c := api.NewController(conf)
//defer stopServer(c)
dir, err := ioutil.TempDir("", "oci-repo-test") dir, err := ioutil.TempDir("", "oci-repo-test")
if err != nil { if err != nil {
panic(err) panic(err)
@ -2719,26 +2378,12 @@ func TestCrossRepoMount(t *testing.T) {
c.Config.Storage.Dedupe = false c.Config.Storage.Dedupe = false
c.Config.Storage.GC = false c.Config.Storage.GC = false
go func() { go startServer(c)
// this blocks defer stopServer(c)
if err := c.Run(); err != nil { WaitTillServerReady(baseURL)
return
}
}()
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
digest := "sha256:7a0437f04f83f084b7ed68ad9c4a4947e12fc4e1b006b38129bac89114ec3621" digest := "sha256:7a0437f04f83f084b7ed68ad9c4a4947e12fc4e1b006b38129bac89114ec3621"
name := "zot-c-test" name := "zot-c-test"
client := resty.New() client := resty.New()
headResponse, err := client.R().SetBasicAuth(username, passphrase). headResponse, err := client.R().SetBasicAuth(username, passphrase).
Head(fmt.Sprintf("%s/v2/%s/blobs/%s", baseURL, name, digest)) Head(fmt.Sprintf("%s/v2/%s/blobs/%s", baseURL, name, digest))
@ -2879,25 +2524,10 @@ func TestParallelRequests(t *testing.T) {
subPaths["/b"] = config.StorageConfig{RootDirectory: secondSubDir} subPaths["/b"] = config.StorageConfig{RootDirectory: secondSubDir}
c.Config.Storage.SubPaths = subPaths c.Config.Storage.SubPaths = subPaths
c.Config.Storage.RootDirectory = dir c.Config.Storage.RootDirectory = dir
go func() { go startServer(c)
// this blocks WaitTillServerReady(baseURL)
if err := c.Run(); err != nil {
return
}
}()
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
// without creds, should get access error // without creds, should get access error
for i, testcase := range testCases { for i, testcase := range testCases {
@ -3067,15 +2697,6 @@ func TestParallelRequests(t *testing.T) {
assert.Equal(t, err, nil, "Should not be nil") assert.Equal(t, err, nil, "Should not be nil")
assert.NotEqual(t, getResponse.StatusCode(), 500, "response should return success code") assert.NotEqual(t, getResponse.StatusCode(), 500, "response should return success code")
if i < 5 { // nolint: scopelint
deleteResponse, err := client.R().
SetBasicAuth(username, passphrase).
Delete(baseURL + "/v2/" + testcase.destImageName + "/blobs/sha256:" + blob)
assert.Equal(t, err, nil, "Should not be nil")
assert.Equal(t, deleteResponse.StatusCode(), 202, "response should return success code")
}
} }
tagResponse, err = client.R().SetBasicAuth(username, passphrase). tagResponse, err = client.R().SetBasicAuth(username, passphrase).
@ -3134,27 +2755,11 @@ func TestHardLink(t *testing.T) {
subPaths := make(map[string]config.StorageConfig) subPaths := make(map[string]config.StorageConfig)
subPaths["/a"] = config.StorageConfig{RootDirectory: subDir, Dedupe: true} subPaths["/a"] = config.StorageConfig{RootDirectory: subDir, Dedupe: true}
c.Config.Storage.SubPaths = subPaths c.Config.Storage.SubPaths = subPaths
go func() { go startServer(c)
// this blocks defer stopServer(c)
if err := c.Run(); err != nil { WaitTillServerReady(baseURL)
return
}
}()
time.Sleep(5 * time.Second)
// wait till ready
for {
_, err := resty.R().Get(baseURL)
if err == nil {
break
}
time.Sleep(100 * time.Millisecond)
}
err = os.Chmod(dir, 0644) err = os.Chmod(dir, 0644)
if err != nil { if err != nil {
@ -3244,14 +2849,14 @@ func getAllManifests(imagePath string) []string {
return manifestList return manifestList
} }
func stopServer(ctrl *api.Controller) { func startServer(c *api.Controller) {
err := ctrl.Server.Shutdown(context.Background()) // this blocks
if err != nil { if err := c.Run(); err != nil {
panic(err) return
}
err = os.RemoveAll(ctrl.Config.Storage.RootDirectory)
if err != nil {
panic(err)
} }
} }
func stopServer(c *api.Controller) {
ctx := context.Background()
_ = c.Server.Shutdown(ctx)
}

View File

@ -330,7 +330,7 @@ func TestServerCVEResponse(t *testing.T) {
time.Sleep(100 * time.Millisecond) time.Sleep(100 * time.Millisecond)
} }
time.Sleep(35 * time.Second) time.Sleep(90 * time.Second)
defer func(controller *api.Controller) { defer func(controller *api.Controller) {
ctx := context.Background() ctx := context.Background()

View File

@ -28,7 +28,6 @@ import (
) )
const ( const (
SleepTime = 50 * time.Millisecond
SecondToNanoseconds = 1000000000 SecondToNanoseconds = 1000000000
) )

View File

@ -418,7 +418,7 @@ func TestCVESearch(t *testing.T) {
} }
// Wait for trivy db to download // Wait for trivy db to download
time.Sleep(45 * time.Second) time.Sleep(90 * time.Second)
defer func() { defer func() {
ctx := context.Background() ctx := context.Background()

View File

@ -6,6 +6,7 @@ import (
"io/ioutil" "io/ioutil"
"os" "os"
"path" "path"
"time"
"github.com/phayes/freeport" "github.com/phayes/freeport"
"gopkg.in/resty.v1" "gopkg.in/resty.v1"
@ -14,6 +15,7 @@ import (
const ( const (
BaseURL = "http://127.0.0.1:%s" BaseURL = "http://127.0.0.1:%s"
BaseSecureURL = "https://127.0.0.1:%s" BaseSecureURL = "https://127.0.0.1:%s"
SleepTime = 100 * time.Millisecond
) )
func GetFreePort() string { func GetFreePort() string {
@ -108,3 +110,14 @@ func CopyFiles(sourceDir string, destDir string) error {
return nil return nil
} }
func WaitTillServerReady(url string) {
for {
_, err := resty.R().Get(url)
if err == nil {
break
}
time.Sleep(SleepTime)
}
}