Skip to content

Commit

Permalink
fix(kuma-cp) builtin DNS resolve alias with dots (#2208)
Browse files Browse the repository at this point in the history
Signed-off-by: Jakub Dyszkiewicz <jakub.dyszkiewicz@gmail.com>
  • Loading branch information
jakubdyszkiewicz authored Jun 25, 2021
1 parent b71a7f1 commit 1b941f5
Show file tree
Hide file tree
Showing 21 changed files with 70 additions and 32 deletions.
3 changes: 3 additions & 0 deletions pkg/xds/generator/dns_generator.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
package generator

import (
"strings"

"github.com/asaskevich/govalidator"

mesh_proto "github.com/kumahq/kuma/api/mesh/v1alpha1"
Expand Down Expand Up @@ -52,6 +54,7 @@ func (g DNSGenerator) computeVIPs(ctx xds_context.Context, proxy *core_xds.Proxy
if domain, ok := domainsByIPs[outbound.Address]; ok {
// add regular .mesh domain
meshedVips[domain+"."+ctx.ControlPlane.DNSResolver.GetDomain()] = outbound.Address
meshedVips[strings.ReplaceAll(domain, "_", ".")+"."+ctx.ControlPlane.DNSResolver.GetDomain()] = outbound.Address
// add hostname from address in external service
endpoints := proxy.Routing.OutboundTargets[outbound.Tags[mesh_proto.ServiceTag]]
for _, endpoint := range endpoints {
Expand Down
4 changes: 2 additions & 2 deletions pkg/xds/generator/dns_generator_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,8 @@ var _ = Describe("DNSGenerator", func() {

dnsResolver := resolver.NewDNSResolver("mesh")
dnsResolver.SetVIPs(map[string]string{
"backend": "240.0.0.0",
"httpbin": "240.0.0.1",
"backend_test-ns_svc_8080": "240.0.0.0",
"httpbin": "240.0.0.1",
})
ctx := xds_context.Context{
ConnectionInfo: xds_context.ConnectionInfo{
Expand Down
2 changes: 1 addition & 1 deletion pkg/xds/generator/testdata/dns/1-dataplane.input.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ networking:
- port: 80
address: 240.0.0.0
tags:
kuma.io/service: backend
kuma.io/service: backend_test-ns_svc_8080
- port: 80
address: 240.0.0.1
tags:
Expand Down
8 changes: 7 additions & 1 deletion pkg/xds/generator/testdata/dns/1-envoy-config.golden.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,13 @@ resources:
addressList:
address:
- 240.0.0.0
name: backend.mesh
name: backend.test-ns.svc.8080.mesh
- answerTtl: 30s
endpoint:
addressList:
address:
- 240.0.0.0
name: backend_test-ns_svc_8080.mesh
- answerTtl: 30s
endpoint:
addressList:
Expand Down
1 change: 0 additions & 1 deletion test/e2e/deploy/kuma_deploy_global_zone.go
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,6 @@ spec:

err = NewClusterSetup().
Install(Kuma(core.Zone, optsZone...)).
Install(KumaDNS()).
Install(YamlK8s(namespaceWithSidecarInjection(TestNamespace))).
Install(DemoClientK8s("default")).
Install(EchoServerK8s("default")).
Expand Down
3 changes: 0 additions & 3 deletions test/e2e/externalservices/externalservices_kubernetes.go
Original file line number Diff line number Diff line change
Expand Up @@ -91,9 +91,6 @@ metadata:

// Global
cluster = clusters.GetCluster(Kuma1)
deployOptsFuncs = append(deployOptsFuncs,
WithEnv("KUMA_RUNTIME_KUBERNETES_INJECTOR_BUILTIN_DNS_ENABLED", "true"))

err = NewClusterSetup().
Install(Kuma(core.Standalone, deployOptsFuncs...)).
Install(YamlK8s(namespaceWithSidecarInjection(TestNamespace))).
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ networking:

err = NewClusterSetup().
Install(Kuma(core.Zone, optsZone1...)).
Install(DemoClientUniversal(AppModeDemoClient, defaultMesh, demoClientToken, WithTransparentProxy(true), WithBuiltinDNS(true))).
Install(DemoClientUniversal(AppModeDemoClient, defaultMesh, demoClientToken, WithTransparentProxy(true))).
Setup(zone1)
Expect(err).ToNot(HaveOccurred())
err = zone1.VerifyKuma()
Expand All @@ -104,7 +104,7 @@ networking:

err = NewClusterSetup().
Install(Kuma(core.Zone, optsZone2...)).
Install(DemoClientUniversal(AppModeDemoClient, defaultMesh, demoClientToken, WithTransparentProxy(true), WithBuiltinDNS(true))).
Install(DemoClientUniversal(AppModeDemoClient, defaultMesh, demoClientToken, WithTransparentProxy(true))).
Setup(zone2)
Expect(err).ToNot(HaveOccurred())
err = zone2.VerifyKuma()
Expand Down
2 changes: 1 addition & 1 deletion test/e2e/externalservices/externalservices_universal.go
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ networking:
err = NewClusterSetup().
Install(externalservice.Install(externalservice.HttpServer, externalservice.UniversalAppEchoServer)).
Install(externalservice.Install(externalservice.HttpsServer, externalservice.UniversalAppHttpsEchoServer)).
Install(DemoClientUniversal(AppModeDemoClient, "default", demoClientToken, WithTransparentProxy(true), WithBuiltinDNS(true))).
Install(DemoClientUniversal(AppModeDemoClient, "default", demoClientToken, WithTransparentProxy(true))).
Setup(cluster)
Expect(err).ToNot(HaveOccurred())

Expand Down
1 change: 0 additions & 1 deletion test/e2e/healthcheck/hybrid/healthcheck_hybrid.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,6 @@ metadata:
zoneK8s = k8sClusters.GetCluster(Kuma2)
err = NewClusterSetup().
Install(Kuma(core.Zone, optsZoneK8s...)).
Install(KumaDNS()).
Install(YamlK8s(namespaceWithSidecarInjection(TestNamespace))).
Install(DemoClientK8s("default")).
Setup(zoneK8s)
Expand Down
2 changes: 1 addition & 1 deletion test/e2e/healthcheck/universal/policy_http.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ conf:
Expect(err).ToNot(HaveOccurred())

err = DemoClientUniversal("dp-demo-client", "default", demoClientToken,
WithTransparentProxy(true), WithBuiltinDNS(true))(cluster)
WithTransparentProxy(true))(cluster)
Expect(err).ToNot(HaveOccurred())
err = TestServerUniversal("test-server", "default", testServerToken,
WithArgs([]string{"health-check", "http"}),
Expand Down
2 changes: 1 addition & 1 deletion test/e2e/healthcheck/universal/policy_tcp.go
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ conf:
Expect(err).ToNot(HaveOccurred())

err = DemoClientUniversal("dp-demo-client", "default", demoClientToken,
WithTransparentProxy(true), WithBuiltinDNS(true))(cluster)
WithTransparentProxy(true))(cluster)
Expect(err).ToNot(HaveOccurred())
err = TestServerUniversal("test-server", "default", testServerToken,
WithArgs([]string{"health-check", "tcp"}),
Expand Down
1 change: 0 additions & 1 deletion test/e2e/helm/kuma_helm_deploy_autoscaling.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,6 @@ func ControlPlaneAutoscalingWithHelmChart() {

err = NewClusterSetup().
Install(Kuma(core.Standalone, deployOptsFuncs...)).
Install(KumaDNS()).
Setup(cluster)
Expect(err).ToNot(HaveOccurred())
})
Expand Down
1 change: 0 additions & 1 deletion test/e2e/helm/kuma_helm_deploy_global_zone.go
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,6 @@ metadata:

err = NewClusterSetup().
Install(Kuma(core.Zone, optsZone...)).
Install(KumaDNS()).
Install(YamlK8s(namespaceWithSidecarInjection(TestNamespace))).
Install(DemoClientK8s("default")).
Install(EchoServerK8s("default")).
Expand Down
7 changes: 6 additions & 1 deletion test/e2e/helm/kuma_helm_deploy_multi_apps.go
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,6 @@ metadata:

err = NewClusterSetup().
Install(Kuma(core.Standalone, deployOptsFuncs...)).
Install(KumaDNS()).
Install(YamlK8s(defaultMesh)).
Setup(cluster)
Expect(err).ToNot(HaveOccurred())
Expand Down Expand Up @@ -112,5 +111,11 @@ metadata:
"curl", "-v", "-m", "3", "--fail", "echo-server_kuma-test_svc_80.mesh")
return stderr, err
}, "10s", "1s").Should(ContainSubstring("HTTP/1.1 200 OK"))

Eventually(func() (string, error) { // should access a service with . instead of _
_, stderr, err := cluster.ExecWithRetries(TestNamespace, clientPod.GetName(), "demo-client",
"curl", "-v", "-m", "3", "--fail", "echo-server.kuma-test.svc.80.mesh")
return stderr, err
}, "10s", "1s").Should(ContainSubstring("HTTP/1.1 200 OK"))
})
}
9 changes: 5 additions & 4 deletions test/e2e/hybrid/kuma_hybrid.go
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ metadata:
WithIngress(),
WithGlobalAddress(globalCP.GetKDSServerAddress()),
WithCNI(),
WithEnv("KUMA_RUNTIME_KUBERNETES_INJECTOR_BUILTIN_DNS_ENABLED", "true"))
WithEnv("KUMA_RUNTIME_KUBERNETES_INJECTOR_BUILTIN_DNS_ENABLED", "false")) // check if old resolving still works

