Skip to content

Commit

Permalink
Add test for policy
Browse files Browse the repository at this point in the history
  • Loading branch information
alpeb committed May 24, 2024
1 parent c84ce35 commit b98408d
Show file tree
Hide file tree
Showing 3 changed files with 76 additions and 11 deletions.
49 changes: 41 additions & 8 deletions test/integration/deep/dualstack/dualstack_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"context"
"encoding/json"
"fmt"
"io"
"os"
"strings"
"testing"
Expand Down Expand Up @@ -56,15 +57,16 @@ func TestDualStack(t *testing.T) {
checkPods(t, ns, "ipfamilies-server")
checkPods(t, ns, "client")

var ipv4, ipv6 string
var clientIPv6, serverIPv4, serverIPv6 string

t.Run("Retrieve pod IPs", func(t *testing.T) {
out, err = TestHelper.Kubectl("",
cmd := []string{
"get", "po",
"-l", "app.kubernetes.io/name=ipfamilies-server",
"-o", "jsonpath='{.items[*].status.podIPs}'",
"-n", ns,
)
}

out, err = TestHelper.Kubectl("", append(cmd, "-l", "app=server")...)
if err != nil {
testutil.AnnotatedFatalf(t, "unexpected error", "unexpected error: %v\noutput:\n%s", err, out)
}
Expand All @@ -77,8 +79,39 @@ func TestDualStack(t *testing.T) {
if len(IPs) != 2 {
testutil.AnnotatedFatalf(t, "unexpected number of IPs", "expected 2 IPs, got %s", fmt.Sprint(len(IPs)))
}
ipv4 = IPs[0].IP
ipv6 = IPs[1].IP
serverIPv4 = IPs[0].IP
serverIPv6 = IPs[1].IP

out, err = TestHelper.Kubectl("", append(cmd, "-l", "app=client")...)
if err != nil {
testutil.AnnotatedFatalf(t, "unexpected error", "unexpected error: %v\noutput:\n%s", err, out)
}

out = strings.Trim(out, "'")
if err = json.Unmarshal([]byte(out), &IPs); err != nil {
testutil.AnnotatedFatalf(t, "error unmarshaling JSON", "error unmarshaling JSON '%s': %s", out, err)
}
if len(IPs) != 2 {
testutil.AnnotatedFatalf(t, "unexpected number of IPs", "expected 2 IPs, got %s", fmt.Sprint(len(IPs)))
}
clientIPv6 = IPs[1].IP
})

t.Run("Apply policy", func(t *testing.T) {
file, err := os.Open("testdata/ipfamilies-policy.yml")
if err != nil {
testutil.AnnotatedFatalf(t, "unexpected error", "unexpected error: %v", err)
}
defer file.Close()
manifest, err := io.ReadAll(file)
if err != nil {
testutil.AnnotatedFatalf(t, "unexpected error", "unexpected error: %v", err)
}
in := strings.ReplaceAll(string(manifest), "{IPv6}", clientIPv6)
out, err = TestHelper.KubectlApply(in, ns)
if err != nil {
testutil.AnnotatedFatalf(t, "unexpected error", "unexpected error: %v\noutput:\n%s", err, out)
}
})

t.Run("Hit IPv4 addr directly", func(t *testing.T) {
Expand All @@ -87,7 +120,7 @@ func TestDualStack(t *testing.T) {
"-c", "curl",
"-n", ns,
"--",
"curl", "-s", "http://"+ipv4+":8080",
"curl", "-s", "http://"+serverIPv4+":8080",
)
if err != nil {
testutil.AnnotatedFatalf(t, "unexpected error", "unexpected error: %v\noutput:\n%s", err, out)
Expand All @@ -103,7 +136,7 @@ func TestDualStack(t *testing.T) {
"-c", "curl",
"-n", ns,
"--",
"curl", "-s", "http://["+ipv6+"]:8080",
"curl", "-s", "http://["+serverIPv6+"]:8080",
)
if err != nil {
testutil.AnnotatedFatalf(t, "unexpected error", "unexpected error: %v\noutput:\n%s", err, out)
Expand Down
32 changes: 32 additions & 0 deletions test/integration/deep/dualstack/testdata/ipfamilies-policy.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
apiVersion: policy.linkerd.io/v1beta2
kind: Server
metadata:
name: ipfamilies
spec:
podSelector:
matchLabels:
app.kubernetes.io/name: ipfamilies-server
port: http
proxyProtocol: HTTP/1
---
apiVersion: policy.linkerd.io/v1alpha1
kind: AuthorizationPolicy
metadata:
name: ipfamilies
spec:
targetRef:
group: policy.linkerd.io
kind: Server
name: ipfamilies
requiredAuthenticationRefs:
- name: ipfamilies
kind: NetworkAuthentication
group: policy.linkerd.io
---
apiVersion: policy.linkerd.io/v1alpha1
kind: NetworkAuthentication
metadata:
name: ipfamilies
spec:
networks:
- cidr: {IPv6}/128
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,13 @@ metadata:
spec:
selector:
matchLabels:
app.kubernetes.io/name: ipfamilies-server
app: server
template:
metadata:
annotations:
linkerd.io/inject: enabled
labels:
app.kubernetes.io/name: ipfamilies-server
app: server
spec:
containers:
- image: ghcr.io/alpeb/family-server:v1
Expand Down Expand Up @@ -48,7 +48,7 @@ spec:
protocol: TCP
targetPort: http
selector:
app.kubernetes.io/name: ipfamilies-server
app: server
type: ClusterIP
---
apiVersion: apps/v1
Expand Down

0 comments on commit b98408d

Please sign in to comment.