Skip to content

Commit

Permalink
feat (dns) : Add host.crc.testing to /etc/hosts (#4410)
Browse files Browse the repository at this point in the history
+ Add another method `GetHostName()` to CrcBundleInfo struct in order to
  provide host domain
+ Use abovementioned method in `dns.addOpenShiftHosts` in order to add
  another dns entry for `host.crc.testing`

Signed-off-by: Rohan Kumar <rohaan@redhat.com>
  • Loading branch information
rohanKanojia committed Nov 20, 2024
1 parent 8e5c7be commit 5c91517
Show file tree
Hide file tree
Showing 4 changed files with 60 additions and 2 deletions.
4 changes: 4 additions & 0 deletions pkg/crc/machine/bundle/metadata.go
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,10 @@ func (bundle *CrcBundleInfo) GetAPIHostname() string {
return fmt.Sprintf("api.%s.%s", bundle.ClusterInfo.ClusterName, bundle.ClusterInfo.BaseDomain)
}

func (bundle *CrcBundleInfo) GetHostname() string {
return fmt.Sprintf("host.%s.%s", bundle.ClusterInfo.ClusterName, bundle.ClusterInfo.BaseDomain)
}

func (bundle *CrcBundleInfo) GetAppHostname(appName string) string {
return fmt.Sprintf("%s.%s", appName, bundle.ClusterInfo.AppsDomain)
}
Expand Down
8 changes: 8 additions & 0 deletions pkg/crc/machine/bundle/metadata_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -289,3 +289,11 @@ func TestGetBundleInfoFromNameInvalid(t *testing.T) {
_, err = GetBundleInfoFromName("crc_nanoshift_libvirt_4.16.7_amd64_232.crcbundle")
assert.Error(t, err)
}

func TestGetHostName(t *testing.T) {
// Given
// When
hostName := parsedReference.GetHostname()
// Then
assert.Equal(t, "host.crc.testing", hostName)
}
12 changes: 10 additions & 2 deletions pkg/crc/services/dns/dns.go
Original file line number Diff line number Diff line change
Expand Up @@ -205,10 +205,18 @@ func matchIP(ips []net.IP, expectedIP string) bool {
}

func addOpenShiftHosts(serviceConfig services.ServicePostStartConfig) error {
return adminhelper.UpdateHostsFile(serviceConfig.IP, serviceConfig.BundleMetadata.GetAPIHostname(),
hostnames := getApplicableHostnames(serviceConfig)
return adminhelper.UpdateHostsFile(serviceConfig.IP, hostnames...)
}

func getApplicableHostnames(serviceConfig services.ServicePostStartConfig) []string {
return []string{
serviceConfig.BundleMetadata.GetAPIHostname(),
serviceConfig.BundleMetadata.GetHostname(),
serviceConfig.BundleMetadata.GetAppHostname("oauth-openshift"),
serviceConfig.BundleMetadata.GetAppHostname("console-openshift-console"),
serviceConfig.BundleMetadata.GetAppHostname("downloads-openshift-console"),
serviceConfig.BundleMetadata.GetAppHostname("canary-openshift-ingress-canary"),
serviceConfig.BundleMetadata.GetAppHostname("default-route-openshift-image-registry"))
serviceConfig.BundleMetadata.GetAppHostname("default-route-openshift-image-registry"),
}
}
38 changes: 38 additions & 0 deletions pkg/crc/services/dns/dns_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
package dns

import (
"testing"

"github.com/Masterminds/semver/v3"
"github.com/crc-org/crc/v2/pkg/crc/machine/bundle"
"github.com/crc-org/crc/v2/pkg/crc/services"
"github.com/stretchr/testify/assert"
)

func TestGetApplicableHostnames(t *testing.T) {
// Given
bundleMetadata := services.ServicePostStartConfig{
BundleMetadata: bundle.CrcBundleInfo{
ClusterInfo: bundle.ClusterInfo{
OpenShiftVersion: semver.MustParse("4.6.1"),
ClusterName: "crc",
BaseDomain: "testing",
AppsDomain: "apps.crc.testing",
SSHPrivateKeyFile: "id_ecdsa_crc",
KubeConfig: "kubeconfig",
},
},
}
// When
hostnames := getApplicableHostnames(bundleMetadata)
// Then
assert.Equal(t, []string{
"api.crc.testing",
"host.crc.testing",
"oauth-openshift.apps.crc.testing",
"console-openshift-console.apps.crc.testing",
"downloads-openshift-console.apps.crc.testing",
"canary-openshift-ingress-canary.apps.crc.testing",
"default-route-openshift-image-registry.apps.crc.testing",
}, hostnames)
}

0 comments on commit 5c91517

Please sign in to comment.