description("Canonicalization of IPv4 addresses."); cases = [ [".", ""], // Regular IP addresses in different bases. ["192.168.0.1", "192.168.0.1"], ["0300.0250.00.01", "192.168.0.1"], ["0xC0.0Xa8.0x0.0x1", "192.168.0.1"], // Non-IP addresses due to invalid characters. ["192.168.9.com", ""], // Invalid characters for the base should be rejected. ["19a.168.0.1", ""], ["0308.0250.00.01", ""], ["0xCG.0xA8.0x0.0x1", ""], // If there are not enough components, the last one should fill them out. ["192", "0.0.0.192"], ["0xC0a80001", "192.168.0.1"], ["030052000001", "192.168.0.1"], ["000030052000001", "192.168.0.1"], ["192.168", "192.0.0.168"], ["192.0x00A80001", "192.168.0.1"], ["0xc0.052000001", "192.168.0.1"], ["192.168.1", "192.168.0.1"], // Too many components means not an IP address. ["192.168.0.0.1", ""], // We allow a single trailing dot. ["192.168.0.1.", "192.168.0.1"], ["192.168.0.1. hello", ""], ["192.168.0.1..", ""], // Two dots in a row means not an IP address. ["192.168..1", ""], // Any numerical overflow should be marked as BROKEN. ["0x100.0", ""], ["0x100.0.0", ""], ["0x100.0.0.0", ""], ["0.0x100.0.0", ""], ["0.0.0x100.0", ""], ["0.0.0.0x100", ""], ["0.0.0x10000", ""], ["0.0x1000000", ""], ["0x100000000", ""], // Repeat the previous tests, minus 1, to verify boundaries. ["0xFF.0", "255.0.0.0"], ["0xFF.0.0", "255.0.0.0"], ["0xFF.0.0.0", "255.0.0.0"], ["0.0xFF.0.0", "0.255.0.0"], ["0.0.0xFF.0", "0.0.255.0"], ["0.0.0.0xFF", "0.0.0.255"], ["0.0.0xFFFF", "0.0.255.255"], ["0.0xFFFFFF", "0.255.255.255"], ["0xFFFFFFFF", "255.255.255.255"], // Old trunctations tests. They're all "BROKEN" now. ["276.256.0xf1a2.077777", ""], ["192.168.0.257", ""], ["192.168.0xa20001", ""], ["192.015052000001", ""], ["0X12C0a80001", ""], ["276.1.2", ""], // Spaces should be rejected. ["192.168.0.1 hello", ""], // Very large numbers. ["0000000000000300.0x00000000000000fF.00000000000000001", "192.255.0.1"], ["0000000000000300.0xffffffffFFFFFFFF.3022415481470977", ""], // A number has no length limit, but long numbers can still overflow. ["00000000000000000001", "0.0.0.1"], ["0000000000000000100000000000000001", ""], // If a long component is non-numeric, it's a hostname, *not* a broken IP. ["0.0.0.000000000000000000z", ""], ["0.0.0.100000000000000000z", ""], // Truncation of all zeros should still result in 0. ["0.00.0x.0x0", "0.0.0.0"] ]; // We test the empty string individually. shouldBe("canonicalize('http:///')", "'http:'"); for (var i = 0; i < cases.length; ++i) { test_vector = cases[i][0]; expected_result = cases[i][1]; if (expected_result === "") { // We use "" to represent that the test vector ought not to parse. // It appears that we're supposed to apply a default canonicalization. expected_result = escape(test_vector.toLowerCase()); } shouldBe("canonicalize('http://" + test_vector + "/')", "'http://" + expected_result + "/'"); } var successfullyParsed = true;