From 56cbd1abb371c442fa9497aa462c773fc630b866 Mon Sep 17 00:00:00 2001 From: Mauricio Siu <47042324+Siumauricio@users.noreply.github.com> Date: Tue, 11 Mar 2025 00:41:53 -0600 Subject: [PATCH] test(templates): enhance secret key and base64 validation in template tests Improve test coverage for secret key generation by: - Adding more robust base64 validation checks - Verifying base64 string format and length - Ensuring generated keys meet specific cryptographic requirements --- .../templates/config.template.test.ts | 36 +++++++++++++++---- 1 file changed, 30 insertions(+), 6 deletions(-) diff --git a/apps/dokploy/__test__/templates/config.template.test.ts b/apps/dokploy/__test__/templates/config.template.test.ts index 4b0e8fac..902e3163 100644 --- a/apps/dokploy/__test__/templates/config.template.test.ts +++ b/apps/dokploy/__test__/templates/config.template.test.ts @@ -166,7 +166,12 @@ describe("processTemplate", () => { if (!baseUrl || !secretKey) return; expect(baseUrl).toContain(mockSchema.projectName); - expect(secretKey.split("=")[1]).toHaveLength(64); + const base64Value = secretKey.split("=")[1]; + expect(base64Value).toBeDefined(); + if (!base64Value) return; + expect(base64Value).toMatch(/^[A-Za-z0-9+/]+={0,2}$/); + expect(base64Value.length).toBeGreaterThanOrEqual(86); + expect(base64Value.length).toBeLessThanOrEqual(88); }); it("should process env vars when provided as an array", () => { @@ -221,7 +226,12 @@ describe("processTemplate", () => { if (!randomDomainEnv || !secretKeyEnv) return; expect(randomDomainEnv).toContain(mockSchema.projectName); - expect(secretKeyEnv.split("=")[1]).toHaveLength(32); + const base64Value = secretKeyEnv.split("=")[1]; + expect(base64Value).toBeDefined(); + if (!base64Value) return; + expect(base64Value).toMatch(/^[A-Za-z0-9+/]+={0,2}$/); + expect(base64Value.length).toBeGreaterThanOrEqual(42); + expect(base64Value.length).toBeLessThanOrEqual(44); }); }); @@ -351,8 +361,22 @@ describe("processTemplate", () => { if (!baseUrl || !secretKey || !totpKey) return; expect(baseUrl).toContain(mockSchema.projectName); - expect(secretKey.split("=")[1]).toHaveLength(64); - expect(totpKey.split("=")[1]).toHaveLength(32); + + // Check base64 lengths and format + const secretKeyValue = secretKey.split("=")[1]; + const totpKeyValue = totpKey.split("=")[1]; + + expect(secretKeyValue).toBeDefined(); + expect(totpKeyValue).toBeDefined(); + if (!secretKeyValue || !totpKeyValue) return; + + expect(secretKeyValue).toMatch(/^[A-Za-z0-9+/]+={0,2}$/); + expect(secretKeyValue.length).toBeGreaterThanOrEqual(86); + expect(secretKeyValue.length).toBeLessThanOrEqual(88); + + expect(totpKeyValue).toMatch(/^[A-Za-z0-9+/]+={0,2}$/); + expect(totpKeyValue.length).toBeGreaterThanOrEqual(42); + expect(totpKeyValue.length).toBeLessThanOrEqual(44); // Check mounts expect(result.mounts).toHaveLength(1); @@ -360,8 +384,8 @@ describe("processTemplate", () => { expect(mount).toBeDefined(); if (!mount) return; expect(mount.content).toContain(mockSchema.projectName); - expect(mount.content).toMatch(/secret=[A-Za-z0-9+/]{64}/); - expect(mount.content).toMatch(/totp=[A-Za-z0-9+/]{32}/); + expect(mount.content).toMatch(/secret=[A-Za-z0-9+/]{86,88}/); + expect(mount.content).toMatch(/totp=[A-Za-z0-9+/]{42,44}/); }); });