mirror of
https://github.com/project-zot/zot.git
synced 2025-01-27 23:01:43 -05:00
49e8167dbe
- AccessControlContext now resides in a separate package from where it can be imported, along with the contextKey that will be used to set and retrieve this context value. - AccessControlContext has a new field called Username, that will be of use for future implementations in graphQL resolvers. - GlobalSearch resolver now uses this context to filter repos available to the logged user. - moved logic for uploading images in tests so that it can be used in every package - tests were added for multiple request scenarios, when zot-server requires authz on specific repos - added tests with injected errors for extended coverage - added tests for status code error injection utilities Closes https://github.com/project-zot/zot/issues/615 Signed-off-by: Alex Stan <alexandrustan96@yahoo.ro>
153 lines
3.3 KiB
Go
153 lines
3.3 KiB
Go
//go:build dev
|
|
// +build dev
|
|
|
|
// This file should be linked only in **development** mode.
|
|
|
|
package test_test
|
|
|
|
import (
|
|
"errors"
|
|
"testing"
|
|
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
"zotregistry.io/zot/pkg/test"
|
|
)
|
|
|
|
var (
|
|
errKey1 = errors.New("key1 not found")
|
|
errKey2 = errors.New("key2 not found")
|
|
errNotZero = errors.New("not zero")
|
|
errCall1 = errors.New("call1 error")
|
|
errCall2 = errors.New("call2 error")
|
|
)
|
|
|
|
func foo() error {
|
|
fmap := map[string]string{"key1": "val1", "key2": "val2"}
|
|
|
|
_, ok := fmap["key1"] // should never fail
|
|
if !test.Ok(ok) {
|
|
return errKey1
|
|
}
|
|
|
|
_, ok = fmap["key2"] // should never fail
|
|
if !test.Ok(ok) {
|
|
return errKey2
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func errgen(i int) error {
|
|
if i != 0 {
|
|
return errNotZero
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func bar() error {
|
|
err := errgen(0) // should never fail
|
|
if test.Error(err) != nil {
|
|
return errCall1
|
|
}
|
|
|
|
err = errgen(0) // should never fail
|
|
if test.Error(err) != nil {
|
|
return errCall2
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func baz() error {
|
|
if test.ErrStatusCode(0) != 0 {
|
|
return errCall1
|
|
}
|
|
|
|
if test.ErrStatusCode(0) != 0 {
|
|
return errCall2
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func alwaysErr() error {
|
|
return errNotZero
|
|
}
|
|
|
|
func alwaysNotOk() bool {
|
|
return false
|
|
}
|
|
|
|
func TestInject(t *testing.T) {
|
|
Convey("Injected failure", t, func(c C) {
|
|
// should be success without injection
|
|
err := foo()
|
|
So(err, ShouldBeNil)
|
|
|
|
Convey("Check Ok", func() {
|
|
Convey("Without skipping", func() {
|
|
test.InjectFailure(0) // inject a failure
|
|
err := foo() // should be a failure
|
|
So(err, ShouldNotBeNil) // should be a failure
|
|
So(errors.Is(err, errKey1), ShouldBeTrue)
|
|
})
|
|
|
|
Convey("With skipping", func() {
|
|
test.InjectFailure(1) // inject a failure but skip first one
|
|
err := foo() // should be a failure
|
|
So(errors.Is(err, errKey1), ShouldBeFalse)
|
|
So(errors.Is(err, errKey2), ShouldBeTrue)
|
|
})
|
|
})
|
|
|
|
// should be success without injection
|
|
err = bar()
|
|
So(err, ShouldBeNil)
|
|
|
|
Convey("Check Err", func() {
|
|
Convey("Without skipping", func() {
|
|
test.InjectFailure(0) // inject a failure
|
|
err := bar() // should be a failure
|
|
So(err, ShouldNotBeNil) // should be a failure
|
|
So(errors.Is(err, errCall1), ShouldBeTrue)
|
|
})
|
|
|
|
Convey("With skipping", func() {
|
|
test.InjectFailure(1) // inject a failure but skip first one
|
|
err := bar() // should be a failure
|
|
So(errors.Is(err, errCall1), ShouldBeFalse)
|
|
So(errors.Is(err, errCall2), ShouldBeTrue)
|
|
})
|
|
})
|
|
|
|
Convey("Check ErrStatusCode", func() {
|
|
Convey("Without skipping", func() {
|
|
test.InjectFailure(0) // inject a failure
|
|
err := baz() // should be a failure
|
|
So(err, ShouldNotBeNil) // should be a failure
|
|
So(errors.Is(err, errCall1), ShouldBeTrue)
|
|
})
|
|
|
|
Convey("With skipping", func() {
|
|
test.InjectFailure(1) // inject a failure but skip first one
|
|
err := baz() // should be a failure
|
|
So(errors.Is(err, errCall1), ShouldBeFalse)
|
|
So(errors.Is(err, errCall2), ShouldBeTrue)
|
|
})
|
|
})
|
|
})
|
|
|
|
Convey("Without injected failure", t, func(c C) {
|
|
err := alwaysErr()
|
|
So(test.Error(err), ShouldNotBeNil)
|
|
|
|
ok := alwaysNotOk()
|
|
So(test.Ok(ok), ShouldBeFalse)
|
|
})
|
|
|
|
Convey("Incomplete injected failure", t, func(c C) {
|
|
test.InjectFailure(0) // inject a failure
|
|
So(func() { test.InjectFailure(0) }, ShouldPanic)
|
|
})
|
|
}
|