diff options
| author | Jörg Frings-Fürst <debian@jff-webhsoting.net> | 2022-10-29 22:32:11 +0200 | 
|---|---|---|
| committer | Jörg Frings-Fürst <debian@jff-webhsoting.net> | 2022-10-29 22:32:11 +0200 | 
| commit | 0c23cbef1a729b95597d225cad90345a0cf7de9a (patch) | |
| tree | 697f20d2671106e317eafdc9535693e4aa8535db /test/test.cpp | |
| parent | 130dc6e51879b4e337a53719ef325c7d6b3dae94 (diff) | |
| parent | 1d7d65107664f3451d7384598209e5dfcbb871cc (diff) | |
Merge branch 'feature/upstream' into develop
Diffstat (limited to 'test/test.cpp')
| -rw-r--r-- | test/test.cpp | 38 | 
1 files changed, 38 insertions, 0 deletions
| diff --git a/test/test.cpp b/test/test.cpp index 31e9866..fade025 100644 --- a/test/test.cpp +++ b/test/test.cpp @@ -213,6 +213,18 @@ TEST(UriSuite, TestIpSixPass) {  		URI_TEST_IP_SIX_PASS("2001:db8:100:f101::1");  		URI_TEST_IP_SIX_PASS("a:b:c::12:1");  		URI_TEST_IP_SIX_PASS("a:b::0:1:2:3"); + +		// Issue #146: These are not leading zeros. +		URI_TEST_IP_SIX_PASS("::100.1.1.1"); +		URI_TEST_IP_SIX_PASS("::1.100.1.1"); +		URI_TEST_IP_SIX_PASS("::1.1.100.1"); +		URI_TEST_IP_SIX_PASS("::1.1.1.100"); +		URI_TEST_IP_SIX_PASS("::100.100.100.100"); +		URI_TEST_IP_SIX_PASS("::10.1.1.1"); +		URI_TEST_IP_SIX_PASS("::1.10.1.1"); +		URI_TEST_IP_SIX_PASS("::1.1.10.1"); +		URI_TEST_IP_SIX_PASS("::1.1.1.10"); +		URI_TEST_IP_SIX_PASS("::10.10.10.10");  }  TEST(UriSuite, TestIpSixFail) { @@ -259,6 +271,32 @@ TEST(UriSuite, TestIpSixFail) {  		// Nonhex  		URI_TEST_IP_SIX_FAIL("g:0:0:0:0:0:0"); + +		// Issue #146: Zipper between the 7th and 8th quads. +		URI_TEST_IP_SIX_FAIL("0:0:0:0:0:0:0::1"); + +		// Issue #146: Leading or trailing ":". +		URI_TEST_IP_SIX_FAIL(":1::1"); +		URI_TEST_IP_SIX_FAIL("1::1:"); +		URI_TEST_IP_SIX_FAIL(":1::1:"); +		URI_TEST_IP_SIX_FAIL(":0:0:0:0:0:0:0:0"); +		URI_TEST_IP_SIX_FAIL("0:0:0:0:0:0:0:0:"); +		URI_TEST_IP_SIX_FAIL(":0:0:0:0:0:0:0:0:"); + +		// Issue #146: Zipper between six quads and IPv4 address. +		URI_TEST_IP_SIX_FAIL("1:1:1:1:1:1::1.1.1.1"); +} + +TEST(UriSuite, TestIpFuture) { +		UriParserStateA stateA; +		UriUriA uriA; +		stateA.uri = &uriA; + +		// Issue #146: The leading "v" of IPvFuture is case-insensitive. +		ASSERT_TRUE(0 == uriParseUriA(&stateA, "//[vF.addr]")); +		uriFreeUriMembersA(&uriA); +		ASSERT_TRUE(0 == uriParseUriA(&stateA, "//[VF.addr]")); +		uriFreeUriMembersA(&uriA);  }  TEST(UriSuite, TestIpSixOverread) { | 
