From de25bb8744edbf1d9e90bbe17b3b888139437d29 Mon Sep 17 00:00:00 2001 From: Karl Johan Grahn <6355577+karl-johan-grahn@users.noreply.github.com> Date: Tue, 17 Dec 2024 17:17:28 +0100 Subject: [PATCH] Fix incorrect encoding of health endpoint (#618) * Fix incorrect encoding of health endpoint --- .github/workflows/pull_request.yml | 23 --------- .github/workflows/pull_request_test.yaml | 61 ++++++++++++++++++++++++ pkg/kube/wrappers/routeWrapper.go | 7 ++- pkg/kube/wrappers/routeWrapper_test.go | 8 ++++ 4 files changed, 75 insertions(+), 24 deletions(-) create mode 100644 .github/workflows/pull_request_test.yaml diff --git a/.github/workflows/pull_request.yml b/.github/workflows/pull_request.yml index df40f1c7..eb68533b 100644 --- a/.github/workflows/pull_request.yml +++ b/.github/workflows/pull_request.yml @@ -14,7 +14,6 @@ env: DOCKER_FILE_PATH: Dockerfile GOLANG_VERSION: 1.21 HELM_VERSION: v3.8.2 - KIND_VERSION: "v0.17.0" REGISTRY: ghcr.io jobs: @@ -50,27 +49,6 @@ jobs: run: | helm lint charts/ingressmonitorcontroller - # - name: Install kind - # uses: engineerd/setup-kind@v0.5.0 - # with: - # version: ${{ env.KIND_VERSION }} - - # - name: Check cluster info - # run: | - # kubectl version --client - # kind version - # kind version | grep -q ${KIND_VERSION} - - # - name: Set up Cluster - # run: | - # kubectl cluster-info - # make install - # mkdir -p .local - # echo "${{ secrets.IMC_GITHUB_PIPELINE_CONFIG_ENCODED }}" | base64 --decode > .local/test-config.yaml - - # - name: Test - # run: make test - - name: Generate Tag id: generate_tag run: | @@ -107,5 +85,4 @@ jobs: ${{ env.GHCR_IMAGE_REPOSITORY }}:${{ steps.generate_tag.outputs.GIT_TAG }} labels: | org.opencontainers.image.source=${{ github.event.repository.clone_url }} - org.opencontainers.image.created=${{ steps.prep.outputs.created }} org.opencontainers.image.revision=${{ github.sha }} diff --git a/.github/workflows/pull_request_test.yaml b/.github/workflows/pull_request_test.yaml new file mode 100644 index 00000000..ce142aec --- /dev/null +++ b/.github/workflows/pull_request_test.yaml @@ -0,0 +1,61 @@ +name: Run Tests on PR Label + +on: + pull_request: + branches: + - 'master' + paths-ignore: + - '*.md' + - 'docs/' + - 'examples/' + - 'hack/' + - 'config/' + types: [ labeled ] + +env: + KIND_VERSION: "v0.25.0" + GOLANG_VERSION: 1.21 + +jobs: + + test: + runs-on: ubuntu-latest + name: Test + if: ${{ github.event.label.name == 'ok-to-test' }} + steps: + + - name: Remove the test label + uses: actions-ecosystem/action-remove-labels@v1 + with: + labels: ok-to-test + + - name: Check out code + uses: actions/checkout@v4 + with: + ref: ${{github.event.pull_request.head.sha}} + + - name: Set up Go + uses: actions/setup-go@v5 + with: + go-version: ${{ env.GOLANG_VERSION }} + + - name: Install kind + uses: engineerd/setup-kind@v0.5.0 + with: + version: ${{ env.KIND_VERSION }} + + - name: Check cluster info + run: | + kubectl version --client + kind version + kind version | grep -q ${KIND_VERSION} + + - name: Set up Cluster + run: | + kubectl cluster-info + make install + mkdir -p .local + echo "${{ secrets.IMC_GITHUB_PIPELINE_CONFIG_ENCODED }}" | base64 --decode > .local/test-config.yaml + + - name: Test + run: make test diff --git a/pkg/kube/wrappers/routeWrapper.go b/pkg/kube/wrappers/routeWrapper.go index 72342dd9..4ab47192 100644 --- a/pkg/kube/wrappers/routeWrapper.go +++ b/pkg/kube/wrappers/routeWrapper.go @@ -129,5 +129,10 @@ func (rw *RouteWrapper) GetURL(forceHttps bool, healthEndpoint string) string { u.Path = path.Join(u.Path, healthEndpoint) } } - return u.String() + path, err := url.PathUnescape(u.String()) + if err != nil { + log.Info(fmt.Sprintf("Error in unescaping path :%v", err)) + return "" + } + return path } diff --git a/pkg/kube/wrappers/routeWrapper_test.go b/pkg/kube/wrappers/routeWrapper_test.go index cfd5fee4..d06c16df 100644 --- a/pkg/kube/wrappers/routeWrapper_test.go +++ b/pkg/kube/wrappers/routeWrapper_test.go @@ -53,6 +53,14 @@ func TestRouteWrapper_getURL(t *testing.T) { }, want: "http://testurl.stackator.com/hello", }, + { + name: "TestGetUrlWithParams", + fields: fields{ + route: createRouteObjectWithPath("testRoute", "test", routeTestUrl, "/health?standbyok=true&sealedcode=204&uninitcode=204"), + Client: fakekubeclient.NewClientBuilder().Build(), + }, + want: "http://testurl.stackator.com/health?standbyok=true&sealedcode=204&uninitcode=204", + }, { name: "TestGetUrlWithNoPath", fields: fields{