err = NewClusterSetup().
Install(Kuma(core.Zone, optsZone1...)).
Expand All @@ -95,7 +95,8 @@ metadata:
zone2 = k8sClusters.GetCluster(Kuma2)
optsZone2 = append(optsZone2,
WithIngress(),
WithGlobalAddress(globalCP.GetKDSServerAddress()))
WithGlobalAddress(globalCP.GetKDSServerAddress()),
WithEnv("KUMA_RUNTIME_KUBERNETES_INJECTOR_BUILTIN_DNS_ENABLED", "false"))

err = NewClusterSetup().
Install(Kuma(core.Zone, optsZone2...)).
Expand All @@ -117,8 +118,8 @@ metadata:

err = NewClusterSetup().
Install(Kuma(core.Zone, optsZone3...)).
Install(EchoServerUniversal(AppModeEchoServer, nonDefaultMesh, "universal", echoServerToken, WithTransparentProxy(true))).
Install(DemoClientUniversal(AppModeDemoClient, nonDefaultMesh, demoClientToken, WithTransparentProxy(true))).
Install(EchoServerUniversal(AppModeEchoServer, nonDefaultMesh, "universal", echoServerToken, WithTransparentProxy(true), WithBuiltinDNS(false))).
Install(DemoClientUniversal(AppModeDemoClient, nonDefaultMesh, demoClientToken, WithTransparentProxy(true), WithBuiltinDNS(false))).
Install(IngressUniversal(ingressTokenKuma3)).
Setup(zone3)
Expect(err).ToNot(HaveOccurred())
Expand Down
7 changes: 5 additions & 2 deletions test/e2e/kic/kubernetes/kong_ingress.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import (
"net/http"
"time"

"github.com/gruntwork-io/terratest/modules/k8s"
"github.com/gruntwork-io/terratest/modules/retry"
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
Expand Down Expand Up @@ -63,18 +64,18 @@ metadata:
Expect(err).ToNot(HaveOccurred())
// Global
kubernetes = k8sClusters.GetCluster(Kuma1)
kubernetesOps = append(kubernetesOps, WithEnv("KUMA_RUNTIME_KUBERNETES_INJECTOR_BUILTIN_DNS_ENABLED", "true"))
err = NewClusterSetup().
Install(Kuma(config_core.Standalone, kubernetesOps...)).
Install(YamlK8s(namespaceWithSidecarInjection(TestNamespace))).
Install(EchoServerK8s("default")).
Install(EchoServerK8sIngress()).
Setup(kubernetes)
Expect(err).ToNot(HaveOccurred())
err = kubernetes.VerifyKuma()
Expect(err).ToNot(HaveOccurred())
})
E2EAfterEach(func() {
err := k8s.RunKubectlE(kubernetes.GetTesting(), kubernetes.GetKubectlOptions(), "delete", "ingress", "--all", "-n", "kuma-test")
Expect(err).ToNot(HaveOccurred())
Expect(kubernetes.DeleteNamespace(ingressNamespace)).To(Succeed())
})
E2EAfterSuite(func() {
Expand All @@ -88,6 +89,7 @@ metadata:
err := NewClusterSetup().
Install(kic.KongIngressController()).
Install(kic.KongIngressNodePort()).
Install(EchoServerK8sIngress()).
Setup(kubernetes)
Expect(err).ToNot(HaveOccurred())

Expand All @@ -109,6 +111,7 @@ metadata:
err := NewClusterSetup().
Install(kic.KongIngressController(kic.WithNamespace(ingressNamespace))).
Install(kic.KongIngressNodePort(kic.WithNamespace(ingressNamespace))).
Install(EchoServerK8sIngressWithMeshDNS()).
Setup(kubernetes)
Expect(err).ToNot(HaveOccurred())

Expand Down
4 changes: 0 additions & 4 deletions test/e2e/tracing/tracing_kubernetes.go
Original file line number Diff line number Diff line change
Expand Up @@ -65,12 +65,8 @@ spec:
c, err := NewK8SCluster(NewTestingT(), Kuma1, Silent)
Expect(err).ToNot(HaveOccurred())
cluster = c
deployOptsFuncs = append(deployOptsFuncs,
WithEnv("KUMA_RUNTIME_KUBERNETES_INJECTOR_BUILTIN_DNS_ENABLED", "true"))

err = NewClusterSetup().
Install(Kuma(core.Standalone, deployOptsFuncs...)).
Install(KumaDNS()).
Install(YamlK8s(namespaceWithSidecarInjection(TestNamespace))).
Install(DemoClientK8s("default")).
Install(EchoServerK8s("default")).
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,6 @@ spec:

err = NewClusterSetup().
Install(Kuma(config_core.Zone, optsZoneKube...)).
Install(KumaDNS()).
Install(YamlK8s(namespaceWithSidecarInjection(TestNamespace))).
Install(DemoClientK8s("default")).
Setup(zoneKube)
Expand Down
4 changes: 2 additions & 2 deletions test/framework/interface.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ type deployOptions struct {
appArgs []string
token string
transparent bool
builtindns bool
builtindns *bool // true by default
protocol string
serviceName string
serviceVersion string
Expand Down Expand Up @@ -251,7 +251,7 @@ func WithTransparentProxy(transparent bool) DeployOptionsFunc {

func WithBuiltinDNS(builtindns bool) DeployOptionsFunc {
return func(o *deployOptions) {
o.builtindns = builtindns
o.builtindns = &builtindns
}
}

Expand Down
31 changes: 31 additions & 0 deletions test/framework/setup.go
Original file line number Diff line number Diff line change
Expand Up @@ -204,6 +204,37 @@ spec:
return YamlK8s(ingress)
}

func EchoServerK8sIngressWithMeshDNS() InstallFunc {
ingress := `
---
apiVersion: v1
kind: Service
metadata:
name: echo-server-externalname
namespace: kuma-test
spec:
type: ExternalName
externalName: echo-server.kuma-test.svc.80.mesh
---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
namespace: kuma-test
name: k8s-ingress-dot-mesh
annotations:
kubernetes.io/ingress.class: kong
spec:
rules:
- http:
paths:
- path: /
backend:
serviceName: echo-server-externalname
servicePort: 80
`
return YamlK8s(ingress)
}

func EchoServerK8s(mesh string) InstallFunc {
const name = "echo-server"
service := `
Expand Down
5 changes: 3 additions & 2 deletions test/framework/universal_cluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -207,8 +207,9 @@ func (c *UniversalCluster) DeployApp(fs ...DeployOptionsFunc) error {
return err
}

builtindns := opts.builtindns == nil || *opts.builtindns
if transparent {
app.setupTransparent(c.apps[AppModeCP].ip, opts.builtindns)
app.setupTransparent(c.apps[AppModeCP].ip, builtindns)
}

ip := app.ip
Expand All @@ -219,7 +220,7 @@ func (c *UniversalCluster) DeployApp(fs ...DeployOptionsFunc) error {
}
}

err = c.CreateDP(app, opts.name, ip, dpyaml, token, opts.builtindns)
err = c.CreateDP(app, opts.name, ip, dpyaml, token, builtindns)
if err != nil {
return err
}
Expand Down

0 comments on commit 1b941f5

Please sign in to comment.