2023-06-22 14:29:45 +03:00
|
|
|
package common_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/x509"
|
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
|
|
|
2024-02-01 06:34:07 +02:00
|
|
|
"zotregistry.dev/zot/pkg/common"
|
|
|
|
test "zotregistry.dev/zot/pkg/test/common"
|
2023-06-22 14:29:45 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestHTTPClient(t *testing.T) {
|
|
|
|
Convey("test getTLSConfig()", t, func() {
|
|
|
|
caCertPool, _ := x509.SystemCertPool()
|
|
|
|
tlsConfig, err := common.GetTLSConfig("wrongPath", caCertPool)
|
|
|
|
So(tlsConfig, ShouldBeNil)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
|
|
|
|
tempDir := t.TempDir()
|
2023-08-18 11:46:11 +03:00
|
|
|
err = test.CopyTestKeysAndCerts(tempDir)
|
2023-06-22 14:29:45 +03:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
err = os.Chmod(path.Join(tempDir, "ca.crt"), 0o000)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
_, err = common.GetTLSConfig(tempDir, caCertPool)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("test CreateHTTPClient() no permissions on certificate", t, func() {
|
|
|
|
tempDir := t.TempDir()
|
2023-08-18 11:46:11 +03:00
|
|
|
err := test.CopyTestKeysAndCerts(tempDir)
|
2023-06-22 14:29:45 +03:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
err = os.Chmod(path.Join(tempDir, "ca.crt"), 0o000)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
_, err = common.CreateHTTPClient(true, "localhost", tempDir)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("test CreateHTTPClient() no permissions on key", t, func() {
|
|
|
|
tempDir := t.TempDir()
|
2023-08-18 11:46:11 +03:00
|
|
|
err := test.CopyTestKeysAndCerts(tempDir)
|
2023-06-22 14:29:45 +03:00
|
|
|
So(err, ShouldBeNil)
|
|
|
|
err = os.Chmod(path.Join(tempDir, "client.key"), 0o000)
|
|
|
|
So(err, ShouldBeNil)
|
|
|
|
|
|
|
|
_, err = common.CreateHTTPClient(true, "localhost", tempDir)
|
|
|
|
So(err, ShouldNotBeNil)
|
|
|
|
})
|
|
|
|
}
|