wordpress-develop/tests/phpunit/tests/option/sanitize-option.php
Sergey Biryukov 164b22cf6a Tests: First pass at using assertSame() instead of assertEquals() in most of the unit tests.
This ensures that not only the return values match the expected results, but also that their type is the same.

Going forward, stricter type checking by using `assertSame()` should generally be preferred to `assertEquals()` where appropriate, to make the tests more reliable.

Props johnbillion, jrf, SergeyBiryukov.
See #38266.

git-svn-id: https://develop.svn.wordpress.org/trunk@48937 602fd350-edb4-49c9-b593-d223f7449a82
2020-09-02 00:35:36 +00:00

162 lines
5.4 KiB
PHP

<?php
/**
* @group option
*/
class Tests_Sanitize_Option extends WP_UnitTestCase {
/**
* Data provider to test all of the sanitize_option() case
*
* Inner array params: $option_name, $sanitized, $original
*
* @return array
*/
public function sanitize_option_provider() {
return array(
array( 'admin_email', 'mail@example.com', 'mail@example.com' ),
array( 'admin_email', get_option( 'admin_email' ), 'invalid' ),
array( 'page_on_front', 0, 0 ),
array( 'page_on_front', 10, '-10' ),
array( 'posts_per_page', 10, 10 ),
array( 'posts_per_page', -1, -1 ),
array( 'posts_per_page', 2, -2 ),
array( 'posts_per_page', 1, 'ten' ),
array( 'default_ping_status', 'open', 'open' ),
array( 'default_ping_status', 'closed', '' ),
array( 'blogname', 'My Site', 'My Site' ),
array( 'blogname', '&lt;i&gt;My Site&lt;/i&gt;', '<i>My Site</i>' ),
array( 'blog_charset', 'UTF-8', 'UTF-8' ),
array( 'blog_charset', 'charset', '">charset<"' ),
array( 'blog_public', 1, null ),
array( 'blog_public', 1, '1' ),
array( 'blog_public', -2, '-2' ),
array( 'date_format', 'F j, Y', 'F j, Y' ),
array( 'date_format', 'F j, Y', 'F j, <strong>Y</strong>' ),
array( 'ping_sites', 'http://rpc.pingomatic.com/', 'http://rpc.pingomatic.com/' ),
array( 'ping_sites', "http://www.example.com\nhttp://example.org", "www.example.com \n\texample.org\n\n" ),
array( 'gmt_offset', '0', 0 ),
array( 'gmt_offset', '1.5', '1.5' ),
array( 'siteurl', 'http://example.org', 'http://example.org' ),
array( 'siteurl', 'http://example.org/subdir', 'http://example.org/subdir' ),
array( 'siteurl', get_option( 'siteurl' ), '' ),
array( 'home', 'http://example.org', 'http://example.org' ),
array( 'home', 'https://example.org', 'https://example.org' ),
array( 'home', 'http://localhost:8000', 'http://localhost:8000' ),
array( 'home', get_option( 'home' ), '' ),
array( 'WPLANG', 0, 0 ),
array( 'WPLANG', '', '' ),
array(
'illegal_names',
array( 'www', 'web', 'root', 'admin', 'main', 'invite', 'administrator', 'files' ),
array( 'www', 'web', 'root', 'admin', 'main', 'invite', 'administrator', 'files' ),
),
array(
'illegal_names',
array( 'www', 'web', 'root', 'admin', 'main', 'invite', 'administrator', 'files' ),
'www web root admin main invite administrator files',
),
array(
'banned_email_domains',
array( 'mail.com', 'gmail.com' ),
array( 'mail.com', 'gmail.com' ),
),
array(
'banned_email_domains',
array( 'mail.com' ),
"mail.com\ngmail,com",
),
array( 'timezone_string', 0, 0 ),
array( 'timezone_string', 'Europe/London', 'Europe/London' ),
array( 'timezone_string', get_option( 'timezone_string' ), 'invalid' ),
array( 'permalink_structure', '', '' ),
array( 'permalink_structure', '/%year%/%20%postname%', '/%year%/ %postname%' ),
array( 'default_role', 'subscriber', 'subscriber' ),
array( 'default_role', 'subscriber', 'invalid' ),
array( 'default_role', 'editor', 'editor' ),
array( 'moderation_keys', 'string of words', 'string of words' ),
array( 'moderation_keys', "one\ntwo three", "one\none\ntwo three" ),
);
}
/**
* @dataProvider sanitize_option_provider
*/
public function test_sanitize_option( $option_name, $sanitized, $original ) {
$this->assertSame( $sanitized, sanitize_option( $option_name, $original ) );
}
public function upload_path_provider() {
return array(
array( '<a href="http://www.example.com">Link</a>', 'Link' ),
array( '<scr' . 'ipt>url</scr' . 'ipt>', 'url' ),
array( '/path/to/things', '/path/to/things' ),
array( '\path\to\things', '\path\to\things' ),
);
}
/**
* @dataProvider upload_path_provider
*/
public function test_sanitize_option_upload_path( $provided, $expected ) {
$this->assertSame( $expected, sanitize_option( 'upload_path', $provided ) );
}
/**
* @ticket 36122
*/
public function test_emoji_in_blogname_and_description() {
global $wpdb;
$value = "whee\xf0\x9f\x98\x88";
if ( 'utf8mb4' === $wpdb->get_col_charset( $wpdb->options, 'option_value' ) ) {
$expected = $value;
} else {
$expected = 'whee&#x1f608;';
}
$this->assertSame( $expected, sanitize_option( 'blogname', $value ) );
$this->assertSame( $expected, sanitize_option( 'blogdescription', $value ) );
}
/**
* @dataProvider permalink_structure_provider
*/
public function test_sanitize_permalink_structure( $provided, $expected, $valid ) {
global $wp_settings_errors;
$old_wp_settings_errors = (array) $wp_settings_errors;
$actual = sanitize_option( 'permalink_structure', $provided );
$errors = get_settings_errors( 'permalink_structure' );
// Clear errors.
$wp_settings_errors = $old_wp_settings_errors;
if ( $valid ) {
$this->assertEmpty( $errors );
} else {
$this->assertNotEmpty( $errors );
$this->assertSame( 'invalid_permalink_structure', $errors[0]['code'] );
}
$this->assertEquals( $expected, $actual );
}
public function permalink_structure_provider() {
return array(
array( '', '', true ),
array( '%postname', false, false ),
array( '%/%', false, false ),
array( '%%%', false, false ),
array( '%a%', '%a%', true ),
array( '%postname%', '%postname%', true ),
array( '/%postname%/', '/%postname%/', true ),
array( '/%year%/%monthnum%/%day%/%postname%/', '/%year%/%monthnum%/%day%/%postname%/', true ),
array( '/%year/%postname%/', '/%year/%postname%/', true ),
);
}
}