Wordpress/tests/phpunit/tests/user.php
Sergey Biryukov 1106d82f93 Privacy: Introduce filters for the headers of all the privacy-related e-mails:
* `wp_privacy_personal_data_email_headers`
* `user_request_confirmed_email_headers`
* `user_erasure_complete_email_headers`
* `user_request_action_email_headers`

Props xkon, garrett-eclipse, zaffarn, desrosj.
Fixes #44501.

git-svn-id: https://develop.svn.wordpress.org/trunk@47279 602fd350-edb4-49c9-b593-d223f7449a82
2020-02-11 21:41:26 +00:00

1933 lines
54 KiB
PHP

<?php
/**
* Test functions in wp-includes/user.php
*
* @group user
*/
class Tests_User extends WP_UnitTestCase {
protected static $admin_id;
protected static $editor_id;
protected static $author_id;
protected static $contrib_id;
protected static $sub_id;
protected static $user_ids = array();
protected static $_author;
protected $author;
protected $user_data;
public static function wpSetUpBeforeClass( $factory ) {
self::$contrib_id = $factory->user->create(
array(
'user_login' => 'user1',
'user_nicename' => 'userone',
'user_pass' => 'password',
'first_name' => 'John',
'last_name' => 'Doe',
'display_name' => 'John Doe',
'user_email' => 'blackburn@battlefield3.com',
'user_url' => 'http://tacos.com',
'role' => 'contributor',
'nickname' => 'Johnny',
'description' => 'I am a WordPress user that cares about privacy.',
)
);
self::$user_ids[] = self::$contrib_id;
self::$author_id = $factory->user->create(
array(
'user_login' => 'author_login',
'user_email' => 'author@email.com',
'role' => 'author',
)
);
self::$user_ids[] = self::$author_id;
self::$admin_id = $factory->user->create( array( 'role' => 'administrator' ) );
self::$user_ids[] = self::$admin_id;
self::$editor_id = $factory->user->create(
array(
'user_email' => 'test@test.com',
'role' => 'editor',
)
);
self::$user_ids[] = self::$editor_id;
self::$sub_id = $factory->user->create( array( 'role' => 'subscriber' ) );
self::$user_ids[] = self::$sub_id;
self::$_author = get_user_by( 'ID', self::$author_id );
}
function setUp() {
parent::setUp();
$this->author = clone self::$_author;
}
function test_get_users_of_blog() {
// Add one of each user role.
$nusers = array(
self::$contrib_id,
self::$author_id,
self::$admin_id,
self::$editor_id,
self::$sub_id,
);
$user_list = get_users();
// Find the role of each user as returned by get_users_of_blog().
$found = array();
foreach ( $user_list as $user ) {
// Only include the users we just created - there might be some others that existed previously.
if ( in_array( $user->ID, $nusers, true ) ) {
$found[] = $user->ID;
}
}
// Make sure every user we created was returned.
$this->assertEqualSets( $nusers, $found );
}
// Simple get/set tests for user_option functions.
function test_user_option() {
$key = rand_str();
$val = rand_str();
// Get an option that doesn't exist.
$this->assertFalse( get_user_option( $key, self::$author_id ) );
// Set and get.
update_user_option( self::$author_id, $key, $val );
$this->assertEquals( $val, get_user_option( $key, self::$author_id ) );
// Change and get again.
$val2 = rand_str();
update_user_option( self::$author_id, $key, $val2 );
$this->assertEquals( $val2, get_user_option( $key, self::$author_id ) );
}
/**
* Simple tests for usermeta functions.
*/
function test_usermeta() {
$key = 'key';
$val = 'value1';
// Get a meta key that doesn't exist.
$this->assertEquals( '', get_user_meta( self::$author_id, $key, true ) );
// Set and get.
update_user_meta( self::$author_id, $key, $val );
$this->assertEquals( $val, get_user_meta( self::$author_id, $key, true ) );
// Change and get again.
$val2 = 'value2';
update_user_meta( self::$author_id, $key, $val2 );
$this->assertEquals( $val2, get_user_meta( self::$author_id, $key, true ) );
// Delete and get.
delete_user_meta( self::$author_id, $key );
$this->assertEquals( '', get_user_meta( self::$author_id, $key, true ) );
// Delete by key AND value.
update_user_meta( self::$author_id, $key, $val );
// Incorrect key: key still exists.
delete_user_meta( self::$author_id, $key, rand_str() );
$this->assertEquals( $val, get_user_meta( self::$author_id, $key, true ) );
// Correct key: deleted.
delete_user_meta( self::$author_id, $key, $val );
$this->assertEquals( '', get_user_meta( self::$author_id, $key, true ) );
}
/**
* Test usermeta functions in array mode.
*/
function test_usermeta_array() {
// Some values to set.
$vals = array(
rand_str() => 'val-' . rand_str(),
rand_str() => 'val-' . rand_str(),
rand_str() => 'val-' . rand_str(),
);
// There is already some stuff in the array.
$this->assertTrue( is_array( get_user_meta( self::$author_id ) ) );
foreach ( $vals as $k => $v ) {
update_user_meta( self::$author_id, $k, $v );
}
// Get the complete usermeta array.
$out = get_user_meta( self::$author_id );
// For reasons unclear, the resulting array is indexed numerically; meta keys are not included anywhere.
// So we'll just check to make sure our values are included somewhere.
foreach ( $vals as $k => $v ) {
$this->assertTrue( isset( $out[ $k ] ) && $out[ $k ][0] === $v );
}
// Delete one key and check again.
$keys = array_keys( $vals );
$key_to_delete = array_pop( $keys );
delete_user_meta( self::$author_id, $key_to_delete );
$out = get_user_meta( self::$author_id );
// Make sure that key is excluded from the results.
foreach ( $vals as $k => $v ) {
if ( $k === $key_to_delete ) {
$this->assertFalse( isset( $out[ $k ] ) );
} else {
$this->assertTrue( isset( $out[ $k ] ) && $out[ $k ][0] === $v );
}
}
}
/**
* Test property magic functions for property get/set/isset.
*/
function test_user_properties() {
$user = new WP_User( self::$author_id );
foreach ( $user->data as $key => $data ) {
$this->assertEquals( $data, $user->$key );
}
$this->assertTrue( isset( $user->$key ) );
$this->assertFalse( isset( $user->fooooooooo ) );
$user->$key = 'foo';
$this->assertEquals( 'foo', $user->$key );
$this->assertEquals( 'foo', $user->data->$key ); // This will fail with WP < 3.3.
foreach ( get_object_vars( $user ) as $key => $value ) {
$this->assertEquals( $value, $user->$key );
}
}
/**
* Test the magic __unset() method.
*
* @ticket 20043
*/
public function test_user_unset() {
// phpcs:disable WordPress.NamingConventions.ValidVariableName.UsedPropertyNotSnakeCase
$user = new WP_User( self::$author_id );
// Test custom fields.
$user->customField = 123;
$this->assertEquals( $user->customField, 123 );
unset( $user->customField );
$this->assertFalse( isset( $user->customField ) );
return $user;
// phpcs:enable
}
/**
* Test 'id' (lowercase).
*
* @depends test_user_unset
* @expectedDeprecated WP_User->id
* @ticket 20043
*/
function test_user_unset_lowercase_id( $user ) {
$id = $user->id;
unset( $user->id );
$this->assertSame( $id, $user->id );
return $user;
}
/**
* Test 'ID'.
*
* @depends test_user_unset_lowercase_id
* @ticket 20043
*/
function test_user_unset_uppercase_id( $user ) {
$this->assertNotEmpty( $user->ID );
unset( $user->ID );
$this->assertNotEmpty( $user->ID );
}
/**
* Test meta property magic functions for property get/set/isset.
*/
function test_user_meta_properties() {
$user = new WP_User( self::$author_id );
update_user_option( self::$author_id, 'foo', 'foo', true );
$this->assertTrue( isset( $user->foo ) );
$this->assertEquals( 'foo', $user->foo );
}
/**
* @expectedDeprecated WP_User->id
*/
function test_id_property_back_compat() {
$user = new WP_User( self::$author_id );
$this->assertTrue( isset( $user->id ) );
$this->assertEquals( $user->ID, $user->id );
$user->id = 1234;
$this->assertEquals( $user->ID, $user->id );
}
/**
* ticket 19265
*/
function test_user_level_property_back_compat() {
$roles = array(
self::$admin_id => 10,
self::$editor_id => 7,
self::$author_id => 2,
self::$contrib_id => 1,
self::$sub_id => 0,
);
foreach ( $roles as $user_id => $level ) {
$user = new WP_User( $user_id );
$this->assertTrue( isset( $user->user_level ) );
$this->assertEquals( $level, $user->user_level );
}
}
function test_construction() {
$user = new WP_User( self::$author_id );
$this->assertInstanceOf( 'WP_User', $user );
$this->assertEquals( self::$author_id, $user->ID );
$user2 = new WP_User( 0, $user->user_login );
$this->assertInstanceOf( 'WP_User', $user2 );
$this->assertEquals( self::$author_id, $user2->ID );
$this->assertEquals( $user->user_login, $user2->user_login );
$user3 = new WP_User();
$this->assertInstanceOf( 'WP_User', $user3 );
$this->assertEquals( 0, $user3->ID );
$this->assertFalse( isset( $user3->user_login ) );
$user3->init( $user->data );
$this->assertEquals( self::$author_id, $user3->ID );
$user4 = new WP_User( $user->user_login );
$this->assertInstanceOf( 'WP_User', $user4 );
$this->assertEquals( self::$author_id, $user4->ID );
$this->assertEquals( $user->user_login, $user4->user_login );
$user5 = new WP_User( null, $user->user_login );
$this->assertInstanceOf( 'WP_User', $user5 );
$this->assertEquals( self::$author_id, $user5->ID );
$this->assertEquals( $user->user_login, $user5->user_login );
$user6 = new WP_User( $user );
$this->assertInstanceOf( 'WP_User', $user6 );
$this->assertEquals( self::$author_id, $user6->ID );
$this->assertEquals( $user->user_login, $user6->user_login );
$user7 = new WP_User( $user->data );
$this->assertInstanceOf( 'WP_User', $user7 );
$this->assertEquals( self::$author_id, $user7->ID );
$this->assertEquals( $user->user_login, $user7->user_login );
}
function test_get() {
$user = new WP_User( self::$author_id );
$this->assertEquals( 'author_login', $user->get( 'user_login' ) );
$this->assertEquals( 'author@email.com', $user->get( 'user_email' ) );
$this->assertEquals( 0, $user->get( 'use_ssl' ) );
$this->assertEquals( '', $user->get( 'field_that_does_not_exist' ) );
update_user_meta( self::$author_id, 'dashed-key', 'abcdefg' );
$this->assertEquals( 'abcdefg', $user->get( 'dashed-key' ) );
}
function test_has_prop() {
$user = new WP_User( self::$author_id );
$this->assertTrue( $user->has_prop( 'user_email' ) );
$this->assertTrue( $user->has_prop( 'use_ssl' ) );
$this->assertFalse( $user->has_prop( 'field_that_does_not_exist' ) );
update_user_meta( self::$author_id, 'dashed-key', 'abcdefg' );
$this->assertTrue( $user->has_prop( 'dashed-key' ) );
}
function test_update_user() {
$user = new WP_User( self::$author_id );
update_user_meta( self::$author_id, 'description', 'about me' );
$this->assertEquals( 'about me', $user->get( 'description' ) );
$user_data = array(
'ID' => self::$author_id,
'display_name' => 'test user',
);
wp_update_user( $user_data );
$user = new WP_User( self::$author_id );
$this->assertEquals( 'test user', $user->get( 'display_name' ) );
// Make sure there is no collateral damage to fields not in $user_data.
$this->assertEquals( 'about me', $user->get( 'description' ) );
// Pass as stdClass.
$user_data = array(
'ID' => self::$author_id,
'display_name' => 'a test user',
);
wp_update_user( (object) $user_data );
$user = new WP_User( self::$author_id );
$this->assertEquals( 'a test user', $user->get( 'display_name' ) );
$user->display_name = 'some test user';
wp_update_user( $user );
$this->assertEquals( 'some test user', $user->get( 'display_name' ) );
// Test update of fields in _get_additional_user_keys().
$user_data = array(
'ID' => self::$author_id,
'use_ssl' => 1,
'show_admin_bar_front' => 1,
'rich_editing' => 1,
'syntax_highlighting' => 1,
'first_name' => 'first',
'last_name' => 'last',
'nickname' => 'nick',
'comment_shortcuts' => 'true',
'admin_color' => 'classic',
'description' => 'describe',
);
wp_update_user( $user_data );
$user = new WP_User( self::$author_id );
foreach ( $user_data as $key => $value ) {
$this->assertEquals( $value, $user->get( $key ), $key );
}
}
/**
* ticket 19595
*/
function test_global_userdata() {
global $userdata, $wpdb;
wp_set_current_user( self::$sub_id );
$this->assertNotEmpty( $userdata );
$this->assertInstanceOf( 'WP_User', $userdata );
$this->assertEquals( $userdata->ID, self::$sub_id );
$prefix = $wpdb->get_blog_prefix();
$cap_key = $prefix . 'capabilities';
$this->assertTrue( isset( $userdata->$cap_key ) );
}
/**
* ticket 19769
*/
function test_global_userdata_is_null_when_logged_out() {
global $userdata;
wp_set_current_user( 0 );
$this->assertNull( $userdata );
}
function test_exists() {
$user = new WP_User( self::$author_id );
$this->assertTrue( $user->exists() );
$user = new WP_User( 123456789 );
$this->assertFalse( $user->exists() );
$user = new WP_User( 0 );
$this->assertFalse( $user->exists() );
}
function test_global_authordata() {
global $authordata, $id;
$old_post_id = $id;
$user = new WP_User( self::$author_id );
$post = array(
'post_author' => self::$author_id,
'post_status' => 'publish',
'post_content' => rand_str(),
'post_title' => rand_str(),
'post_type' => 'post',
);
// Insert a post and make sure the ID is OK.
$post_id = wp_insert_post( $post );
$this->assertTrue( is_numeric( $post_id ) );
setup_postdata( get_post( $post_id ) );
$this->assertNotEmpty( $authordata );
$this->assertInstanceOf( 'WP_User', $authordata );
$this->assertEquals( $authordata->ID, self::$author_id );
if ( $old_post_id ) {
setup_postdata( get_post( $old_post_id ) );
}
}
/**
* @ticket 13317
*/
function test_get_userdata() {
$this->assertFalse( get_userdata( 0 ) );
$this->assertFalse( get_userdata( '0' ) );
$this->assertFalse( get_userdata( 'string' ) );
$this->assertFalse( get_userdata( array( 'array' ) ) );
}
/**
* @ticket 23480
*/
function test_user_get_data_by_id() {
$user = WP_User::get_data_by( 'id', self::$author_id );
$this->assertInstanceOf( 'stdClass', $user );
$this->assertEquals( self::$author_id, $user->ID );
// @ticket 23480
$user1 = WP_User::get_data_by( 'id', -1 );
$this->assertEquals( false, $user1 );
$user2 = WP_User::get_data_by( 'id', 0 );
$this->assertEquals( false, $user2 );
$user3 = WP_User::get_data_by( 'id', null );
$this->assertEquals( false, $user3 );
$user4 = WP_User::get_data_by( 'id', '' );
$this->assertEquals( false, $user4 );
$user5 = WP_User::get_data_by( 'id', false );
$this->assertEquals( false, $user5 );
$user6 = WP_User::get_data_by( 'id', $user->user_nicename );
$this->assertEquals( false, $user6 );
$user7 = WP_User::get_data_by( 'id', 99999 );
$this->assertEquals( false, $user7 );
}
/**
* @ticket 33869
*/
public function test_user_get_data_by_ID_should_alias_to_id() {
$user = WP_User::get_data_by( 'ID', self::$author_id );
$this->assertEquals( self::$author_id, $user->ID );
}
/**
* @ticket 21431
*/
function test_count_many_users_posts() {
$user_id_b = self::factory()->user->create( array( 'role' => 'author' ) );
$post_id_a = self::factory()->post->create( array( 'post_author' => self::$author_id ) );
$post_id_b = self::factory()->post->create( array( 'post_author' => $user_id_b ) );
$post_id_c = self::factory()->post->create(
array(
'post_author' => $user_id_b,
'post_status' => 'private',
)
);
wp_set_current_user( self::$author_id );
$counts = count_many_users_posts( array( self::$author_id, $user_id_b ), 'post', false );
$this->assertEquals( 1, $counts[ self::$author_id ] );
$this->assertEquals( 1, $counts[ $user_id_b ] );
$counts = count_many_users_posts( array( self::$author_id, $user_id_b ), 'post', true );
$this->assertEquals( 1, $counts[ self::$author_id ] );
$this->assertEquals( 1, $counts[ $user_id_b ] );
wp_set_current_user( $user_id_b );
$counts = count_many_users_posts( array( self::$author_id, $user_id_b ), 'post', false );
$this->assertEquals( 1, $counts[ self::$author_id ] );
$this->assertEquals( 2, $counts[ $user_id_b ] );
$counts = count_many_users_posts( array( self::$author_id, $user_id_b ), 'post', true );
$this->assertEquals( 1, $counts[ self::$author_id ] );
$this->assertEquals( 1, $counts[ $user_id_b ] );
}
/**
* @ticket 22858
*/
function test_wp_update_user_on_nonexistent_users() {
$user_id = 1;
// Find me a non-existent user ID.
while ( get_userdata( $user_id ) ) {
++$user_id;
}
// If this test fails, it will error out for calling the to_array() method on a non-object.
$this->assertInstanceOf( 'WP_Error', wp_update_user( array( 'ID' => $user_id ) ) );
}
/**
* @ticket 28435
*/
function test_wp_update_user_should_not_change_password_when_passed_WP_User_instance() {
$testuserid = 1;
$user = get_userdata( $testuserid );
$pwd_before = $user->user_pass;
wp_update_user( $user );
// Reload the data.
$pwd_after = get_userdata( $testuserid )->user_pass;
$this->assertEquals( $pwd_before, $pwd_after );
}
/**
* @ticket 45747
* @group ms-excluded
*/
function test_wp_update_user_should_not_mark_user_as_spam_on_single_site() {
$u = wp_update_user(
array(
'ID' => self::$contrib_id,
'spam' => '0',
)
);
$this->assertNotWPError( $u );
$u = wp_update_user(
array(
'ID' => self::$contrib_id,
'spam' => '1',
)
);
$this->assertWPError( $u );
$this->assertSame( 'no_spam', $u->get_error_code() );
}
/**
* @ticket 28315
*/
function test_user_meta_error() {
$id1 = wp_insert_user(
array(
'user_login' => rand_str(),
'user_pass' => 'password',
'user_email' => 'taco@burrito.com',
)
);
$this->assertEquals( $id1, email_exists( 'taco@burrito.com' ) );
$id2 = wp_insert_user(
array(
'user_login' => rand_str(),
'user_pass' => 'password',
'user_email' => 'taco@burrito.com',
)
);
if ( ! defined( 'WP_IMPORTING' ) ) {
$this->assertWPError( $id2 );
}
update_user_meta( $id2, 'key', 'value' );
$metas = array_keys( get_user_meta( 1 ) );
$this->assertNotContains( 'key', $metas );
}
/**
* @ticket 30647
*/
function test_user_update_email_error() {
$id1 = wp_insert_user(
array(
'user_login' => 'blackburn',
'user_pass' => 'password',
'user_email' => 'blackburn@battlefield4.com',
)
);
$this->assertEquals( $id1, email_exists( 'blackburn@battlefield4.com' ) );
$id2 = wp_insert_user(
array(
'user_login' => 'miller',
'user_pass' => 'password',
'user_email' => 'miller@battlefield4.com',
)
);
$this->assertEquals( $id2, email_exists( 'miller@battlefield4.com' ) );
if ( ! is_wp_error( $id2 ) ) {
wp_update_user(
array(
'ID' => $id2,
'user_email' => 'david@battlefield4.com',
)
);
$this->assertEquals( $id2, email_exists( 'david@battlefield4.com' ) );
$return = wp_update_user(
array(
'ID' => $id2,
'user_email' => 'blackburn@battlefield4.com',
)
);
if ( ! defined( 'WP_IMPORTING' ) ) {
$this->assertWPError( $return );
}
}
}
/**
* @ticket 27317
* @dataProvider _illegal_user_logins_data
*/
function test_illegal_user_logins_single( $user_login ) {
$user_data = array(
'user_login' => $user_login,
'user_email' => 'testuser@example.com',
'user_pass' => wp_generate_password(),
);
add_filter( 'illegal_user_logins', array( $this, '_illegal_user_logins' ) );
$response = wp_insert_user( $user_data );
$this->assertInstanceOf( 'WP_Error', $response );
$this->assertEquals( 'invalid_username', $response->get_error_code() );
remove_filter( 'illegal_user_logins', array( $this, '_illegal_user_logins' ) );
$user_id = wp_insert_user( $user_data );
$user = get_user_by( 'id', $user_id );
$this->assertInstanceOf( 'WP_User', $user );
}
/**
* @ticket 27317
* @dataProvider _illegal_user_logins_data
*/
function test_illegal_user_logins_single_wp_create_user( $user_login ) {
$user_email = 'testuser-' . $user_login . '@example.com';
add_filter( 'illegal_user_logins', array( $this, '_illegal_user_logins' ) );
$response = register_new_user( $user_login, $user_email );
$this->assertInstanceOf( 'WP_Error', $response );
$this->assertEquals( 'invalid_username', $response->get_error_code() );
remove_filter( 'illegal_user_logins', array( $this, '_illegal_user_logins' ) );
$response = register_new_user( $user_login, $user_email );
$user = get_user_by( 'id', $response );
$this->assertInstanceOf( 'WP_User', $user );
}
/**
* @ticket 27317
* @group ms-required
*/
function test_illegal_user_logins_multisite() {
$user_data = array(
'user_login' => 'testuser',
'user_email' => 'testuser@example.com',
);
add_filter( 'illegal_user_logins', array( $this, '_illegal_user_logins' ) );
$response = wpmu_validate_user_signup( $user_data['user_login'], $user_data['user_email'] );
$this->assertInstanceOf( 'WP_Error', $response['errors'] );
$this->assertEquals( 'user_name', $response['errors']->get_error_code() );
remove_filter( 'illegal_user_logins', array( $this, '_illegal_user_logins' ) );
$response = wpmu_validate_user_signup( $user_data['user_login'], $user_data['user_email'] );
$this->assertInstanceOf( 'WP_Error', $response['errors'] );
$this->assertEquals( 0, count( $response['errors']->get_error_codes() ) );
}
function _illegal_user_logins_data() {
$data = array(
array( 'testuser' ),
);
// Multisite doesn't allow mixed case logins ever.
if ( ! is_multisite() ) {
$data[] = array( 'TestUser' );
}
return $data;
}
function _illegal_user_logins() {
return array( 'testuser' );
}
/**
* @ticket 24618
*/
public function test_validate_username_string() {
$this->assertTrue( validate_username( 'johndoe' ) );
$this->assertTrue( validate_username( 'test@test.com' ) );
}
/**
* @ticket 24618
*/
public function test_validate_username_contains_uppercase_letters() {
if ( is_multisite() ) {
$this->assertFalse( validate_username( 'JohnDoe' ) );
} else {
$this->assertTrue( validate_username( 'JohnDoe' ) );
}
}
/**
* @ticket 24618
*/
public function test_validate_username_empty() {
$this->assertFalse( validate_username( '' ) );
}
/**
* @ticket 24618
*/
public function test_validate_username_invalid() {
$this->assertFalse( validate_username( '@#&99sd' ) );
}
/**
* @ticket 29880
*/
public function test_wp_insert_user_should_not_wipe_existing_password() {
$user_details = array(
'user_login' => rand_str(),
'user_pass' => 'password',
'user_email' => rand_str() . '@example.com',
);
$user_id = wp_insert_user( $user_details );
$this->assertEquals( $user_id, email_exists( $user_details['user_email'] ) );
// Check that providing an empty password doesn't remove a user's password.
$user_details['ID'] = $user_id;
$user_details['user_pass'] = '';
$user_id = wp_insert_user( $user_details );
$user = WP_User::get_data_by( 'id', $user_id );
$this->assertNotEmpty( $user->user_pass );
}
/**
* @ticket 29696
*/
public function test_wp_insert_user_should_sanitize_user_nicename_parameter() {
$user = $this->author;
$userdata = $user->to_array();
$userdata['user_nicename'] = str_replace( '-', '.', $user->user_nicename );
wp_insert_user( $userdata );
$updated_user = new WP_User( $user->ID );
$this->assertSame( $user->user_nicename, $updated_user->user_nicename );
}
/**
* @ticket 33793
*/
public function test_wp_insert_user_should_accept_user_login_with_60_characters() {
$user_login = str_repeat( 'a', 60 );
$u = wp_insert_user(
array(
'user_login' => $user_login,
'user_email' => $user_login . '@example.com',
'user_pass' => 'password',
'user_nicename' => 'something-short',
)
);
$this->assertInternalType( 'int', $u );
$this->assertGreaterThan( 0, $u );
$user = new WP_User( $u );
$this->assertSame( $user_login, $user->user_login );
}
/**
* @ticket 33793
*/
public function test_wp_insert_user_should_reject_user_login_over_60_characters() {
$user_login = str_repeat( 'a', 61 );
$u = wp_insert_user(
array(
'user_login' => $user_login,
'user_email' => $user_login . '@example.com',
'user_pass' => 'password',
'user_nicename' => 'something-short',
)
);
$this->assertWPError( $u );
$this->assertSame( 'user_login_too_long', $u->get_error_code() );
}
/**
* @ticket 33793
*/
public function test_wp_insert_user_should_reject_user_nicename_over_50_characters() {
$user_nicename = str_repeat( 'a', 51 );
$u = wp_insert_user(
array(
'user_login' => 'mynicenamehas50chars',
'user_email' => $user_nicename . '@example.com',
'user_pass' => 'password',
'user_nicename' => $user_nicename,
)
);
$this->assertWPError( $u );
$this->assertSame( 'user_nicename_too_long', $u->get_error_code() );
}
/**
* @ticket 33793
*/
public function test_wp_insert_user_should_not_generate_user_nicename_longer_than_50_chars() {
$user_login = str_repeat( 'a', 55 );
$u = wp_insert_user(
array(
'user_login' => $user_login,
'user_email' => $user_login . '@example.com',
'user_pass' => 'password',
)
);
$this->assertNotEmpty( $u );
$user = new WP_User( $u );
$expected = str_repeat( 'a', 50 );
$this->assertSame( $expected, $user->user_nicename );
}
/**
* @ticket 33793
*/
public function test_wp_insert_user_should_not_truncate_to_a_duplicate_user_nicename() {
$u1 = self::factory()->user->create(
array(
'user_nicename' => str_repeat( 'a', 50 ),
)
);
$user1 = new WP_User( $u1 );
$expected = str_repeat( 'a', 50 );
$this->assertSame( $expected, $user1->user_nicename );
$user_login = str_repeat( 'a', 55 );
$u = wp_insert_user(
array(
'user_login' => $user_login,
'user_email' => $user_login . '@example.com',
'user_pass' => 'password',
)
);
$this->assertNotEmpty( $u );
$user2 = new WP_User( $u );
$expected = str_repeat( 'a', 48 ) . '-2';
$this->assertSame( $expected, $user2->user_nicename );
}
/**
* @ticket 33793
*/
public function test_wp_insert_user_should_not_truncate_to_a_duplicate_user_nicename_when_suffix_has_more_than_one_character() {
$user_ids = self::factory()->user->create_many(
4,
array(
'user_nicename' => str_repeat( 'a', 50 ),
)
);
foreach ( $user_ids as $i => $user_id ) {
$user = new WP_User( $user_id );
if ( 0 === $i ) {
$expected = str_repeat( 'a', 50 );
} else {
$expected = str_repeat( 'a', 48 ) . '-' . ( $i + 1 );
}
$this->assertSame( $expected, $user->user_nicename );
}
$user_login = str_repeat( 'a', 55 );
$u = wp_insert_user(
array(
'user_login' => $user_login,
'user_email' => $user_login . '@example.com',
'user_pass' => 'password',
)
);
$this->assertNotEmpty( $u );
$user = new WP_User( $u );
$expected = str_repeat( 'a', 48 ) . '-5';
$this->assertSame( $expected, $user->user_nicename );
}
/**
* @ticket 28004
*/
public function test_wp_insert_user_with_invalid_user_id() {
global $wpdb;
$max_user = $wpdb->get_var( "SELECT MAX(ID) FROM $wpdb->users" );
$u = wp_insert_user(
array(
'ID' => $max_user + 1,
'user_login' => 'whatever',
'user_email' => 'whatever@example.com',
'user_pass' => 'password',
)
);
$this->assertWPError( $u );
$this->assertSame( 'invalid_user_id', $u->get_error_code() );
}
/**
* @ticket 47902
*/
public function test_wp_insert_user_with_empty_data() {
add_filter( 'wp_pre_insert_user_data', '__return_empty_array' );
$u = self::factory()->user->create();
remove_filter( 'wp_pre_insert_user_data', '__return_empty_array' );
$this->assertWPError( $u );
$this->assertSame( 'empty_data', $u->get_error_code() );
}
/**
* @ticket 35750
*/
public function test_wp_update_user_should_delete_userslugs_cache() {
$u = self::factory()->user->create();
$user = get_userdata( $u );
wp_update_user(
array(
'ID' => $u,
'user_nicename' => 'newusernicename',
)
);
$updated_user = get_userdata( $u );
$this->assertFalse( wp_cache_get( $user->user_nicename, 'userslugs' ) );
$this->assertEquals( $u, wp_cache_get( $updated_user->user_nicename, 'userslugs' ) );
}
function test_changing_email_invalidates_password_reset_key() {
global $wpdb;
$user = $this->author;
$wpdb->update( $wpdb->users, array( 'user_activation_key' => 'key' ), array( 'ID' => $user->ID ) );
clean_user_cache( $user );
$user = get_userdata( $user->ID );
$this->assertEquals( 'key', $user->user_activation_key );
// Check that changing something other than the email doesn't remove the key.
$userdata = array(
'ID' => $user->ID,
'user_nicename' => 'wat',
);
wp_update_user( $userdata );
$user = get_userdata( $user->ID );
$this->assertEquals( 'key', $user->user_activation_key );
// Now check that changing the email does remove it.
$userdata = array(
'ID' => $user->ID,
'user_nicename' => 'cat',
'user_email' => 'foo@bar.dev',
);
wp_update_user( $userdata );
$user = get_userdata( $user->ID );
$this->assertEmpty( $user->user_activation_key );
}
public function test_search_users_login() {
$users = get_users(
array(
'search' => 'user1',
'fields' => 'ID',
)
);
$this->assertTrue( in_array( (string) self::$contrib_id, $users, true ) );
}
public function test_search_users_url() {
$users = get_users(
array(
'search' => '*tacos*',
'fields' => 'ID',
)
);
$this->assertTrue( in_array( (string) self::$contrib_id, $users, true ) );
}
public function test_search_users_email() {
$users = get_users(
array(
'search' => '*battle*',
'fields' => 'ID',
)
);
$this->assertTrue( in_array( (string) self::$contrib_id, $users, true ) );
}
public function test_search_users_nicename() {
$users = get_users(
array(
'search' => '*one*',
'fields' => 'ID',
)
);
$this->assertTrue( in_array( (string) self::$contrib_id, $users, true ) );
}
public function test_search_users_display_name() {
$users = get_users(
array(
'search' => '*Doe*',
'fields' => 'ID',
)
);
$this->assertTrue( in_array( (string) self::$contrib_id, $users, true ) );
}
/**
* @ticket 32158
*/
function test_email_case() {
// Alter the case of the email address (which stays the same).
$userdata = array(
'ID' => self::$editor_id,
'user_email' => 'test@TEST.com',
);
$update = wp_update_user( $userdata );
$this->assertEquals( self::$editor_id, $update );
}
/**
* @ticket 32158
*/
function test_email_change() {
// Change the email address.
$userdata = array(
'ID' => self::$editor_id,
'user_email' => 'test2@test.com',
);
$update = wp_update_user( $userdata );
// Was this successful?
$this->assertEquals( self::$editor_id, $update );
// Verify that the email address has been updated.
$user = get_userdata( self::$editor_id );
$this->assertEquals( $user->user_email, 'test2@test.com' );
}
/**
* Testing wp_new_user_notification email statuses.
*
* @dataProvider data_wp_new_user_notifications
* @ticket 33654
* @ticket 36009
*/
function test_wp_new_user_notification( $notify, $admin_email_sent_expected, $user_email_sent_expected ) {
reset_phpmailer_instance();
$was_admin_email_sent = false;
$was_user_email_sent = false;
wp_new_user_notification( self::$contrib_id, null, $notify );
$mailer = tests_retrieve_phpmailer_instance();
/*
* Check to see if a notification email was sent to the
* post author `blackburn@battlefield3.com` and and site admin `admin@example.org`.
*/
$first_recipient = $mailer->get_recipient( 'to' );
if ( $first_recipient ) {
$was_admin_email_sent = WP_TESTS_EMAIL === $first_recipient->address;
$was_user_email_sent = 'blackburn@battlefield3.com' === $first_recipient->address;
}
$second_recipient = $mailer->get_recipient( 'to', 1 );
if ( $second_recipient ) {
$was_user_email_sent = 'blackburn@battlefield3.com' === $second_recipient->address;
}
$this->assertSame( $admin_email_sent_expected, $was_admin_email_sent, 'Admin email result was not as expected in test_wp_new_user_notification' );
$this->assertSame( $user_email_sent_expected, $was_user_email_sent, 'User email result was not as expected in test_wp_new_user_notification' );
}
/**
* Data provider for test_wp_new_user_notification().
*
* Passes the three available options for the $notify parameter and the expected email
* emails sent status as a bool.
*
* @return array {
* @type array {
* @type string $post_args The arguments that will merged with the $_POST array.
* @type bool $admin_email_sent_expected The expected result of whether an email was sent to the admin.
* @type bool $user_email_sent_expected The expected result of whether an email was sent to the user.
* }
* }
*/
function data_wp_new_user_notifications() {
return array(
array(
'',
true,
false,
),
array(
'admin',
true,
false,
),
array(
'user',
false,
true,
),
array(
'both',
true,
true,
),
array(
'THIS IS NOT A SUPPORTED NOTIFICATION TYPE',
false,
false,
),
);
}
/**
* Set up a user and try sending a notification using the old, deprecated
* function signature `wp_new_user_notification( $user, 'plaintext_password' );`.
*
* @ticket 33654
* @expectedDeprecated wp_new_user_notification
*/
function test_wp_new_user_notification_old_signature_throws_deprecated_warning_but_sends() {
reset_phpmailer_instance();
$was_admin_email_sent = false;
$was_user_email_sent = false;
wp_new_user_notification( self::$contrib_id, 'this_is_a_test_password' );
/*
* Check to see if a notification email was sent to the
* post author `blackburn@battlefield3.com` and and site admin `admin@example.org`.
*/
if ( ! empty( $GLOBALS['phpmailer']->mock_sent ) ) {
$was_admin_email_sent = ( isset( $GLOBALS['phpmailer']->mock_sent[0] ) && WP_TESTS_EMAIL === $GLOBALS['phpmailer']->mock_sent[0]['to'][0][0] );
$was_user_email_sent = ( isset( $GLOBALS['phpmailer']->mock_sent[1] ) && 'blackburn@battlefield3.com' === $GLOBALS['phpmailer']->mock_sent[1]['to'][0][0] );
}
$this->assertTrue( $was_admin_email_sent );
$this->assertTrue( $was_user_email_sent );
}
/**
* Set up a user and try sending a notification using `wp_new_user_notification( $user );`.
*
* @ticket 34377
*/
function test_wp_new_user_notification_old_signature_no_password() {
reset_phpmailer_instance();
$was_admin_email_sent = false;
$was_user_email_sent = false;
wp_new_user_notification( self::$contrib_id );
/*
* Check to see if a notification email was sent to the
* post author `blackburn@battlefield3.com` and and site admin `admin@example.org`.
*/
if ( ! empty( $GLOBALS['phpmailer']->mock_sent ) ) {
$was_admin_email_sent = ( isset( $GLOBALS['phpmailer']->mock_sent[0] ) && WP_TESTS_EMAIL === $GLOBALS['phpmailer']->mock_sent[0]['to'][0][0] );
$was_user_email_sent = ( isset( $GLOBALS['phpmailer']->mock_sent[1] ) && 'blackburn@battlefield3.com' === $GLOBALS['phpmailer']->mock_sent[1]['to'][0][0] );
}
$this->assertTrue( $was_admin_email_sent );
$this->assertFalse( $was_user_email_sent );
}
/**
* Ensure blog's admin email change notification emails do not contain encoded HTML entities
*
* @ticket 40015
*/
function test_new_admin_email_notification_html_entities_decoded() {
reset_phpmailer_instance();
wp_set_current_user( self::$admin_id );
$existing_email = get_option( 'admin_email' );
$new_email = 'new-admin-email@test.dev';
// Give the site a name containing HTML entities.
update_option( 'blogname', '&#039;Test&#039; blog&#039;s &quot;name&quot; has &lt;html entities&gt; &amp;' );
update_option_new_admin_email( $existing_email, $new_email );
$mailer = tests_retrieve_phpmailer_instance();
$recipient = $mailer->get_recipient( 'to' );
$email = $mailer->get_sent();
// Assert recipient is correct.
$this->assertSame( $new_email, $recipient->address, 'Admin email change notification recipient not as expected' );
// Assert that HTML entites have been decode in body and subject.
$this->assertContains( '\'Test\' blog\'s "name" has <html entities> &', $email->subject, 'Email subject does not contain the decoded HTML entities' );
$this->assertNotContains( '&#039;Test&#039; blog&#039;s &quot;name&quot; has &lt;html entities&gt; &amp;', $email->subject, $email->subject, 'Email subject does contains HTML entities' );
}
/**
* A confirmation email should not be sent if the new admin email:
* - Matches the existing admin email, or
* - is not a valid email
*
* @dataProvider data_user_admin_email_confirmation_emails
*/
function test_new_admin_email_confirmation_not_sent_when_email_invalid( $email, $message ) {
reset_phpmailer_instance();
update_option_new_admin_email( get_option( 'admin_email' ), $email );
$mailer = tests_retrieve_phpmailer_instance();
$this->assertFalse( $mailer->get_sent(), $message );
}
/**
* Data provider for test_ms_new_admin_email_confirmation_not_sent_when_email_invalid().
*
* @return array {
* @type array {
* @type string $email The new email for admin_email
* @type string $message An error message to display if the test fails
* }
* }
*/
function data_user_admin_email_confirmation_emails() {
return array(
array(
get_option( 'admin_email' ),
'A confirmation email should not be sent if the current admin email matches the new email',
),
array(
'not an email',
'A confirmation email should not be sent if it is not a valid email',
),
);
}
/**
* A confirmation email should not be sent if user's new email:
* - Matches their existing email, or
* - is not a valid email, or
* - Matches another user's email
*
* @dataProvider data_user_change_email_confirmation_emails
*/
function test_profile_email_confirmation_not_sent_invalid_email( $email, $message ) {
$old_current = get_current_user_id();
$user_id = self::factory()->user->create(
array(
'role' => 'subscriber',
'user_email' => 'email@test.dev',
)
);
wp_set_current_user( $user_id );
self::factory()->user->create(
array(
'role' => 'subscriber',
'user_email' => 'another-user@test.dev',
)
);
reset_phpmailer_instance();
// Set $_POST['email'] with new email and $_POST['id'] with user's ID.
$_POST['user_id'] = $user_id;
$_POST['email'] = $email;
send_confirmation_on_profile_email();
$mailer = tests_retrieve_phpmailer_instance();
$this->assertFalse( $mailer->get_sent(), $message );
wp_set_current_user( $old_current );
}
/**
* Data provider for test_ms_profile_email_confirmation_not_sent_invalid_email().
*
* @return array {
* @type array {
* @type string $email The user's new e-amil.
* @type string $message An error message to display if the test fails
* }
* }
*/
function data_user_change_email_confirmation_emails() {
return array(
array(
'email@test.dev',
'Confirmation email should not be sent if it matches the user\'s existing email',
),
array(
'not an email',
'Confirmation email should not be sent if it is not a valid email',
),
array(
'another-user@test.dev',
'Confirmation email should not be sent if it matches another user\'s email',
),
);
}
/**
* Checks that calling edit_user() with no password returns an error when adding, and doesn't when updating.
*
* @ticket 35715
*/
function test_edit_user_blank_pw() {
$_POST = array();
$_GET = array();
$_REQUEST = array();
$_POST['role'] = 'subscriber';
$_POST['email'] = 'user1@example.com';
$_POST['user_login'] = 'user_login1';
$_POST['first_name'] = 'first_name1';
$_POST['last_name'] = 'last_name1';
$_POST['nickname'] = 'nickname1';
$_POST['display_name'] = 'display_name1';
// Check new user with missing password.
$response = edit_user();
$this->assertInstanceOf( 'WP_Error', $response );
$this->assertEquals( 'pass', $response->get_error_code() );
// Check new user with password set.
$_POST['pass1'] = 'password';
$_POST['pass2'] = 'password';
$user_id = edit_user();
$user = get_user_by( 'ID', $user_id );
$this->assertInternalType( 'int', $user_id );
$this->assertInstanceOf( 'WP_User', $user );
$this->assertEquals( 'nickname1', $user->nickname );
// Check updating user with empty password.
$_POST['nickname'] = 'nickname_updated';
$_POST['pass1'] = '';
$_POST['pass2'] = '';
$user_id = edit_user( $user_id );
$this->assertInternalType( 'int', $user_id );
$this->assertEquals( 'nickname_updated', $user->nickname );
// Check updating user with missing second password.
$_POST['nickname'] = 'nickname_updated2';
$_POST['pass1'] = 'blank_pass2';
$_POST['pass2'] = '';
$response = edit_user( $user_id );
$this->assertInstanceOf( 'WP_Error', $response );
$this->assertEquals( 'pass', $response->get_error_code() );
$this->assertEquals( 'nickname_updated', $user->nickname );
// Check updating user with empty password via `check_passwords` action.
add_action( 'check_passwords', array( $this, 'action_check_passwords_blank_pw' ), 10, 2 );
$user_id = edit_user( $user_id );
remove_action( 'check_passwords', array( $this, 'action_check_passwords_blank_pw' ) );
$this->assertInternalType( 'int', $user_id );
$this->assertEquals( 'nickname_updated2', $user->nickname );
}
/**
* Check passwords action for test_edit_user_blank_pw().
*/
function action_check_passwords_blank_pw( $user_login, &$pass1 ) {
$pass1 = '';
}
/**
* @ticket 16470
*/
function test_send_confirmation_on_profile_email() {
reset_phpmailer_instance();
$was_confirmation_email_sent = false;
$user = $this->factory()->user->create_and_get(
array(
'user_email' => 'before@example.com',
)
);
$_POST['email'] = 'after@example.com';
$_POST['user_id'] = $user->ID;
wp_set_current_user( $user->ID );
do_action( 'personal_options_update' );
if ( ! empty( $GLOBALS['phpmailer']->mock_sent ) ) {
$was_confirmation_email_sent = ( isset( $GLOBALS['phpmailer']->mock_sent[0] ) && 'after@example.com' === $GLOBALS['phpmailer']->mock_sent[0]['to'][0][0] );
}
// A confirmation email is sent.
$this->assertTrue( $was_confirmation_email_sent );
// The new email address gets put into user_meta.
$new_email_meta = get_user_meta( $user->ID, '_new_email', true );
$this->assertEquals( 'after@example.com', $new_email_meta['newemail'] );
// The email address of the user doesn't change. $_POST['email'] should be the email address pre-update.
$this->assertEquals( $_POST['email'], $user->user_email );
}
/**
* @ticket 16470
*/
function test_remove_send_confirmation_on_profile_email() {
remove_action( 'personal_options_update', 'send_confirmation_on_profile_email' );
reset_phpmailer_instance();
$was_confirmation_email_sent = false;
$user = $this->factory()->user->create_and_get(
array(
'user_email' => 'before@example.com',
)
);
$_POST['email'] = 'after@example.com';
$_POST['user_id'] = $user->ID;
wp_set_current_user( $user->ID );
do_action( 'personal_options_update' );
if ( ! empty( $GLOBALS['phpmailer']->mock_sent ) ) {
$was_confirmation_email_sent = ( isset( $GLOBALS['phpmailer']->mock_sent[0] ) && 'after@example.com' === $GLOBALS['phpmailer']->mock_sent[0]['to'][0][0] );
}
// No confirmation email is sent.
$this->assertFalse( $was_confirmation_email_sent );
// No usermeta is created.
$new_email_meta = get_user_meta( $user->ID, '_new_email', true );
$this->assertEmpty( $new_email_meta );
// $_POST['email'] should be the email address posted from the form.
$this->assertEquals( $_POST['email'], 'after@example.com' );
}
/**
* Ensure user email address change confirmation emails do not contain encoded HTML entities
*
* @ticket 16470
* @ticket 40015
*/
function test_send_confirmation_on_profile_email_html_entities_decoded() {
$user_id = self::factory()->user->create(
array(
'role' => 'subscriber',
'user_email' => 'old-email@test.dev',
)
);
wp_set_current_user( $user_id );
reset_phpmailer_instance();
// Give the site a name containing HTML entities.
update_option( 'blogname', '&#039;Test&#039; blog&#039;s &quot;name&quot; has &lt;html entities&gt; &amp;' );
// Set $_POST['email'] with new e-mail and $_POST['user_id'] with user's ID.
$_POST['user_id'] = $user_id;
$_POST['email'] = 'new-email@test.dev';
send_confirmation_on_profile_email();
$mailer = tests_retrieve_phpmailer_instance();
$recipient = $mailer->get_recipient( 'to' );
$email = $mailer->get_sent();
// Assert recipient is correct.
$this->assertSame( 'new-email@test.dev', $recipient->address, 'User email change confirmation recipient not as expected' );
// Assert that HTML entites have been decoded in body and subject.
$this->assertContains( '\'Test\' blog\'s "name" has <html entities> &', $email->subject, 'Email subject does not contain the decoded HTML entities' );
$this->assertNotContains( '&#039;Test&#039; blog&#039;s &quot;name&quot; has &lt;html entities&gt; &amp;', $email->subject, 'Email subject does contains HTML entities' );
}
/**
* @ticket 42564
*/
function test_edit_user_role_update() {
$_POST = array();
$_GET = array();
$_REQUEST = array();
$administrator = self::factory()->user->create(
array(
'role' => 'administrator',
)
);
wp_set_current_user( $administrator );
// Don't let anyone with 'promote_users' (administrator) edit their own role to something without it (subscriber).
$_POST['role'] = 'subscriber';
$_POST['email'] = 'subscriber@subscriber.test';
$_POST['nickname'] = 'subscriber';
$this->assertSame( $administrator, edit_user( $administrator ) );
// Should still have the old role.
$this->assertSame( array( 'administrator' ), get_userdata( $administrator )->roles );
// Promote an editor to an administrator.
$editor = self::factory()->user->create(
array(
'role' => 'editor',
)
);
$_POST['role'] = 'administrator';
$_POST['email'] = 'administrator@administrator.test';
$_POST['nickname'] = 'administrator';
$this->assertSame( $editor, edit_user( $editor ) );
// Should have the new role.
$this->assertSame( array( 'administrator' ), get_userdata( $editor )->roles );
}
/**
* Testing the `wp_user_personal_data_exporter()` function when no user exists.
*
* @ticket 43547
*/
function test_wp_user_personal_data_exporter_no_user() {
$actual = wp_user_personal_data_exporter( 'not-a-user-email@test.com' );
$expected = array(
'data' => array(),
'done' => true,
);
$this->assertSame( $expected, $actual );
}
/**
* Testing the `wp_user_personal_data_exporter()` function when the requested
* user exists.
*
* @ticket 43547
*/
function test_wp_user_personal_data_exporter() {
$test_user = new WP_User( self::$contrib_id );
$actual = wp_user_personal_data_exporter( $test_user->user_email );
$this->assertTrue( $actual['done'] );
// Number of exported users.
$this->assertSame( 1, count( $actual['data'] ) );
// Number of exported user properties.
$this->assertSame( 11, count( $actual['data'][0]['data'] ) );
}
/**
* Testing the `wp_user_personal_data_exporter()` function
* with Community Events Location IP data.
*
* @ticket 43921
*/
function test_wp_community_events_location_ip_personal_data_exporter() {
$test_user = new WP_User( self::$contrib_id );
$location_data = array( 'ip' => '0.0.0.0' );
update_user_option( $test_user->ID, 'community-events-location', $location_data, true );
$actual = wp_user_personal_data_exporter( $test_user->user_email );
$this->assertTrue( $actual['done'] );
// Contains 'Community Events Location'.
$this->assertEquals( 'Community Events Location', $actual['data'][1]['group_label'] );
// Contains location IP.
$this->assertEquals( 'IP', $actual['data'][1]['data'][0]['name'] );
$this->assertEquals( '0.0.0.0', $actual['data'][1]['data'][0]['value'] );
}
/**
* Testing the `wp_user_personal_data_exporter()` function
* with Community Events Location city data.
*
* @ticket 43921
*/
function test_wp_community_events_location_city_personal_data_exporter() {
$test_user = new WP_User( self::$contrib_id );
$location_data = array(
'description' => 'Cincinnati',
'country' => 'US',
'latitude' => '39.1271100',
'longitude' => '-84.5143900',
);
update_user_option( $test_user->ID, 'community-events-location', $location_data, true );
$actual = wp_user_personal_data_exporter( $test_user->user_email );
$this->assertTrue( $actual['done'] );
// Contains 'Community Events Location'.
$this->assertEquals( 'Community Events Location', $actual['data'][1]['group_label'] );
// Contains location city.
$this->assertEquals( 'City', $actual['data'][1]['data'][0]['name'] );
$this->assertEquals( 'Cincinnati', $actual['data'][1]['data'][0]['value'] );
// Contains location country.
$this->assertEquals( 'Country', $actual['data'][1]['data'][1]['name'] );
$this->assertEquals( 'US', $actual['data'][1]['data'][1]['value'] );
// Contains location latitude.
$this->assertEquals( 'Latitude', $actual['data'][1]['data'][2]['name'] );
$this->assertEquals( '39.1271100', $actual['data'][1]['data'][2]['value'] );
// Contains location longitude.
$this->assertEquals( 'Longitude', $actual['data'][1]['data'][3]['name'] );
$this->assertEquals( '-84.5143900', $actual['data'][1]['data'][3]['value'] );
}
/**
* Testing the `wp_user_personal_data_exporter()` function
* with Session Tokens data.
*
* @ticket 45889
*/
function test_wp_session_tokens_personal_data_exporter() {
$test_user = new WP_User( self::$contrib_id );
$session_tokens_data = array(
'yft87y56457687sfd897867545fg76ds78iyuhgjyui7865' => array(
'expiration' => 1580461981,
'ip' => '0.0.0.0',
'ua' => 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36',
'login' => 1580289181,
),
);
update_user_option( $test_user->ID, 'session_tokens', $session_tokens_data, true );
$actual = wp_user_personal_data_exporter( $test_user->user_email );
$this->assertTrue( $actual['done'] );
// Contains Session Tokens.
$this->assertEquals( 'Session Tokens', $actual['data'][1]['group_label'] );
// Contains Expiration.
$this->assertEquals( 'Expiration', $actual['data'][1]['data'][0]['name'] );
$this->assertEquals( 'January 31, 2020 09:13 AM', $actual['data'][1]['data'][0]['value'] );
// Contains IP.
$this->assertEquals( 'IP', $actual['data'][1]['data'][1]['name'] );
$this->assertEquals( '0.0.0.0', $actual['data'][1]['data'][1]['value'] );
// Contains IP.
$this->assertEquals( 'User Agent', $actual['data'][1]['data'][2]['name'] );
$this->assertEquals( 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36', $actual['data'][1]['data'][2]['value'] );
// Contains IP.
$this->assertEquals( 'Last Login', $actual['data'][1]['data'][3]['name'] );
$this->assertEquals( 'January 29, 2020 09:13 AM', $actual['data'][1]['data'][3]['value'] );
}
/**
* Testing the `wp_privacy_additional_user_profile_data` filter works.
*
* @since 5.4.0
*
* @ticket 47509
*/
function test_filter_wp_privacy_additional_user_profile_data() {
$test_user = new WP_User( self::$contrib_id );
add_filter( 'wp_privacy_additional_user_profile_data', array( $this, 'export_additional_user_profile_data' ) );
$actual = wp_user_personal_data_exporter( $test_user->user_email );
remove_filter( 'wp_privacy_additional_user_profile_data', array( $this, 'export_additional_user_profile_data' ) );
$this->assertTrue( $actual['done'] );
// Number of exported users.
$this->assertSame( 1, count( $actual['data'] ) );
// Number of exported user properties (the 11 core properties,
// plus 1 additional from the filter).
$this->assertSame( 12, count( $actual['data'][0]['data'] ) );
// Check that the item added by the filter was retained.
$this->assertSame(
1,
count(
wp_list_filter(
$actual['data'][0]['data'],
array(
'name' => 'Test Additional Data Name',
'value' => 'Test Additional Data Value',
)
)
)
);
// _doing_wrong() should be called because the filter callback
// adds a item with a 'name' that is the same as one generated by core.
$this->setExpectedIncorrectUsage( 'wp_user_personal_data_exporter' );
add_filter( 'wp_privacy_additional_user_profile_data', array( $this, 'export_additional_user_profile_data_with_dup_name' ) );
$actual = wp_user_personal_data_exporter( $test_user->user_email );
remove_filter( 'wp_privacy_additional_user_profile_data', array( $this, 'export_additional_user_profile_data' ) );
$this->assertTrue( $actual['done'] );
// Number of exported users.
$this->assertSame( 1, count( $actual['data'] ) );
// Number of exported user properties
// (the 11 core properties, plus 1 additional from the filter).
$this->assertSame( 12, count( $actual['data'][0]['data'] ) );
// Check that the duplicate 'name' => 'User ID' was stripped.
$this->assertSame(
1,
count(
wp_list_filter(
$actual['data'][0]['data'],
array(
'name' => 'User ID',
)
)
)
);
// Check that the item added by the filter was retained.
$this->assertSame(
1,
count(
wp_list_filter(
$actual['data'][0]['data'],
array(
'name' => 'Test Additional Data Name',
'value' => 'Test Additional Data Value',
)
)
)
);
}
/**
* Filter callback to add additional profile data to the User Group on Export Requests.
*
* @since 5.4.0
*
* @ticket 47509
*
* @return array $additional_profile_data The additional user data.
*/
public function export_additional_user_profile_data() {
$additional_profile_data = array(
// This item should be retained and included in the export.
array(
'name' => 'Test Additional Data Name',
'value' => 'Test Additional Data Value',
),
);
return $additional_profile_data;
}
/**
* Filter callback to add additional profile data to the User Group on Export Requests.
*
* This callback should generate a `_doing_it_wrong()`.
*
* @since 5.4.0
*
* @ticket 47509
*
* @return array $additional_profile_data The additional user data.
*/
public function export_additional_user_profile_data_with_dup_name() {
$additional_profile_data = array(
// This item should be stripped out by wp_user_personal_data_exporter()
// because it's 'name' duplicates one exported by core.
array(
'name' => 'User ID',
'value' => 'Some User ID',
),
// This item should be retained and included in the export.
array(
'name' => 'Test Additional Data Name',
'value' => 'Test Additional Data Value',
),
);
return $additional_profile_data;
}
}