mirror of
https://github.com/phpbb/phpbb.git
synced 2025-07-30 21:40:43 +02:00
[ticket/12926] Support for IDN (IRI)
Add international domain name support for URLs. PHPBB3-12926
This commit is contained in:
@@ -74,13 +74,77 @@ class phpbb_functions_make_clickable_test extends phpbb_test_case
|
||||
'http://www.phpbb.com/community/path/to/long/url/file.ext#section',
|
||||
'<!-- m --><a class="postlink" href="http://www.phpbb.com/community/path/to/long/url/file.ext#section">http://www.phpbb.com/community/path/to/ ... xt#section</a><!-- m -->'
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
// IDN is not parsed and returned as is
|
||||
array('http://домен.рф', 'http://домен.рф'),
|
||||
public function data_test_make_clickable_url_idn()
|
||||
{
|
||||
return array(
|
||||
array(
|
||||
'http://www.täst.de/community/',
|
||||
'<!-- m --><a class="postlink" href="http://www.täst.de/community/">http://www.täst.de/community/</a><!-- m -->'
|
||||
),
|
||||
array(
|
||||
'http://www.täst.de/path/file.ext#section',
|
||||
'<!-- m --><a class="postlink" href="http://www.täst.de/path/file.ext#section">http://www.täst.de/path/file.ext#section</a><!-- m -->'
|
||||
),
|
||||
array(
|
||||
'ftp://ftp.täst.de/',
|
||||
'<!-- m --><a class="postlink" href="ftp://ftp.täst.de/">ftp://ftp.täst.de/</a><!-- m -->'
|
||||
),
|
||||
array(
|
||||
'sip://bantu@täst.de',
|
||||
'<!-- m --><a class="postlink" href="sip://bantu@täst.de">sip://bantu@täst.de</a><!-- m -->'
|
||||
),
|
||||
array(
|
||||
'www.täst.de/community/',
|
||||
'<!-- w --><a class="postlink" href="http://www.täst.de/community/">www.täst.de/community/</a><!-- w -->'
|
||||
),
|
||||
// Test appending punctuation mark to the URL
|
||||
array(
|
||||
'http://домен.рф/viewtopic.php?t=1!',
|
||||
'<!-- m --><a class="postlink" href="http://домен.рф/viewtopic.php?t=1">http://домен.рф/viewtopic.php?t=1</a><!-- m -->!'
|
||||
),
|
||||
array(
|
||||
'www.домен.рф/сообщество/?',
|
||||
'<!-- w --><a class="postlink" href="http://www.домен.рф/сообщество/">www.домен.рф/сообщество/</a><!-- w -->?'
|
||||
),
|
||||
// Test shortened text for URL > 55 characters long
|
||||
// URL text should be turned into: first 39 chars + ' ... ' + last 10 chars
|
||||
array(
|
||||
'http://www.домен.рф/сообщество/путь/по/длинной/ссылке/file.ext#section',
|
||||
'<!-- m --><a class="postlink" href="http://www.домен.рф/сообщество/путь/по/длинной/ссылке/file.ext#section">http://www.домен.рф/сообщество/путь/по/ ... xt#section</a><!-- m -->'
|
||||
),
|
||||
|
||||
// IDN with invalid characters shouldn't be parsed correctly (only 'valid' part)
|
||||
array(
|
||||
'http://www.täst╫.de',
|
||||
'<!-- m --><a class="postlink" href="http://www.täst">http://www.täst</a><!-- m -->╫.de'
|
||||
),
|
||||
// IDN in emails is unsupported yet
|
||||
array('почта@домен.рф', 'почта@домен.рф'),
|
||||
);
|
||||
}
|
||||
|
||||
public function data_test_make_clickable_local_url_idn()
|
||||
{
|
||||
return array(
|
||||
array(
|
||||
'http://www.домен.рф/viewtopic.php?t=1',
|
||||
'<!-- l --><a class="postlink-local" href="http://www.домен.рф/viewtopic.php?t=1">viewtopic.php?t=1</a><!-- l -->'
|
||||
),
|
||||
// Test appending punctuation mark to the URL
|
||||
array(
|
||||
'http://www.домен.рф/viewtopic.php?t=1!',
|
||||
'<!-- l --><a class="postlink-local" href="http://www.домен.рф/viewtopic.php?t=1">viewtopic.php?t=1</a><!-- l -->!'
|
||||
),
|
||||
array(
|
||||
'http://www.домен.рф/сообщество/?',
|
||||
'<!-- l --><a class="postlink-local" href="http://www.домен.рф/сообщество/">сообщество/</a><!-- l -->?'
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
parent::setUp();
|
||||
@@ -97,4 +161,20 @@ class phpbb_functions_make_clickable_test extends phpbb_test_case
|
||||
{
|
||||
$this->assertSame($expected, make_clickable($url));
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider data_test_make_clickable_url_idn
|
||||
*/
|
||||
public function test_urls_matching_idn($url, $expected)
|
||||
{
|
||||
$this->assertSame($expected, make_clickable($url));
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider data_test_make_clickable_local_url_idn
|
||||
*/
|
||||
public function test_local_urls_matching_idn($url, $expected)
|
||||
{
|
||||
$this->assertSame($expected, make_clickable($url, "http://www.домен.рф"));
|
||||
}
|
||||
}
|
||||
|
@@ -89,6 +89,32 @@ class phpbb_profilefield_type_url_test extends phpbb_test_case
|
||||
'FIELD_INVALID_URL-field',
|
||||
'Field should reject invalid URL having multi value parameters',
|
||||
),
|
||||
|
||||
// IDN url type profilefields
|
||||
array(
|
||||
'http://www.täst.de',
|
||||
array(),
|
||||
false,
|
||||
'Field should accept valid IDN',
|
||||
),
|
||||
array(
|
||||
'http://täst.de/index.html?param1=test¶m2=awesome',
|
||||
array(),
|
||||
false,
|
||||
'Field should accept valid IDN URL with params',
|
||||
),
|
||||
array(
|
||||
'http://домен.рф/index.html/тест/path?document=get',
|
||||
array(),
|
||||
false,
|
||||
'Field should accept valid IDN URL',
|
||||
),
|
||||
array(
|
||||
'http://домен.рф/index.html/тест/path?document[]=DocType%20test&document[]=AnotherDoc',
|
||||
array(),
|
||||
'FIELD_INVALID_URL-field',
|
||||
'Field should reject invalid IDN URL having multi value parameters',
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
@@ -119,6 +145,20 @@ class phpbb_profilefield_type_url_test extends phpbb_test_case
|
||||
'http://example.com',
|
||||
'Field should return correct raw value',
|
||||
),
|
||||
|
||||
// IDN tests
|
||||
array(
|
||||
'http://täst.de',
|
||||
array('field_show_novalue' => true),
|
||||
'http://täst.de',
|
||||
'Field should return the correct raw value',
|
||||
),
|
||||
array(
|
||||
'http://домен.рф',
|
||||
array('field_show_novalue' => false),
|
||||
'http://домен.рф',
|
||||
'Field should return correct raw value',
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
|
@@ -32,6 +32,6 @@ class phpbb_regex_url_test extends phpbb_test_case
|
||||
*/
|
||||
public function test_url($url, $expected)
|
||||
{
|
||||
$this->assertEquals($expected, preg_match('#^' . get_preg_expression('url') . '$#i', $url));
|
||||
$this->assertEquals($expected, preg_match('#^' . get_preg_expression('url') . '$#iu', $url));
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user