diff --git a/frontend/cypress.config.ts b/frontend/cypress.config.ts index 5b8a83b1..1ef916df 100644 --- a/frontend/cypress.config.ts +++ b/frontend/cypress.config.ts @@ -7,4 +7,10 @@ export default defineConfig({ bundler: "vite", }, }, -}); \ No newline at end of file + + e2e: { + setupNodeEvents(on, config) { + // implement node event listeners here + }, + }, +}); diff --git a/frontend/cypress/e2e/addRepository.cy.ts b/frontend/cypress/e2e/addRepository.cy.ts new file mode 100644 index 00000000..efb7465c --- /dev/null +++ b/frontend/cypress/e2e/addRepository.cy.ts @@ -0,0 +1,53 @@ +describe("Adding repository flow", () => { + const addChartNameInput = "[data-cy='add-chart-name']"; + const addChartUrlInput = "[data-cy='add-chart-url']"; + const addChartRepositoryButton = "[data-cy='add-chart-repository-button']"; + + it("Adding new chart repository", () => { + cy.intercept("GET", "http://localhost:5173/status", { + fixture: "status.json", + }).as("status"); + + cy.intercept("GET", "http://localhost:5173/api/helm/releases", { + fixture: "releases.json", + }).as("releases"); + + cy.visit( + "http://localhost:5173/#/minikube/installed?filteredNamespace=default" + ); + + cy.get("[data-cy='navigation-link']").contains("Repository").click(); + cy.get("[data-cy='install-repository-button']").click(); + + cy.get(addChartNameInput).type("Komodorio"); + cy.get(addChartUrlInput).type("https://helm-charts.komodor.io"); + + cy.intercept("GET", "http://localhost:5173/api/helm/repositories", { + fixture: "repositories.json", + }).as("repositories"); + + cy.get(addChartRepositoryButton).click(); + + cy.contains("https://helm-charts.komodor.io"); + + cy.get("[data-cy='chart-viewer-install-button']") + .eq(0) + .click({ force: true }) + .contains("Install") + .click(); + + cy.intercept("POST", "http://localhost:5173/api/helm/releases/default", { + fixture: "defaultReleases.json", + }).as("defaultReleases"); + + cy.intercept( + "GET", + "http://localhost:5173/api/helm/releases/default/helm-dashboard/history", + { fixture: "history.json" } + ).as("history"); + + cy.contains("Confirm").click(); + + cy.wait(["@defaultReleases", "@history"]); + }); +}); diff --git a/frontend/cypress/fixtures/defaultReleases.json b/frontend/cypress/fixtures/defaultReleases.json new file mode 100644 index 00000000..9a352775 --- /dev/null +++ b/frontend/cypress/fixtures/defaultReleases.json @@ -0,0 +1,190 @@ +{ + "name":"helm-dashboard", + "info":{ + "first_deployed":"2024-01-17T22:25:14.933425+02:00", + "last_deployed":"2024-01-17T22:25:14.933425+02:00", + "deleted":"", + "description":"Install complete", + "status":"deployed", + "notes":"Thank you for installing Helm Dashboard.\nHelm Dashboard can be accessed:\n * Within your cluster, at the following DNS name at port 8080:\n\n helm-dashboard.default.svc.cluster.local\n\n * From outside the cluster, run these commands in the same shell:\n\n export POD_NAME=$(kubectl get pods --namespace default -l \"app.kubernetes.io/name=helm-dashboard,app.kubernetes.io/instance=helm-dashboard\" -o jsonpath=\"{.items[0].metadata.name}\")\n export CONTAINER_PORT=$(kubectl get pod --namespace default $POD_NAME -o jsonpath=\"{.spec.containers[0].ports[0].containerPort}\")\n echo \"Visit http://127.0.0.1:8080 to use your application\"\n kubectl --namespace default port-forward $POD_NAME 8080:$CONTAINER_PORT\n\nVisit our repo at:\nhttps://github.com/komodorio/helm-dashboard\n\n" + }, + "chart":{ + "metadata":{ + "name":"helm-dashboard", + "version":"0.1.10", + "description":"A GUI Dashboard for Helm by Komodor", + "icon":"https://raw.githubusercontent.com/komodorio/helm-dashboard/main/pkg/dashboard/static/logo.svg", + "apiVersion":"v2", + "appVersion":"1.3.3", + "type":"application" + }, + "lock":null, + "templates":[ + { + "name":"templates/NOTES.txt", + "data":"VGhhbmsgeW91IGZvciBpbnN0YWxsaW5nIEhlbG0gRGFzaGJvYXJkLgpIZWxtIERhc2hib2FyZCBjYW4gYmUgYWNjZXNzZWQ6CiAgKiBXaXRoaW4geW91ciBjbHVzdGVyLCBhdCB0aGUgZm9sbG93aW5nIEROUyBuYW1lIGF0IHBvcnQge3sgLlZhbHVlcy5zZXJ2aWNlLnBvcnQgfX06CgogICAge3sgdGVtcGxhdGUgImhlbG0tZGFzaGJvYXJkLmZ1bGxuYW1lIiAuIH19Lnt7IC5SZWxlYXNlLk5hbWVzcGFjZSB9fS5zdmMuY2x1c3Rlci5sb2NhbAoKICAqIEZyb20gb3V0c2lkZSB0aGUgY2x1c3RlciwgcnVuIHRoZXNlIGNvbW1hbmRzIGluIHRoZSBzYW1lIHNoZWxsOgoKICAgIGV4cG9ydCBQT0RfTkFNRT0kKGt1YmVjdGwgZ2V0IHBvZHMgLS1uYW1lc3BhY2Uge3sgLlJlbGVhc2UuTmFtZXNwYWNlIH19IC1sICJhcHAua3ViZXJuZXRlcy5pby9uYW1lPXt7IGluY2x1ZGUgImhlbG0tZGFzaGJvYXJkLm5hbWUiIC4gfX0sYXBwLmt1YmVybmV0ZXMuaW8vaW5zdGFuY2U9e3sgLlJlbGVhc2UuTmFtZSB9fSIgLW8ganNvbnBhdGg9InsuaXRlbXNbMF0ubWV0YWRhdGEubmFtZX0iKQogICAgZXhwb3J0IENPTlRBSU5FUl9QT1JUPSQoa3ViZWN0bCBnZXQgcG9kIC0tbmFtZXNwYWNlIHt7IC5SZWxlYXNlLk5hbWVzcGFjZSB9fSAkUE9EX05BTUUgLW8ganNvbnBhdGg9Insuc3BlYy5jb250YWluZXJzWzBdLnBvcnRzWzBdLmNvbnRhaW5lclBvcnR9IikKICAgIGVjaG8gIlZpc2l0IGh0dHA6Ly8xMjcuMC4wLjE6ODA4MCB0byB1c2UgeW91ciBhcHBsaWNhdGlvbiIKICAgIGt1YmVjdGwgLS1uYW1lc3BhY2Uge3sgLlJlbGVhc2UuTmFtZXNwYWNlIH19IHBvcnQtZm9yd2FyZCAkUE9EX05BTUUgODA4MDokQ09OVEFJTkVSX1BPUlQKClZpc2l0IG91ciByZXBvIGF0OgpodHRwczovL2dpdGh1Yi5jb20va29tb2RvcmlvL2hlbG0tZGFzaGJvYXJkCgo=" + }, + { + "name":"templates/_helpers.tpl", + "data":"e3svKgpFeHBhbmQgdGhlIG5hbWUgb2YgdGhlIGNoYXJ0LgoqL319Cnt7LSBkZWZpbmUgImhlbG0tZGFzaGJvYXJkLm5hbWUiIC19fQp7ey0gZGVmYXVsdCAuQ2hhcnQuTmFtZSAuVmFsdWVzLm5hbWVPdmVycmlkZSB8IHRydW5jIDYzIHwgdHJpbVN1ZmZpeCAiLSIgfX0Ke3stIGVuZCB9fQoKe3svKgpDcmVhdGUgYSBkZWZhdWx0IGZ1bGx5IHF1YWxpZmllZCBhcHAgbmFtZS4KV2UgdHJ1bmNhdGUgYXQgNjMgY2hhcnMgYmVjYXVzZSBzb21lIEt1YmVybmV0ZXMgbmFtZSBmaWVsZHMgYXJlIGxpbWl0ZWQgdG8gdGhpcyAoYnkgdGhlIEROUyBuYW1pbmcgc3BlYykuCklmIHJlbGVhc2UgbmFtZSBjb250YWlucyBjaGFydCBuYW1lIGl0IHdpbGwgYmUgdXNlZCBhcyBhIGZ1bGwgbmFtZS4KKi99fQp7ey0gZGVmaW5lICJoZWxtLWRhc2hib2FyZC5mdWxsbmFtZSIgLX19Cnt7LSBpZiAuVmFsdWVzLmZ1bGxuYW1lT3ZlcnJpZGUgfX0Ke3stIC5WYWx1ZXMuZnVsbG5hbWVPdmVycmlkZSB8IHRydW5jIDYzIHwgdHJpbVN1ZmZpeCAiLSIgfX0Ke3stIGVsc2UgfX0Ke3stICRuYW1lIDo9IGRlZmF1bHQgLkNoYXJ0Lk5hbWUgLlZhbHVlcy5uYW1lT3ZlcnJpZGUgfX0Ke3stIGlmIGNvbnRhaW5zICRuYW1lIC5SZWxlYXNlLk5hbWUgfX0Ke3stIC5SZWxlYXNlLk5hbWUgfCB0cnVuYyA2MyB8IHRyaW1TdWZmaXggIi0iIH19Cnt7LSBlbHNlIH19Cnt7LSBwcmludGYgIiVzLSVzIiAuUmVsZWFzZS5OYW1lICRuYW1lIHwgdHJ1bmMgNjMgfCB0cmltU3VmZml4ICItIiB9fQp7ey0gZW5kIH19Cnt7LSBlbmQgfX0Ke3stIGVuZCB9fQoKe3svKgpDcmVhdGUgY2hhcnQgbmFtZSBhbmQgdmVyc2lvbiBhcyB1c2VkIGJ5IHRoZSBjaGFydCBsYWJlbC4KKi99fQp7ey0gZGVmaW5lICJoZWxtLWRhc2hib2FyZC5jaGFydCIgLX19Cnt7LSBwcmludGYgIiVzLSVzIiAuQ2hhcnQuTmFtZSAuQ2hhcnQuVmVyc2lvbiB8IHJlcGxhY2UgIisiICJfIiB8IHRydW5jIDYzIHwgdHJpbVN1ZmZpeCAiLSIgfX0Ke3stIGVuZCB9fQoKe3svKgpDb21tb24gbGFiZWxzCiovfX0Ke3stIGRlZmluZSAiaGVsbS1kYXNoYm9hcmQubGFiZWxzIiAtfX0KaGVsbS5zaC9jaGFydDoge3sgaW5jbHVkZSAiaGVsbS1kYXNoYm9hcmQuY2hhcnQiIC4gfX0Ke3sgaW5jbHVkZSAiaGVsbS1kYXNoYm9hcmQuc2VsZWN0b3JMYWJlbHMiIC4gfX0Ke3stIGlmIC5DaGFydC5BcHBWZXJzaW9uIH19CmFwcC5rdWJlcm5ldGVzLmlvL3ZlcnNpb246IHt7IC5DaGFydC5BcHBWZXJzaW9uIHwgcXVvdGUgfX0Ke3stIGVuZCB9fQphcHAua3ViZXJuZXRlcy5pby9tYW5hZ2VkLWJ5OiB7eyAuUmVsZWFzZS5TZXJ2aWNlIH19Cnt7LSBlbmQgfX0KCnt7LyoKU2VsZWN0b3IgbGFiZWxzCiovfX0Ke3stIGRlZmluZSAiaGVsbS1kYXNoYm9hcmQuc2VsZWN0b3JMYWJlbHMiIC19fQphcHAua3ViZXJuZXRlcy5pby9uYW1lOiB7eyBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5uYW1lIiAuIH19CmFwcC5rdWJlcm5ldGVzLmlvL2luc3RhbmNlOiB7eyAuUmVsZWFzZS5OYW1lIH19Cnt7LSBlbmQgfX0KCnt7LyoKQ3JlYXRlIHRoZSBuYW1lIG9mIHRoZSBzZXJ2aWNlIGFjY291bnQgdG8gdXNlCiovfX0Ke3stIGRlZmluZSAiaGVsbS1kYXNoYm9hcmQuc2VydmljZUFjY291bnROYW1lIiAtfX0Ke3stIGlmIC5WYWx1ZXMuc2VydmljZUFjY291bnQuY3JlYXRlIH19Cnt7LSBkZWZhdWx0IChpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5mdWxsbmFtZSIgLikgLlZhbHVlcy5zZXJ2aWNlQWNjb3VudC5uYW1lIH19Cnt7LSBlbHNlIH19Cnt7LSBkZWZhdWx0ICJkZWZhdWx0IiAuVmFsdWVzLnNlcnZpY2VBY2NvdW50Lm5hbWUgfX0Ke3stIGVuZCB9fQp7ey0gZW5kIH19Cg==" + }, + { + "name":"templates/deployment.yaml", + "data":"YXBpVmVyc2lvbjogYXBwcy92MQpraW5kOiBEZXBsb3ltZW50Cm1ldGFkYXRhOgogIG5hbWU6IHt7IGluY2x1ZGUgImhlbG0tZGFzaGJvYXJkLmZ1bGxuYW1lIiAuIH19CiAgbGFiZWxzOgogICAge3stIGluY2x1ZGUgImhlbG0tZGFzaGJvYXJkLmxhYmVscyIgLiB8IG5pbmRlbnQgNCB9fQpzcGVjOgogIHt7LSBpZiBub3QgLlZhbHVlcy5hdXRvc2NhbGluZy5lbmFibGVkIH19CiAgcmVwbGljYXM6IHt7IC5WYWx1ZXMucmVwbGljYUNvdW50IH19CiAge3stIGVuZCB9fQogIHNlbGVjdG9yOgogICAgbWF0Y2hMYWJlbHM6CiAgICAgIHt7LSBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5zZWxlY3RvckxhYmVscyIgLiB8IG5pbmRlbnQgNiB9fQogIHN0cmF0ZWd5OiB7ey0gdG9ZYW1sIC5WYWx1ZXMudXBkYXRlU3RyYXRlZ3kgfCBuaW5kZW50IDQgfX0KICB0ZW1wbGF0ZToKICAgIG1ldGFkYXRhOgogICAgICB7ey0gd2l0aCAuVmFsdWVzLnBvZEFubm90YXRpb25zIH19CiAgICAgIGFubm90YXRpb25zOgogICAgICAgIHt7LSB0b1lhbWwgLiB8IG5pbmRlbnQgOCB9fQogICAgICB7ey0gZW5kIH19CiAgICAgIGxhYmVsczoKICAgICAgICB7ey0gaW5jbHVkZSAiaGVsbS1kYXNoYm9hcmQuc2VsZWN0b3JMYWJlbHMiIC4gfCBuaW5kZW50IDggfX0KICAgIHNwZWM6CiAgICAgIHt7LSB3aXRoIC5WYWx1ZXMuaW1hZ2VQdWxsU2VjcmV0cyB9fQogICAgICBpbWFnZVB1bGxTZWNyZXRzOgogICAgICAgIHt7LSB0b1lhbWwgLiB8IG5pbmRlbnQgOCB9fQogICAgICB7ey0gZW5kIH19CiAgICAgIHNlcnZpY2VBY2NvdW50TmFtZToge3sgaW5jbHVkZSAiaGVsbS1kYXNoYm9hcmQuc2VydmljZUFjY291bnROYW1lIiAuIH19CiAgICAgIHNlY3VyaXR5Q29udGV4dDoKICAgICAgICB7ey0gdG9ZYW1sIC5WYWx1ZXMucG9kU2VjdXJpdHlDb250ZXh0IHwgbmluZGVudCA4IH19CiAgICAgIGNvbnRhaW5lcnM6CiAgICAgICAgLSBuYW1lOiB7eyAuQ2hhcnQuTmFtZSB9fQogICAgICAgICAgY29tbWFuZDoKICAgICAgICAgICAgLSAvYmluL2hlbG0tZGFzaGJvYXJkCiAgICAgICAgICBhcmdzOgogICAgICAgICAge3stIHdpdGggLlZhbHVlcy5leHRyYUFyZ3MgfX0KICAgICAgICAgICAge3stIHRvWWFtbCAuIHwgbmluZGVudCAxMiB9fQogICAgICAgICAge3stIGVuZCB9fQogICAgICAgICAgc2VjdXJpdHlDb250ZXh0OgogICAgICAgICAgICB7ey0gdG9ZYW1sIC5WYWx1ZXMuc2VjdXJpdHlDb250ZXh0IHwgbmluZGVudCAxMiB9fQogICAgICAgICAgaW1hZ2U6ICJ7eyAuVmFsdWVzLmltYWdlLnJlcG9zaXRvcnkgfX06e3sgLlZhbHVlcy5pbWFnZS50YWcgfCBkZWZhdWx0IC5DaGFydC5BcHBWZXJzaW9uIH19IgogICAgICAgICAgaW1hZ2VQdWxsUG9saWN5OiB7eyAuVmFsdWVzLmltYWdlLnB1bGxQb2xpY3kgfX0KICAgICAgICAgIGVudjoKICAgICAgICAgICAgLSBuYW1lOiBIRUxNX0NBQ0hFX0hPTUUKICAgICAgICAgICAgICB2YWx1ZTogL29wdC9kYXNoYm9hcmQvaGVsbS9jYWNoZQogICAgICAgICAgICAtIG5hbWU6IEhFTE1fQ09ORklHX0hPTUUKICAgICAgICAgICAgICB2YWx1ZTogL29wdC9kYXNoYm9hcmQvaGVsbS9jb25maWcKICAgICAgICAgICAgLSBuYW1lOiBIRUxNX0RBVEFfSE9NRQogICAgICAgICAgICAgIHZhbHVlOiAvb3B0L2Rhc2hib2FyZC9oZWxtL2RhdGEKICAgICAgICAgICAgLSBuYW1lOiBERUJVRwogICAgICAgICAgICAgIHZhbHVlOiB7ey0gdGVybmFyeSAiIDEiICIiIC5WYWx1ZXMuZGVidWcgfX0KICAgICAgICAgICAge3stIGlmIC5WYWx1ZXMuZGFzaGJvYXJkLm5hbWVzcGFjZSB9fQogICAgICAgICAgICAtIG5hbWU6IEhFTE1fTkFNRVNQQUNFCiAgICAgICAgICAgICAgdmFsdWU6IHt7IC5WYWx1ZXMuZGFzaGJvYXJkLm5hbWVzcGFjZSB9fQogICAgICAgICAgICB7e2VuZH19CiAgICAgICAgICBwb3J0czoKICAgICAgICAgICAgLSBuYW1lOiBodHRwCiAgICAgICAgICAgICAgY29udGFpbmVyUG9ydDogODA4MAogICAgICAgICAgICAgIHByb3RvY29sOiBUQ1AKICAgICAgICAgIGxpdmVuZXNzUHJvYmU6CiAgICAgICAgICAgIGh0dHBHZXQ6CiAgICAgICAgICAgICAgcGF0aDogL3N0YXR1cwogICAgICAgICAgICAgIHBvcnQ6IGh0dHAKICAgICAgICAgIHJlYWRpbmVzc1Byb2JlOgogICAgICAgICAgICBodHRwR2V0OgogICAgICAgICAgICAgIHBhdGg6IC9zdGF0dXMKICAgICAgICAgICAgICBwb3J0OiBodHRwCiAgICAgICAgICByZXNvdXJjZXM6CiAgICAgICAgICAgIHt7LSB0b1lhbWwgLlZhbHVlcy5yZXNvdXJjZXMgfCBuaW5kZW50IDEyIH19CiAgICAgICAgICB2b2x1bWVNb3VudHM6CiAgICAgICAgICAgIC0gbmFtZTogZGF0YQogICAgICAgICAgICAgIG1vdW50UGF0aDogL29wdC9kYXNoYm9hcmQvaGVsbQogICAgICB7ey0gd2l0aCAuVmFsdWVzLm5vZGVTZWxlY3RvciB9fQogICAgICBub2RlU2VsZWN0b3I6CiAgICAgICAge3stIHRvWWFtbCAuIHwgbmluZGVudCA4IH19CiAgICAgIHt7LSBlbmQgfX0KICAgICAge3stIHdpdGggLlZhbHVlcy5hZmZpbml0eSB9fQogICAgICBhZmZpbml0eToKICAgICAgICB7ey0gdG9ZYW1sIC4gfCBuaW5kZW50IDggfX0KICAgICAge3stIGVuZCB9fQogICAgICB7ey0gd2l0aCAuVmFsdWVzLnRvbGVyYXRpb25zIH19CiAgICAgIHRvbGVyYXRpb25zOgogICAgICAgIHt7LSB0b1lhbWwgLiB8IG5pbmRlbnQgOCB9fQogICAgICB7ey0gZW5kIH19CiAgICAgIHZvbHVtZXM6CiAgICAgICAgLSBuYW1lOiBkYXRhCiAgICAgICAge3stIGlmIC5WYWx1ZXMuZGFzaGJvYXJkLnBlcnNpc3RlbmNlLmVuYWJsZWQgfX0KICAgICAgICAgIHBlcnNpc3RlbnRWb2x1bWVDbGFpbToKICAgICAgICAgICAgY2xhaW1OYW1lOiB7eyBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5mdWxsbmFtZSIgLiB9fQogICAgICAgIHt7LSBlbHNlIH19CiAgICAgICAgICBlbXB0eURpcjogeyB9CiAgICAgICAge3stIGVuZCB9fQoK" + }, + { + "name":"templates/ingress.yaml", + "data":"e3stIGlmIC5WYWx1ZXMuaW5ncmVzcy5lbmFibGVkIC19fQp7ey0gJGZ1bGxOYW1lIDo9IGluY2x1ZGUgImhlbG0tZGFzaGJvYXJkLmZ1bGxuYW1lIiAuIC19fQp7ey0gJHN2Y1BvcnQgOj0gLlZhbHVlcy5zZXJ2aWNlLnBvcnQgLX19Cnt7LSBpZiBhbmQgLlZhbHVlcy5pbmdyZXNzLmNsYXNzTmFtZSAobm90IChzZW12ZXJDb21wYXJlICI+PTEuMTgtMCIgLkNhcGFiaWxpdGllcy5LdWJlVmVyc2lvbi5HaXRWZXJzaW9uKSkgfX0KICB7ey0gaWYgbm90IChoYXNLZXkgLlZhbHVlcy5pbmdyZXNzLmFubm90YXRpb25zICJrdWJlcm5ldGVzLmlvL2luZ3Jlc3MuY2xhc3MiKSB9fQogIHt7LSAkXyA6PSBzZXQgLlZhbHVlcy5pbmdyZXNzLmFubm90YXRpb25zICJrdWJlcm5ldGVzLmlvL2luZ3Jlc3MuY2xhc3MiIC5WYWx1ZXMuaW5ncmVzcy5jbGFzc05hbWV9fQogIHt7LSBlbmQgfX0Ke3stIGVuZCB9fQp7ey0gaWYgc2VtdmVyQ29tcGFyZSAiPj0xLjE5LTAiIC5DYXBhYmlsaXRpZXMuS3ViZVZlcnNpb24uR2l0VmVyc2lvbiAtfX0KYXBpVmVyc2lvbjogbmV0d29ya2luZy5rOHMuaW8vdjEKe3stIGVsc2UgaWYgc2VtdmVyQ29tcGFyZSAiPj0xLjE0LTAiIC5DYXBhYmlsaXRpZXMuS3ViZVZlcnNpb24uR2l0VmVyc2lvbiAtfX0KYXBpVmVyc2lvbjogbmV0d29ya2luZy5rOHMuaW8vdjFiZXRhMQp7ey0gZWxzZSAtfX0KYXBpVmVyc2lvbjogZXh0ZW5zaW9ucy92MWJldGExCnt7LSBlbmQgfX0Ka2luZDogSW5ncmVzcwptZXRhZGF0YToKICBuYW1lOiB7eyAkZnVsbE5hbWUgfX0KICBsYWJlbHM6CiAgICB7ey0gaW5jbHVkZSAiaGVsbS1kYXNoYm9hcmQubGFiZWxzIiAuIHwgbmluZGVudCA0IH19CiAge3stIHdpdGggLlZhbHVlcy5pbmdyZXNzLmFubm90YXRpb25zIH19CiAgYW5ub3RhdGlvbnM6CiAgICB7ey0gdG9ZYW1sIC4gfCBuaW5kZW50IDQgfX0KICB7ey0gZW5kIH19CnNwZWM6CiAge3stIGlmIGFuZCAuVmFsdWVzLmluZ3Jlc3MuY2xhc3NOYW1lIChzZW12ZXJDb21wYXJlICI+PTEuMTgtMCIgLkNhcGFiaWxpdGllcy5LdWJlVmVyc2lvbi5HaXRWZXJzaW9uKSB9fQogIGluZ3Jlc3NDbGFzc05hbWU6IHt7IC5WYWx1ZXMuaW5ncmVzcy5jbGFzc05hbWUgfX0KICB7ey0gZW5kIH19CiAge3stIGlmIC5WYWx1ZXMuaW5ncmVzcy50bHMgfX0KICB0bHM6CiAgICB7ey0gcmFuZ2UgLlZhbHVlcy5pbmdyZXNzLnRscyB9fQogICAgLSBob3N0czoKICAgICAgICB7ey0gcmFuZ2UgLmhvc3RzIH19CiAgICAgICAgLSB7eyAuIHwgcXVvdGUgfX0KICAgICAgICB7ey0gZW5kIH19CiAgICAgIHNlY3JldE5hbWU6IHt7IC5zZWNyZXROYW1lIH19CiAgICB7ey0gZW5kIH19CiAge3stIGVuZCB9fQogIHJ1bGVzOgogICAge3stIHJhbmdlIC5WYWx1ZXMuaW5ncmVzcy5ob3N0cyB9fQogICAgLSBob3N0OiB7eyAuaG9zdCB8IHF1b3RlIH19CiAgICAgIGh0dHA6CiAgICAgICAgcGF0aHM6CiAgICAgICAgICB7ey0gcmFuZ2UgLnBhdGhzIH19CiAgICAgICAgICAtIHBhdGg6IHt7IC5wYXRoIH19CiAgICAgICAgICAgIHt7LSBpZiBhbmQgLnBhdGhUeXBlIChzZW12ZXJDb21wYXJlICI+PTEuMTgtMCIgJC5DYXBhYmlsaXRpZXMuS3ViZVZlcnNpb24uR2l0VmVyc2lvbikgfX0KICAgICAgICAgICAgcGF0aFR5cGU6IHt7IC5wYXRoVHlwZSB9fQogICAgICAgICAgICB7ey0gZW5kIH19CiAgICAgICAgICAgIGJhY2tlbmQ6CiAgICAgICAgICAgICAge3stIGlmIHNlbXZlckNvbXBhcmUgIj49MS4xOS0wIiAkLkNhcGFiaWxpdGllcy5LdWJlVmVyc2lvbi5HaXRWZXJzaW9uIH19CiAgICAgICAgICAgICAgc2VydmljZToKICAgICAgICAgICAgICAgIG5hbWU6IHt7ICRmdWxsTmFtZSB9fQogICAgICAgICAgICAgICAgcG9ydDoKICAgICAgICAgICAgICAgICAgbnVtYmVyOiB7eyAkc3ZjUG9ydCB9fQogICAgICAgICAgICAgIHt7LSBlbHNlIH19CiAgICAgICAgICAgICAgc2VydmljZU5hbWU6IHt7ICRmdWxsTmFtZSB9fQogICAgICAgICAgICAgIHNlcnZpY2VQb3J0OiB7eyAkc3ZjUG9ydCB9fQogICAgICAgICAgICAgIHt7LSBlbmQgfX0KICAgICAgICAgIHt7LSBlbmQgfX0KICAgIHt7LSBlbmQgfX0Ke3stIGVuZCB9fQo=" + }, + { + "name":"templates/pvc.yaml", + "data":"e3stIGlmIC5WYWx1ZXMuZGFzaGJvYXJkLnBlcnNpc3RlbmNlLmVuYWJsZWQgLX19CmFwaVZlcnNpb246IHYxCmtpbmQ6IFBlcnNpc3RlbnRWb2x1bWVDbGFpbQptZXRhZGF0YToKICBuYW1lOiB7eyBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5mdWxsbmFtZSIgLiB9fQogIG5hbWVzcGFjZToge3sgLlJlbGVhc2UuTmFtZXNwYWNlIHwgcXVvdGUgfX0KICBsYWJlbHM6CiAgICB7ey0gaW5jbHVkZSAiaGVsbS1kYXNoYm9hcmQubGFiZWxzIiAuIHwgbmluZGVudCA0IH19CiAge3stIHdpdGggLlZhbHVlcy5kYXNoYm9hcmQucGVyc2lzdGVuY2UuYW5ub3RhdGlvbnMgfX0KICBhbm5vdGF0aW9uczoKICAgIHt7LSB0b1lhbWwgLiB8IG5pbmRlbnQgNCB9fQogIHt7LSBlbmQgfX0Kc3BlYzoKICB7ey0gaWYgLlZhbHVlcy5kYXNoYm9hcmQucGVyc2lzdGVuY2UuaG9zdFBhdGggfX0KICBzdG9yYWdlQ2xhc3NOYW1lOiAiIgogIHt7LSBlbHNlIH19CiAge3stIGlmIGtpbmRJcyAic3RyaW5nIiAuVmFsdWVzLmRhc2hib2FyZC5wZXJzaXN0ZW5jZS5zdG9yYWdlQ2xhc3MgfX0KICBzdG9yYWdlQ2xhc3NOYW1lOiAie3sgLlZhbHVlcy5kYXNoYm9hcmQucGVyc2lzdGVuY2Uuc3RvcmFnZUNsYXNzIH19IgogIHt7LSBlbmQgfX0KICB7ey0gZW5kIH19CiAgYWNjZXNzTW9kZXM6CiAge3stIGlmIG5vdCAoZW1wdHkgLlZhbHVlcy5kYXNoYm9hcmQucGVyc2lzdGVuY2UuYWNjZXNzTW9kZXMpIH19CiAge3stIHJhbmdlIC5WYWx1ZXMuZGFzaGJvYXJkLnBlcnNpc3RlbmNlLmFjY2Vzc01vZGVzIH19CiAgICAtIHt7IC4gfCBxdW90ZSB9fQogIHt7LSBlbmQgfX0KICB7ey0gZW5kIH19CiAgcmVzb3VyY2VzOgogICAgcmVxdWVzdHM6CiAgICAgIHN0b3JhZ2U6IHt7IC5WYWx1ZXMuZGFzaGJvYXJkLnBlcnNpc3RlbmNlLnNpemUgfCBxdW90ZSB9fQp7ey0gZW5kIH19CgotLS0Ke3stIGlmIGFuZCAuVmFsdWVzLmRhc2hib2FyZC5wZXJzaXN0ZW5jZS5lbmFibGVkIC5WYWx1ZXMuZGFzaGJvYXJkLnBlcnNpc3RlbmNlLmhvc3RQYXRoIC19fQphcGlWZXJzaW9uOiB2MQpraW5kOiBQZXJzaXN0ZW50Vm9sdW1lCm1ldGFkYXRhOgogIG5hbWU6IHt7IGluY2x1ZGUgImhlbG0tZGFzaGJvYXJkLmZ1bGxuYW1lIiAuIH19CiAgbmFtZXNwYWNlOiB7eyAuUmVsZWFzZS5OYW1lc3BhY2UgfCBxdW90ZSB9fQogIGxhYmVsczoKICAgIHt7LSBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5sYWJlbHMiIC4gfCBuaW5kZW50IDQgfX0KICB7ey0gd2l0aCAuVmFsdWVzLmRhc2hib2FyZC5wZXJzaXN0ZW5jZS5hbm5vdGF0aW9ucyB9fQogIGFubm90YXRpb25zOgogICAge3stIHRvWWFtbCAuIHwgbmluZGVudCA0IH19CiAge3stIGVuZCB9fQpzcGVjOgogIGFjY2Vzc01vZGVzOgogIHt7LSBpZiBub3QgKGVtcHR5IC5WYWx1ZXMuZGFzaGJvYXJkLnBlcnNpc3RlbmNlLmFjY2Vzc01vZGVzKSB9fQogIHt7LSByYW5nZSAuVmFsdWVzLmRhc2hib2FyZC5wZXJzaXN0ZW5jZS5hY2Nlc3NNb2RlcyB9fQogICAgLSB7eyAuIHwgcXVvdGUgfX0KICB7ey0gZW5kIH19CiAge3stIGVuZCB9fQogIGNhcGFjaXR5OgogICAgc3RvcmFnZToge3sgLlZhbHVlcy5kYXNoYm9hcmQucGVyc2lzdGVuY2Uuc2l6ZSB8IHF1b3RlIH19CiAgaG9zdFBhdGg6CiAgICBwYXRoOiB7eyAuVmFsdWVzLmRhc2hib2FyZC5wZXJzaXN0ZW5jZS5ob3N0UGF0aCB8IHF1b3RlIH19Cnt7LSBlbmQgLX19Cg==" + }, + { + "name":"templates/service.yaml", + "data":"YXBpVmVyc2lvbjogdjEKa2luZDogU2VydmljZQptZXRhZGF0YToKICBuYW1lOiB7eyBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5mdWxsbmFtZSIgLiB9fQogIGxhYmVsczoKICAgIHt7LSBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5sYWJlbHMiIC4gfCBuaW5kZW50IDQgfX0Kc3BlYzoKICB0eXBlOiB7eyAuVmFsdWVzLnNlcnZpY2UudHlwZSB9fQogIHBvcnRzOgogICAgLSBwb3J0OiB7eyAuVmFsdWVzLnNlcnZpY2UucG9ydCB9fQogICAgICB0YXJnZXRQb3J0OiBodHRwCiAgICAgIHByb3RvY29sOiBUQ1AKICAgICAgbmFtZTogaHR0cAogIHNlbGVjdG9yOgogICAge3stIGluY2x1ZGUgImhlbG0tZGFzaGJvYXJkLnNlbGVjdG9yTGFiZWxzIiAuIHwgbmluZGVudCA0IH19Cg==" + }, + { + "name":"templates/serviceaccount.yaml", + "data":"e3stIGlmIC5WYWx1ZXMuc2VydmljZUFjY291bnQuY3JlYXRlIC19fQphcGlWZXJzaW9uOiB2MQpraW5kOiBTZXJ2aWNlQWNjb3VudAptZXRhZGF0YToKICBuYW1lOiB7eyBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5zZXJ2aWNlQWNjb3VudE5hbWUiIC4gfX0KICBsYWJlbHM6CiAgICB7ey0gaW5jbHVkZSAiaGVsbS1kYXNoYm9hcmQubGFiZWxzIiAuIHwgbmluZGVudCA0IH19CiAge3stIHdpdGggLlZhbHVlcy5zZXJ2aWNlQWNjb3VudC5hbm5vdGF0aW9ucyB9fQogIGFubm90YXRpb25zOgogICAge3stIHRvWWFtbCAuIHwgbmluZGVudCA0IH19CiAge3stIGVuZCB9fQp7ey0gZW5kIH19CgotLS0Ka2luZDogQ2x1c3RlclJvbGUKYXBpVmVyc2lvbjogcmJhYy5hdXRob3JpemF0aW9uLms4cy5pby92MQptZXRhZGF0YToKICBuYW1lOiB7eyBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5zZXJ2aWNlQWNjb3VudE5hbWUiIC4gfX0KcnVsZXM6CiAgLSBhcGlHcm91cHM6IFsiKiJdCiAgICByZXNvdXJjZXM6IFsiKiJdCiAge3stIGlmIC5WYWx1ZXMuZGFzaGJvYXJkLmFsbG93V3JpdGVBY3Rpb25zIH19CiAgICB2ZXJiczogWyJnZXQiLCAibGlzdCIsICJ3YXRjaCIsICJjcmVhdGUiLCAiZGVsZXRlIiwgInBhdGNoIiwgInVwZGF0ZSJdCiAge3stIGVsc2UgfX0KICAgIHZlcmJzOiBbImdldCIsICJsaXN0IiwgIndhdGNoIl0KICB7ey0gZW5kIH19Ci0tLQphcGlWZXJzaW9uOiByYmFjLmF1dGhvcml6YXRpb24uazhzLmlvL3YxCmtpbmQ6IENsdXN0ZXJSb2xlQmluZGluZwptZXRhZGF0YToKICBuYW1lOiB7eyBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5zZXJ2aWNlQWNjb3VudE5hbWUiIC4gfX0Kcm9sZVJlZjoKICBhcGlHcm91cDogcmJhYy5hdXRob3JpemF0aW9uLms4cy5pbwogIGtpbmQ6IENsdXN0ZXJSb2xlCiAgbmFtZToge3sgaW5jbHVkZSAiaGVsbS1kYXNoYm9hcmQuc2VydmljZUFjY291bnROYW1lIiAuIH19CnN1YmplY3RzOgogIC0ga2luZDogU2VydmljZUFjY291bnQKICAgIG5hbWVzcGFjZToge3sgLlJlbGVhc2UuTmFtZXNwYWNlIH19CiAgICBuYW1lOiB7eyBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5zZXJ2aWNlQWNjb3VudE5hbWUiIC4gfX0=" + }, + { + "name":"templates/tests/test-connection.yaml", + "data":"YXBpVmVyc2lvbjogdjEKa2luZDogUG9kCm1ldGFkYXRhOgogIG5hbWU6ICJ7eyBpbmNsdWRlICJoZWxtLWRhc2hib2FyZC5mdWxsbmFtZSIgLiB9fS10ZXN0LWNvbm5lY3Rpb24iCiAgbGFiZWxzOgogICAge3stIGluY2x1ZGUgImhlbG0tZGFzaGJvYXJkLmxhYmVscyIgLiB8IG5pbmRlbnQgNCB9fQogIGFubm90YXRpb25zOgogICAgImhlbG0uc2gvaG9vayI6IHRlc3QKc3BlYzoKICBjb250YWluZXJzOgogICAgLSBuYW1lOiB3Z2V0CiAgICAgIGltYWdlOiBidXN5Ym94CiAgICAgIGNvbW1hbmQ6IFsnd2dldCddCiAgICAgIGFyZ3M6IFsnLS10aW1lb3V0PTUnLCAne3sgaW5jbHVkZSAiaGVsbS1kYXNoYm9hcmQuZnVsbG5hbWUiIC4gfX06e3sgLlZhbHVlcy5zZXJ2aWNlLnBvcnQgfX0nXQogIHJlc3RhcnRQb2xpY3k6IE5ldmVyCg==" + } + ], + "values":{ + "affinity":{ + + }, + "autoscaling":{ + "enabled":false, + "maxReplicas":100, + "minReplicas":1, + "targetCPUUtilizationPercentage":80 + }, + "dashboard":{ + "allowWriteActions":true, + "namespace":"", + "persistence":{ + "accessModes":[ + "ReadWriteOnce" + ], + "annotations":{ + + }, + "enabled":true, + "hostPath":"", + "labels":{ + + }, + "size":"100M", + "storageClass":null + } + }, + "debug":false, + "extraArgs":[ + "--no-browser", + "--bind=0.0.0.0" + ], + "fullnameOverride":"", + "image":{ + "pullPolicy":"IfNotPresent", + "repository":"komodorio/helm-dashboard", + "tag":"" + }, + "imagePullSecrets":[ + + ], + "ingress":{ + "annotations":{ + + }, + "className":"", + "enabled":false, + "hosts":[ + { + "host":"chart-example.local", + "paths":[ + { + "path":"/", + "pathType":"ImplementationSpecific" + } + ] + } + ], + "tls":[ + + ] + }, + "nameOverride":"", + "nodeSelector":{ + + }, + "podAnnotations":{ + + }, + "podSecurityContext":{ + + }, + "replicaCount":1, + "resources":{ + "limits":{ + "cpu":1, + "memory":"1Gi" + }, + "requests":{ + "cpu":"200m", + "memory":"256Mi" + } + }, + "securityContext":{ + + }, + "service":{ + "port":8080, + "type":"ClusterIP" + }, + "serviceAccount":{ + "create":true, + "name":"" + }, + "tolerations":[ + + ], + "updateStrategy":{ + "type":"RollingUpdate" + } + }, + "schema":null, + "files":[ + { + "name":".helmignore", + "data":"IyBQYXR0ZXJucyB0byBpZ25vcmUgd2hlbiBidWlsZGluZyBwYWNrYWdlcy4KIyBUaGlzIHN1cHBvcnRzIHNoZWxsIGdsb2IgbWF0Y2hpbmcsIHJlbGF0aXZlIHBhdGggbWF0Y2hpbmcsIGFuZAojIG5lZ2F0aW9uIChwcmVmaXhlZCB3aXRoICEpLiBPbmx5IG9uZSBwYXR0ZXJuIHBlciBsaW5lLgouRFNfU3RvcmUKIyBDb21tb24gVkNTIGRpcnMKLmdpdC8KLmdpdGlnbm9yZQouYnpyLwouYnpyaWdub3JlCi5oZy8KLmhnaWdub3JlCi5zdm4vCiMgQ29tbW9uIGJhY2t1cCBmaWxlcwoqLnN3cAoqLmJhawoqLnRtcAoqLm9yaWcKKn4KIyBWYXJpb3VzIElERXMKLnByb2plY3QKLmlkZWEvCioudG1wcm9qCi52c2NvZGUvCg==" + }, + { + "name":"README.md", + "data":"# Helm Dashboard

## TL;DR;

```bash
helm repo add komodorio https://helm-charts.komodor.io
helm repo update
helm upgrade --install helm-dashboard komodorio/helm-dashboard
```

## Introduction

This chart bootstraps a Helm Dashboard deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager.

While installed inside cluster, Helm Dashboard will run some additional backgroud actions, for example, will automatically update Helm repositories. To enable that behavior locally, set `HD_CLUSTER_MODE` env variable.

## Prerequisites

- Kubernetes 1.16+

## Installing the Chart

To install the chart with the release name `helm-dashboard`:

```bash
helm install helm-dashboard .
```

The command deploys Helm Dashboard on the Kubernetes cluster in the default configuration. The [Parameters](#parameters) section lists the parameters that can be configured during installation.

> **Tip**: List all releases using `helm list`

## Uninstalling the Chart

To uninstall/delete the `helm-dashboard` deployment:

```bash
helm uninstall helm-dashboard
```

The command removes all the Kubernetes components associated with the chart and deletes the release.

## Adding Authentication

The task of authentication and user control is out of scope for Helm Dashboard. Luckily, there are third-party solutions which are dedicated to provide that functionality.

For instance, you can place authentication proxy in front of Helm Dashboard, like this one: https://github.com/oauth2-proxy/oauth2-proxy

## Parameters

The following table lists the configurable parameters of the chart and their default values.

| Parameter                            | Description                                                                                    | Default                              |
| ------------------------------------ | ---------------------------------------------------------------------------------------------- | ------------------------------------ |
| `image.repository`                   | Image registry/name                                                                            | `docker.io/komodorio/helm-dashboard` |
| `image.tag`                          | Image tag                                                                                      |                                      |
| `image.pullPolicy`                   | Image pull policy                                                                              | `IfNotPresent`                       |
| `replicaCount`                       | Number of dashboard Pods to run                                                                | `1`                                  |
| `dashboard.allowWriteActions`        | Enables write actions. Allow modifying, deleting and creating charts and kubernetes resources. | `true`                               |
| `resources.requests.cpu`             | CPU resource requests                                                                          | `200m`                               |
| `resources.limits.cpu`               | CPU resource limits                                                                            | `1`                                  |
| `resources.requests.memory`          | Memory resource requests                                                                       | `256Mi`                              |
| `resources.limits.memory`            | Memory resource limits                                                                         | `1Gi`                                |
| `service.type           `            | Kubernetes service type                                                                        | `ClusterIP`                          |
| `service.port           `            | Kubernetes service port                                                                        | `8080`                               |
| `serviceAccount.create`              | Creates a service account                                                                      | `true`                               |
| `serviceAccount.name`                | Optional name for the service account                                                          | `{RELEASE_FULLNAME}`                 |
| `nodeSelector`                       | Node labels for pod assignment                                                                 |                                      |
| `affinity`                           | Affinity settings for pod assignment                                                           |                                      |
| `tolerations`                        | Tolerations for pod assignment                                                                 |                                      |
| `dashboard.persistence.enabled`      | Enable helm data persistene using PVC                                                          | `true`                               |
| `dashboard.persistence.accessModes`  | Persistent Volume access modes                                                                 | `["ReadWriteOnce"]`                  |
| `dashboard.persistence.storageClass` | Persistent Volume storage class                                                                | `""`                                 |
| `dashboard.persistence.size`         | Persistent Volume size                                                                         | `100M`                               |
| `dashboard.persistence.hostPath`     | Set path in case you want to use local host path volumes (not recommended in production)       | `""`
| `updateStrategy.type`                | Set up update strategy for helm-dashboard installation.                                        | `RollingUpdate`                    |             
| `extraArgs`     | Set the arguments to be supplied to the helm-dashboard binary       | `[--no-browser, --bind=0.0.0.0]`

Specify each parameter using the `--set key=value[,key=value]` argument to `helm install`.

```bash
helm upgrade --install helm-dashboard komodorio/helm-dashboard --set dashboard.allowWriteActions=true --set service.port=9090
```

> **Tip**: You can use the default [values.yaml](values.yaml)
" + } + ] + }, + "manifest":"---\n# Source: helm-dashboard/templates/serviceaccount.yaml\napiVersion: v1\nkind: ServiceAccount\nmetadata:\n name: helm-dashboard\n labels:\n helm.sh/chart: helm-dashboard-0.1.10\n app.kubernetes.io/name: helm-dashboard\n app.kubernetes.io/instance: helm-dashboard\n app.kubernetes.io/version: \"1.3.3\"\n app.kubernetes.io/managed-by: Helm\n---\n# Source: helm-dashboard/templates/pvc.yaml\napiVersion: v1\nkind: PersistentVolumeClaim\nmetadata:\n name: helm-dashboard\n namespace: \"default\"\n labels:\n helm.sh/chart: helm-dashboard-0.1.10\n app.kubernetes.io/name: helm-dashboard\n app.kubernetes.io/instance: helm-dashboard\n app.kubernetes.io/version: \"1.3.3\"\n app.kubernetes.io/managed-by: Helm\nspec:\n accessModes:\n - \"ReadWriteOnce\"\n resources:\n requests:\n storage: \"100M\"\n---\n# Source: helm-dashboard/templates/serviceaccount.yaml\nkind: ClusterRole\napiVersion: rbac.authorization.k8s.io/v1\nmetadata:\n name: helm-dashboard\nrules:\n - apiGroups: [\"*\"]\n resources: [\"*\"]\n verbs: [\"get\", \"list\", \"watch\", \"create\", \"delete\", \"patch\", \"update\"]\n---\n# Source: helm-dashboard/templates/serviceaccount.yaml\napiVersion: rbac.authorization.k8s.io/v1\nkind: ClusterRoleBinding\nmetadata:\n name: helm-dashboard\nroleRef:\n apiGroup: rbac.authorization.k8s.io\n kind: ClusterRole\n name: helm-dashboard\nsubjects:\n - kind: ServiceAccount\n namespace: default\n name: helm-dashboard\n---\n# Source: helm-dashboard/templates/service.yaml\napiVersion: v1\nkind: Service\nmetadata:\n name: helm-dashboard\n labels:\n helm.sh/chart: helm-dashboard-0.1.10\n app.kubernetes.io/name: helm-dashboard\n app.kubernetes.io/instance: helm-dashboard\n app.kubernetes.io/version: \"1.3.3\"\n app.kubernetes.io/managed-by: Helm\nspec:\n type: ClusterIP\n ports:\n - port: 8080\n targetPort: http\n protocol: TCP\n name: http\n selector:\n app.kubernetes.io/name: helm-dashboard\n app.kubernetes.io/instance: helm-dashboard\n---\n# Source: helm-dashboard/templates/deployment.yaml\napiVersion: apps/v1\nkind: Deployment\nmetadata:\n name: helm-dashboard\n labels:\n helm.sh/chart: helm-dashboard-0.1.10\n app.kubernetes.io/name: helm-dashboard\n app.kubernetes.io/instance: helm-dashboard\n app.kubernetes.io/version: \"1.3.3\"\n app.kubernetes.io/managed-by: Helm\nspec:\n replicas: 1\n selector:\n matchLabels:\n app.kubernetes.io/name: helm-dashboard\n app.kubernetes.io/instance: helm-dashboard\n strategy:\n type: RollingUpdate\n template:\n metadata:\n labels:\n app.kubernetes.io/name: helm-dashboard\n app.kubernetes.io/instance: helm-dashboard\n spec:\n serviceAccountName: helm-dashboard\n securityContext:\n {}\n containers:\n - name: helm-dashboard\n command:\n - /bin/helm-dashboard\n args:\n - --no-browser\n - --bind=0.0.0.0\n securityContext:\n {}\n image: \"komodorio/helm-dashboard:1.3.3\"\n imagePullPolicy: IfNotPresent\n env:\n - name: HELM_CACHE_HOME\n value: /opt/dashboard/helm/cache\n - name: HELM_CONFIG_HOME\n value: /opt/dashboard/helm/config\n - name: HELM_DATA_HOME\n value: /opt/dashboard/helm/data\n - name: DEBUG\n value:\n ports:\n - name: http\n containerPort: 8080\n protocol: TCP\n livenessProbe:\n httpGet:\n path: /status\n port: http\n readinessProbe:\n httpGet:\n path: /status\n port: http\n resources:\n limits:\n cpu: 1\n memory: 1Gi\n requests:\n cpu: 200m\n memory: 256Mi\n volumeMounts:\n - name: data\n mountPath: /opt/dashboard/helm\n volumes:\n - name: data\n persistentVolumeClaim:\n claimName: helm-dashboard\n", + "hooks":[ + { + "name":"helm-dashboard-test-connection", + "kind":"Pod", + "path":"helm-dashboard/templates/tests/test-connection.yaml", + "manifest":"apiVersion: v1\nkind: Pod\nmetadata:\n name: \"helm-dashboard-test-connection\"\n labels:\n helm.sh/chart: helm-dashboard-0.1.10\n app.kubernetes.io/name: helm-dashboard\n app.kubernetes.io/instance: helm-dashboard\n app.kubernetes.io/version: \"1.3.3\"\n app.kubernetes.io/managed-by: Helm\n annotations:\n \"helm.sh/hook\": test\nspec:\n containers:\n - name: wget\n image: busybox\n command: ['wget']\n args: ['--timeout=5', 'helm-dashboard:8080']\n restartPolicy: Never", + "events":[ + "test" + ], + "last_run":{ + "started_at":"", + "completed_at":"", + "phase":"" + } + } + ], + "version":1, + "namespace":"default" +} \ No newline at end of file diff --git a/frontend/cypress/fixtures/example.json b/frontend/cypress/fixtures/example.json new file mode 100644 index 00000000..02e42543 --- /dev/null +++ b/frontend/cypress/fixtures/example.json @@ -0,0 +1,5 @@ +{ + "name": "Using fixtures to represent data", + "email": "hello@cypress.io", + "body": "Fixtures are a great way to mock data for responses to routes" +} diff --git a/frontend/cypress/fixtures/history.json b/frontend/cypress/fixtures/history.json new file mode 100644 index 00000000..75144a80 --- /dev/null +++ b/frontend/cypress/fixtures/history.json @@ -0,0 +1,13 @@ +[ + { + "revision": 1, + "updated": "2024-01-17T22:39:07.2371554+02:00", + "status": "deployed", + "chart": "helm-dashboard-0.1.10", + "app_version": "1.3.3", + "description": "Install complete", + "chart_name": "helm-dashboard", + "chart_ver": "0.1.10", + "has_tests": true + } +] \ No newline at end of file diff --git a/frontend/cypress/fixtures/releases.json b/frontend/cypress/fixtures/releases.json new file mode 100644 index 00000000..0637a088 --- /dev/null +++ b/frontend/cypress/fixtures/releases.json @@ -0,0 +1 @@ +[] \ No newline at end of file diff --git a/frontend/cypress/fixtures/repositories.json b/frontend/cypress/fixtures/repositories.json new file mode 100644 index 00000000..3d9f368f --- /dev/null +++ b/frontend/cypress/fixtures/repositories.json @@ -0,0 +1,6 @@ +[ + { + "name": "Komodorio", + "url": "https://helm-charts.komodor.io" + } +] \ No newline at end of file diff --git a/frontend/cypress/fixtures/status.json b/frontend/cypress/fixtures/status.json new file mode 100644 index 00000000..349a7109 --- /dev/null +++ b/frontend/cypress/fixtures/status.json @@ -0,0 +1,7 @@ +{ + "CurVer": "0.0.0", + "LatestVer": "v1.3.3", + "Analytics": false, + "CacheHitRatio": 0, + "ClusterMode": false +} \ No newline at end of file diff --git a/frontend/cypress/support/e2e.ts b/frontend/cypress/support/e2e.ts new file mode 100644 index 00000000..6a173d6f --- /dev/null +++ b/frontend/cypress/support/e2e.ts @@ -0,0 +1,20 @@ +// *********************************************************** +// This example support/e2e.ts is processed and +// loaded automatically before your test files. +// +// This is a great place to put global configuration and +// behavior that modifies Cypress. +// +// You can change the location of this file or turn off +// automatically serving support files with the +// 'supportFile' configuration option. +// +// You can read more here: +// https://on.cypress.io/configuration +// *********************************************************** + +// Import commands.js using ES2015 syntax: +import "./commands"; + +// Alternatively you can use CommonJS syntax: +// require('./commands') diff --git a/frontend/package.json b/frontend/package.json index 7ba589dd..738e1737 100644 --- a/frontend/package.json +++ b/frontend/package.json @@ -9,7 +9,7 @@ "@types/luxon": "^3.3.0", "@types/marked": "^5.0.0", "compare-versions": "^6.0.0-rc.2", - "diff2html": "^3.4.35", + "diff2html": "^3.4.46", "eslint-config-enpitech": "^1.0.9", "flowbite": "^1.6.6", "flowbite-react": "^0.4.9", @@ -78,7 +78,7 @@ "prettier": "npx prettier src/ --check", "prettier:fix": "npm run prettier -- --write", "cypress:open": "cypress open", - "cypress:run": "cypress run" + "cypress:run": "cypress run" }, "keywords": [], "author": "", diff --git a/frontend/src/components/LinkWithSearchParams.tsx b/frontend/src/components/LinkWithSearchParams.tsx index be947308..5d58049a 100644 --- a/frontend/src/components/LinkWithSearchParams.tsx +++ b/frontend/src/components/LinkWithSearchParams.tsx @@ -13,7 +13,7 @@ const LinkWithSearchParams = ({ }) => { const { search } = useLocation(); const { context } = useParams(); - const {clusterMode} = useAppContext(); + const { clusterMode } = useAppContext(); const params = new URLSearchParams(search); // For state we don't want to keep while navigating @@ -27,7 +27,13 @@ const LinkWithSearchParams = ({ prefixedUrl = `/${context}${to}`; } - return ; + return ( + + ); }; export default LinkWithSearchParams; diff --git a/frontend/src/components/modal/AddRepositoryModal.tsx b/frontend/src/components/modal/AddRepositoryModal.tsx index c7ba9c62..2dfa596a 100644 --- a/frontend/src/components/modal/AddRepositoryModal.tsx +++ b/frontend/src/components/modal/AddRepositoryModal.tsx @@ -81,6 +81,7 @@ function AddRepositoryModal({ isOpen, onClose }: AddRepositoryModalProps) { bottomContent={