wordpress-develop/tests/phpunit/tests/option/option.php
Sergey Biryukov c33e34d8a5 Tests: Rename classes in phpunit/tests/option/ per the naming conventions.
https://make.wordpress.org/core/handbook/testing/automated-testing/writing-phpunit-tests/#naming-and-organization

Follow-up to [47780], [48911], [49327], [50291], [50292], [50342], [50452], [50453], [50456], [50967], [50968], [50969], [51491], [51492], [51493], [51623], [51639], [51646], [51650], [51651], [51860], [52264], [52265], [53489].

See #55652.

git-svn-id: https://develop.svn.wordpress.org/trunk@53494 602fd350-edb4-49c9-b593-d223f7449a82
2022-06-13 15:24:11 +00:00

259 lines
7.0 KiB
PHP

<?php
/**
* @group option
*/
class Tests_Option_Option extends WP_UnitTestCase {
public function __return_foo() {
return 'foo';
}
public function test_the_basics() {
$key = 'key1';
$key2 = 'key2';
$value = 'value1';
$value2 = 'value2';
$this->assertFalse( get_option( 'doesnotexist' ) );
$this->assertTrue( add_option( $key, $value ) );
$this->assertSame( $value, get_option( $key ) );
$this->assertFalse( add_option( $key, $value ) ); // Already exists.
$this->assertFalse( update_option( $key, $value ) ); // Value is the same.
$this->assertTrue( update_option( $key, $value2 ) );
$this->assertSame( $value2, get_option( $key ) );
$this->assertFalse( add_option( $key, $value ) );
$this->assertSame( $value2, get_option( $key ) );
$this->assertTrue( delete_option( $key ) );
$this->assertFalse( get_option( $key ) );
$this->assertFalse( delete_option( $key ) );
$this->assertTrue( update_option( $key2, $value2 ) );
$this->assertSame( $value2, get_option( $key2 ) );
$this->assertTrue( delete_option( $key2 ) );
$this->assertFalse( get_option( $key2 ) );
}
public function test_default_filter() {
$value = 'value';
$this->assertFalse( get_option( 'doesnotexist' ) );
// Default filter overrides $default arg.
add_filter( 'default_option_doesnotexist', array( $this, '__return_foo' ) );
$this->assertSame( 'foo', get_option( 'doesnotexist', 'bar' ) );
// Remove the filter and the $default arg is honored.
remove_filter( 'default_option_doesnotexist', array( $this, '__return_foo' ) );
$this->assertSame( 'bar', get_option( 'doesnotexist', 'bar' ) );
// Once the option exists, the $default arg and the default filter are ignored.
add_option( 'doesnotexist', $value );
$this->assertSame( $value, get_option( 'doesnotexist', 'foo' ) );
add_filter( 'default_option_doesnotexist', array( $this, '__return_foo' ) );
$this->assertSame( $value, get_option( 'doesnotexist', 'foo' ) );
remove_filter( 'default_option_doesnotexist', array( $this, '__return_foo' ) );
// Cleanup.
$this->assertTrue( delete_option( 'doesnotexist' ) );
$this->assertFalse( get_option( 'doesnotexist' ) );
}
/**
* @ticket 31047
*/
public function test_add_option_should_respect_default_option_filter() {
add_filter( 'default_option_doesnotexist', array( $this, '__return_foo' ) );
$added = add_option( 'doesnotexist', 'bar' );
remove_filter( 'default_option_doesnotexist', array( $this, '__return_foo' ) );
$this->assertTrue( $added );
$this->assertSame( 'bar', get_option( 'doesnotexist' ) );
}
public function test_serialized_data() {
$key = __FUNCTION__;
$value = array(
'foo' => true,
'bar' => true,
);
$this->assertTrue( add_option( $key, $value ) );
$this->assertSame( $value, get_option( $key ) );
$value = (object) $value;
$this->assertTrue( update_option( $key, $value ) );
$this->assertEquals( $value, get_option( $key ) );
$this->assertTrue( delete_option( $key ) );
}
/**
* @ticket 23289
*
* @dataProvider data_bad_option_names
*
* @param mixed $option_name Option name.
*/
public function test_get_option_bad_option_name( $option_name ) {
$this->assertFalse( get_option( $option_name ) );
}
/**
* @ticket 23289
*
* @dataProvider data_bad_option_names
*
* @param mixed $option_name Option name.
*/
public function test_add_option_bad_option_name( $option_name ) {
$this->assertFalse( add_option( $option_name, '' ) );
}
/**
* @ticket 23289
*
* @dataProvider data_bad_option_names
*
* @param mixed $option_name Option name.
*/
public function test_update_option_bad_option_name( $option_name ) {
$this->assertFalse( update_option( $option_name, '' ) );
}
/**
* @ticket 23289
*
* @dataProvider data_bad_option_names
*
* @param mixed $option_name Option name.
*/
public function test_delete_option_bad_option_name( $option_name ) {
$this->assertFalse( delete_option( $option_name ) );
}
/**
* Data provider.
*
* @return array
*/
public function data_bad_option_names() {
return array(
'empty string' => array( '' ),
'string 0' => array( '0' ),
'string single space' => array( ' ' ),
'integer 0' => array( 0 ),
'float 0.0' => array( 0.0 ),
'boolean false' => array( false ),
'null' => array( null ),
);
}
/**
* @ticket 53635
*
* @dataProvider data_valid_but_undesired_option_names
*
* @param mixed $option_name Option name.
*/
public function test_get_option_valid_but_undesired_option_names( $option_name ) {
$this->assertFalse( get_option( $option_name ) );
}
/**
* @ticket 53635
*
* @dataProvider data_valid_but_undesired_option_names
*
* @param mixed $option_name Option name.
*/
public function test_add_option_valid_but_undesired_option_names( $option_name ) {
$this->assertTrue( add_option( $option_name, '' ) );
}
/**
* @ticket 53635
*
* @dataProvider data_valid_but_undesired_option_names
*
* @param mixed $option_name Option name.
*/
public function test_update_option_valid_but_undesired_option_names( $option_name ) {
$this->assertTrue( update_option( $option_name, '' ) );
}
/**
* @ticket 53635
*
* @dataProvider data_valid_but_undesired_option_names
*
* @param mixed $option_name Option name.
*/
public function test_delete_option_valid_but_undesired_option_names( $option_name ) {
$this->assertFalse( delete_option( $option_name ) );
}
/**
* Data provider.
*
* @return array
*/
public function data_valid_but_undesired_option_names() {
return array(
'string 123' => array( '123' ),
'integer 123' => array( 123 ),
'integer -123' => array( -123 ),
'float 12.3' => array( 12.3 ),
'float -1.23' => array( -1.23 ),
'boolean true' => array( true ),
);
}
/**
* @ticket 23289
*/
public function test_special_option_name_alloption() {
$this->expectException( 'WPDieException' );
delete_option( 'alloptions' );
}
/**
* @ticket 23289
*/
public function test_special_option_name_notoptions() {
$this->expectException( 'WPDieException' );
delete_option( 'notoptions' );
}
/**
* Options should be autoloaded unless they were added with "no" or `false`.
*
* @ticket 31119
* @dataProvider data_option_autoloading
*/
public function test_option_autoloading( $name, $autoload_value, $expected ) {
global $wpdb;
$added = add_option( $name, 'Autoload test', '', $autoload_value );
$this->assertTrue( $added );
$actual = $wpdb->get_row( $wpdb->prepare( "SELECT autoload FROM $wpdb->options WHERE option_name = %s LIMIT 1", $name ) );
$this->assertSame( $expected, $actual->autoload );
}
/**
* Data provider.
*
* @return array
*/
public function data_option_autoloading() {
return array(
array( 'autoload_yes', 'yes', 'yes' ),
array( 'autoload_true', true, 'yes' ),
array( 'autoload_string', 'foo', 'yes' ),
array( 'autoload_int', 123456, 'yes' ),
array( 'autoload_array', array(), 'yes' ),
array( 'autoload_no', 'no', 'no' ),
array( 'autoload_false', false, 'no' ),
);
}
}