Skip to content

Commit

Permalink
e2e: add openssl e2e test
Browse files Browse the repository at this point in the history
Co-authored-by: Markus Rudy <[email protected]>
  • Loading branch information
msanft and burgerdev committed Feb 23, 2024
1 parent 2f543e3 commit f73e917
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 0 deletions.
1 change: 1 addition & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
"gopls": {
"formatting.gofumpt": true,
},
"go.buildTags": "e2e",
"go.lintTool": "golangci-lint",
"go.lintFlags": [
"--fast",
Expand Down
47 changes: 47 additions & 0 deletions e2e/openssl/openssl_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
//go:build e2e
// +build e2e

package openssl

import (
"context"
"os"
"testing"
"time"

"github.com/edgelesssys/nunki/e2e/internal/kubeclient"
"github.com/stretchr/testify/require"
)

// namespace the tests are executed in.
const namespaceEnv = "K8S_NAMESPACE"

// TestOpenssl verifies that the certificates minted by the coordinator are accepted by OpenSSL in server and client mode.
//
// The test expects deployments/openssl to be available in the cluster (manifest set and workloads ready).
func TestOpenSSL(t *testing.T) {
require := require.New(t)

ctx, cancel := context.WithTimeout(context.Background(), 1*time.Minute)
defer cancel()

c := kubeclient.NewForTest(t)

namespace := os.Getenv(namespaceEnv)
require.NotEmpty(namespace, "environment variable %q must be set", namespaceEnv)

frontendPods, err := c.PodsFromDeployment(context.Background(), namespace, "openssl-frontend")
require.NoError(err)
require.Len(frontendPods, 1, "pod not found: %s/%s", namespace, "openssl-frontend")

// Call the backend server from the frontend. If this command produces no TLS error, we verified that
// - the certificate in the frontend pod can be used as a client certificate
// - the certificate in the backend pod can be used as a server certificate
// - the backend's CA configuration accepted the frontend certificate
// - the frontend's CA configuration accepted the backend certificate
stdout, stderr, err := c.Exec(ctx, namespace, frontendPods[0].Name,
[]string{"/bin/bash", "-c", `printf "GET / HTTP/1.0\nHost: openssl-backend\n" | openssl s_client -connect openssl-backend:443 -verify_return_error -CAfile /tls-config/MeshCACert.pem -cert /tls-config/certChain.pem -key /tls-config/key.pem`},
)
t.Log(stdout)
require.NoError(err, "stderr: %q", stderr)
}

0 comments on commit f73e917

Please sign in to comment.