Initial commit
This commit is contained in:
76
test/url-encoding.test.ts
Normal file
76
test/url-encoding.test.ts
Normal file
@@ -0,0 +1,76 @@
|
||||
import { expect, describe, it } from "bun:test";
|
||||
import { ensureProperlyEncodedUrl } from "../src/github/operations/comment-logic";
|
||||
|
||||
describe("ensureProperlyEncodedUrl", () => {
|
||||
it("should handle URLs with spaces", () => {
|
||||
const url =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix: update message&body=Description here";
|
||||
const expected =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix%3A+update+message&body=Description+here";
|
||||
expect(ensureProperlyEncodedUrl(url)).toBe(expected);
|
||||
});
|
||||
|
||||
it("should handle URLs with unencoded colons", () => {
|
||||
const url =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix: update message";
|
||||
const expected =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix%3A+update+message";
|
||||
expect(ensureProperlyEncodedUrl(url)).toBe(expected);
|
||||
});
|
||||
|
||||
it("should handle URLs that are already properly encoded", () => {
|
||||
const url =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix%3A%20update%20message&body=Description%20here";
|
||||
expect(ensureProperlyEncodedUrl(url)).toBe(url);
|
||||
});
|
||||
|
||||
it("should handle URLs with partially encoded content", () => {
|
||||
const url =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix%3A update message&body=Description here";
|
||||
const expected =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix%3A+update+message&body=Description+here";
|
||||
expect(ensureProperlyEncodedUrl(url)).toBe(expected);
|
||||
});
|
||||
|
||||
it("should handle URLs with special characters", () => {
|
||||
const url =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=feat(scope): add new feature!&body=This is a description with #123";
|
||||
const expected =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=feat%28scope%29%3A+add+new+feature%21&body=This+is+a+description+with+%23123";
|
||||
expect(ensureProperlyEncodedUrl(url)).toBe(expected);
|
||||
});
|
||||
|
||||
it("should not encode the base URL", () => {
|
||||
const url =
|
||||
"https://github.com/owner/repo/compare/main...feature/new-branch?quick_pull=1&title=fix: test";
|
||||
const expected =
|
||||
"https://github.com/owner/repo/compare/main...feature/new-branch?quick_pull=1&title=fix%3A+test";
|
||||
expect(ensureProperlyEncodedUrl(url)).toBe(expected);
|
||||
});
|
||||
|
||||
it("should handle malformed URLs gracefully", () => {
|
||||
const url =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix: test&body=";
|
||||
const expected =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix%3A+test&body=";
|
||||
expect(ensureProperlyEncodedUrl(url)).toBe(expected);
|
||||
});
|
||||
|
||||
it("should handle URLs with line breaks in parameters", () => {
|
||||
const url =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix: test&body=Line 1\nLine 2";
|
||||
const expected =
|
||||
"https://github.com/owner/repo/compare/main...branch?quick_pull=1&title=fix%3A+test&body=Line+1%0ALine+2";
|
||||
expect(ensureProperlyEncodedUrl(url)).toBe(expected);
|
||||
});
|
||||
|
||||
it("should return null for completely invalid URLs", () => {
|
||||
const url = "not-a-url-at-all";
|
||||
expect(ensureProperlyEncodedUrl(url)).toBe(null);
|
||||
});
|
||||
|
||||
it("should handle URLs with severe malformation", () => {
|
||||
const url = "https://[invalid:url:format]/path";
|
||||
expect(ensureProperlyEncodedUrl(url)).toBe(null);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user