mirror of
https://framagit.org/hubzilla/core.git
synced 2026-06-21 09:01:15 -04:00
103 lines
2.7 KiB
PHP
103 lines
2.7 KiB
PHP
<?php
|
|
/**
|
|
* tests function from include/network.php
|
|
*
|
|
* @package test.util
|
|
*/
|
|
|
|
class NetworkTest extends Zotlabs\Tests\Unit\UnitTestCase {
|
|
|
|
/**
|
|
* @dataProvider localUrlTestProvider
|
|
*/
|
|
public function testIsLocalURL($url, $expected) {
|
|
$this->assertEquals($expected, is_local_url($url));
|
|
}
|
|
|
|
public static function localUrlTestProvider() : array {
|
|
return [
|
|
[ '/some/path', true ],
|
|
[ 'https://hubzilla.test/some/path', true ],
|
|
[ 'https://other.site/some/path', false ],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Test the validate_email function.
|
|
*
|
|
* @dataProvider validate_email_provider
|
|
*/
|
|
public function test_validate_email(string $email, bool $expected) : void {
|
|
$this->assertEquals($expected, validate_email($email));
|
|
}
|
|
|
|
/**
|
|
* Test that the validate_email function is disabled when configured to.
|
|
*
|
|
* @dataProvider validate_email_provider
|
|
*/
|
|
public function test_disable_validate_email(string $email) : void {
|
|
\Zotlabs\Lib\Config::Set('system', 'disable_email_validation', true);
|
|
$this->assertTrue(validate_email($email));
|
|
}
|
|
|
|
public static function validate_email_provider() : array {
|
|
return [
|
|
// First some invalid email addresses
|
|
['', false],
|
|
['not_an_email', false],
|
|
['@not_an_email', false],
|
|
['not@an@email', false],
|
|
['not@an@email.com', false],
|
|
|
|
// then test valid addresses too
|
|
['test@example.com', true],
|
|
|
|
// Should also work with international domains
|
|
['some.email@dømain.net', true],
|
|
|
|
// Should also work with the new top-level domains
|
|
['some.email@example.cancerresearch', true],
|
|
|
|
// And internationalized TLD's
|
|
['some.email@example.شبكة', true],
|
|
|
|
// Allow plus/minus addressing
|
|
['address+tag@example.com', true],
|
|
['address-tag@example.com', true],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Test that the parse_webbie function.
|
|
*
|
|
* @dataProvider parse_webbie_provider
|
|
*/
|
|
public function test_parse_webbie(string $webbie, array|false $expected) : void {
|
|
$this->assertEquals($expected, parse_webbie($webbie));
|
|
}
|
|
|
|
public static function parse_webbie_provider() : array {
|
|
return [
|
|
// test valid webfinger address
|
|
['test@example.net', ['host' => 'example.net', 'resource' => urlencode('acct:test@example.net')]],
|
|
|
|
// test valid webfinger address with scheme
|
|
['acct:test@example.net', ['host' => 'example.net', 'resource' => urlencode('acct:test@example.net')]],
|
|
|
|
// test address with leading @
|
|
['@test@example.net', ['host' => 'example.net', 'resource' => urlencode('acct:test@example.net')]],
|
|
|
|
// test address with missing user
|
|
['@example.net', false],
|
|
|
|
// test URL
|
|
['https://example.net/channel/test', ['host' => 'example.net', 'resource' => urlencode('https://example.net/channel/test')]],
|
|
|
|
// test unsupported URL
|
|
['ftp://example.net/channel/test', false],
|
|
];
|
|
}
|
|
|
|
}
|