| [ Index ] | PHP Cross Reference of BuddyPress | 
[Summary view] [Print] [Text view]
1 <?php 2 3 /** 4 * @group xprofile 5 * @group functions 6 */ 7 class BP_Tests_XProfile_Functions extends BP_UnitTestCase { 8 public function test_get_hidden_field_types_for_user_loggedout() { 9 $duser = self::factory()->user->create(); 10 11 $old_current_user = bp_loggedin_user_id(); 12 $this->set_current_user( 0 ); 13 14 $this->assertEquals( array( 'friends', 'loggedin', 'adminsonly' ), bp_xprofile_get_hidden_field_types_for_user( $duser, bp_loggedin_user_id() ) ); 15 16 $this->set_current_user( $old_current_user ); 17 } 18 19 public function test_get_hidden_field_types_for_user_loggedin() { 20 $duser = self::factory()->user->create(); 21 $cuser = self::factory()->user->create(); 22 23 $old_current_user = bp_loggedin_user_id(); 24 $this->set_current_user( $cuser ); 25 26 $this->assertEquals( array( 'friends', 'adminsonly' ), bp_xprofile_get_hidden_field_types_for_user( $duser, bp_loggedin_user_id() ) ); 27 28 $this->set_current_user( $old_current_user ); 29 } 30 31 public function test_get_hidden_field_types_for_user_friends() { 32 $duser = self::factory()->user->create(); 33 $cuser = self::factory()->user->create(); 34 friends_add_friend( $duser, $cuser, true ); 35 36 $old_current_user = bp_loggedin_user_id(); 37 $this->set_current_user( $cuser ); 38 39 $this->assertEquals( array( 'adminsonly' ), bp_xprofile_get_hidden_field_types_for_user( $duser, bp_loggedin_user_id() ) ); 40 41 $this->set_current_user( $old_current_user ); 42 } 43 44 public function test_get_hidden_field_types_for_user_admin() { 45 $duser = self::factory()->user->create(); 46 $cuser = self::factory()->user->create(); 47 $this->grant_bp_moderate( $cuser ); 48 49 $old_current_user = bp_loggedin_user_id(); 50 $this->set_current_user( $cuser ); 51 52 $this->assertEquals( array(), bp_xprofile_get_hidden_field_types_for_user( $duser, bp_loggedin_user_id() ) ); 53 54 $this->revoke_bp_moderate( $cuser ); 55 $this->set_current_user( $old_current_user ); 56 } 57 58 /** 59 * @group bp_xprofile_update_meta 60 * @ticket BP5180 61 */ 62 public function test_bp_xprofile_update_meta_with_line_breaks() { 63 $g = self::factory()->xprofile_group->create(); 64 $f = self::factory()->xprofile_field->create( array( 65 'field_group_id' => $g, 66 ) ); 67 68 $meta_value = 'Foo! 69 70 Bar!'; 71 bp_xprofile_update_meta( $f, 'field', 'linebreak_field', $meta_value ); 72 $this->assertEquals( $meta_value, bp_xprofile_get_meta( $f, 'field', 'linebreak_field' ) ); 73 } 74 75 /** 76 * @group bp_xprofile_fullname_field_id 77 * @group cache 78 */ 79 public function test_bp_xprofile_fullname_field_id_invalidation() { 80 // Prime the cache 81 $id = bp_xprofile_fullname_field_id(); 82 83 bp_update_option( 'bp-xprofile-fullname-field-name', 'foo' ); 84 85 $this->assertFalse( wp_cache_get( 'fullname_field_id', 'bp_xprofile' ) ); 86 } 87 88 /** 89 * @group xprofile_get_field_visibility_level 90 */ 91 public function test_bp_xprofile_get_field_visibility_level_missing_params() { 92 $this->assertSame( '', xprofile_get_field_visibility_level( 0, 1 ) ); 93 $this->assertSame( '', xprofile_get_field_visibility_level( 1, 0 ) ); 94 } 95 96 /** 97 * @group xprofile_get_field_visibility_level 98 */ 99 public function test_bp_xprofile_get_field_visibility_level_user_set() { 100 $u = self::factory()->user->create(); 101 $g = self::factory()->xprofile_group->create(); 102 $f = self::factory()->xprofile_field->create( array( 103 'field_group_id' => $g, 104 ) ); 105 106 bp_xprofile_update_meta( $f, 'field', 'default_visibility', 'adminsonly' ); 107 bp_xprofile_update_meta( $f, 'field', 'allow_custom_visibility', 'allowed' ); 108 109 xprofile_set_field_visibility_level( $f, $u, 'loggedin' ); 110 111 $this->assertSame( 'loggedin', xprofile_get_field_visibility_level( $f, $u ) ); 112 } 113 114 /** 115 * @group xprofile_get_field_visibility_level 116 */ 117 public function test_bp_xprofile_get_field_visibility_level_user_unset() { 118 $u = self::factory()->user->create(); 119 $g = self::factory()->xprofile_group->create(); 120 $f = self::factory()->xprofile_field->create( array( 121 'field_group_id' => $g, 122 ) ); 123 124 bp_xprofile_update_meta( $f, 'field', 'default_visibility', 'adminsonly' ); 125 bp_xprofile_update_meta( $f, 'field', 'allow_custom_visibility', 'allowed' ); 126 127 $this->assertSame( 'adminsonly', xprofile_get_field_visibility_level( $f, $u ) ); 128 129 } 130 131 /** 132 * @group xprofile_get_field_visibility_level 133 */ 134 public function test_bp_xprofile_get_field_visibility_level_admin_override() { 135 $u = self::factory()->user->create(); 136 $g = self::factory()->xprofile_group->create(); 137 $f = self::factory()->xprofile_field->create( array( 138 'field_group_id' => $g, 139 ) ); 140 141 bp_xprofile_update_meta( $f, 'field', 'default_visibility', 'adminsonly' ); 142 bp_xprofile_update_meta( $f, 'field', 'allow_custom_visibility', 'disabled' ); 143 144 xprofile_set_field_visibility_level( $f, $u, 'loggedin' ); 145 146 $this->assertSame( 'adminsonly', xprofile_get_field_visibility_level( $f, $u ) ); 147 } 148 149 /** 150 * @group xprofilemeta 151 * @group bp_xprofile_delete_meta 152 */ 153 public function test_bp_xprofile_delete_meta_empty_object_id() { 154 $this->assertFalse( bp_xprofile_delete_meta( '', 'group' ) ); 155 } 156 157 /** 158 * @group xprofilemeta 159 * @group bp_xprofile_delete_meta 160 */ 161 public function test_bp_xprofile_delete_meta_empty_object_type() { 162 $this->assertFalse( bp_xprofile_delete_meta( 1, '' ) ); 163 } 164 165 /** 166 * @group xprofilemeta 167 * @group bp_xprofile_delete_meta 168 */ 169 public function test_bp_xprofile_delete_meta_illegal_object_type() { 170 $this->assertFalse( bp_xprofile_delete_meta( 1, 'foo' ) ); 171 } 172 173 /** 174 * @group xprofilemeta 175 * @group bp_xprofile_delete_meta 176 * @ticket BP5399 177 */ 178 public function test_bp_xprofile_delete_meta_illegal_characters() { 179 $g = self::factory()->xprofile_group->create(); 180 bp_xprofile_update_meta( $g, 'group', 'foo', 'bar' ); 181 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 182 183 $krazy_key = ' f!@#$%^o *(){}o?+'; 184 bp_xprofile_delete_meta( $g, 'group', $krazy_key ); 185 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 186 } 187 188 /** 189 * @group xprofilemeta 190 * @group bp_xprofile_delete_meta 191 * @ticket BP5399 192 */ 193 public function test_bp_xprofile_delete_meta_trim_meta_value() { 194 $g = self::factory()->xprofile_group->create(); 195 bp_xprofile_update_meta( $g, 'group', 'foo', 'bar' ); 196 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 197 198 bp_xprofile_delete_meta( $g, 'group', 'foo', ' bar ' ); 199 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 200 } 201 202 /** 203 * @group xprofilemeta 204 * @group bp_xprofile_delete_meta 205 */ 206 public function test_bp_xprofile_delete_meta_meta_value_match() { 207 $g = self::factory()->xprofile_group->create(); 208 bp_xprofile_update_meta( $g, 'group', 'foo', 'bar' ); 209 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 210 $this->assertTrue( bp_xprofile_delete_meta( $g, 'group', 'foo', 'bar' ) ); 211 $this->assertSame( '', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 212 } 213 214 /** 215 * @group xprofilemeta 216 * @group bp_xprofile_delete_meta 217 */ 218 public function test_bp_xprofile_delete_meta_delete_all() { 219 $g = self::factory()->xprofile_group->create(); 220 bp_xprofile_update_meta( $g, 'group', 'foo', 'bar' ); 221 bp_xprofile_update_meta( $g, 'group', 'foo2', 'bar' ); 222 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 223 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo2' ) ); 224 225 $this->assertTrue( bp_xprofile_delete_meta( $g, 'group' ) ); 226 227 $this->assertSame( '', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 228 $this->assertSame( '', bp_xprofile_get_meta( $g, 'group', 'foo2' ) ); 229 } 230 231 /** 232 * @group xprofilemeta 233 * @group bp_xprofile_delete_meta 234 */ 235 public function test_bp_xprofile_delete_meta_with_delete_all_but_no_meta_key() { 236 // With no meta key, don't delete for all items - just delete 237 // all for a single item 238 $g1 = self::factory()->xprofile_group->create(); 239 $g2 = self::factory()->xprofile_group->create(); 240 bp_xprofile_add_meta( $g1, 'group', 'foo', 'bar' ); 241 bp_xprofile_add_meta( $g1, 'group', 'foo1', 'bar1' ); 242 bp_xprofile_add_meta( $g2, 'group', 'foo', 'bar' ); 243 bp_xprofile_add_meta( $g2, 'group', 'foo1', 'bar1' ); 244 245 $this->assertTrue( bp_xprofile_delete_meta( $g1, 'group', '', '', true ) ); 246 $this->assertEmpty( bp_xprofile_get_meta( $g1, 'group' ) ); 247 $this->assertSame( 'bar', bp_xprofile_get_meta( $g2, 'group', 'foo' ) ); 248 $this->assertSame( 'bar1', bp_xprofile_get_meta( $g2, 'group', 'foo1' ) ); 249 } 250 251 /** 252 * @group xprofilemeta 253 * @group bp_xprofile_delete_meta 254 */ 255 public function test_bp_xprofile_delete_meta_with_delete_all() { 256 // With no meta key, don't delete for all items - just delete 257 // all for a single item 258 $g1 = self::factory()->xprofile_group->create(); 259 $g2 = self::factory()->xprofile_group->create(); 260 bp_xprofile_add_meta( $g1, 'group', 'foo', 'bar' ); 261 bp_xprofile_add_meta( $g1, 'group', 'foo1', 'bar1' ); 262 bp_xprofile_add_meta( $g2, 'group', 'foo', 'bar' ); 263 bp_xprofile_add_meta( $g2, 'group', 'foo1', 'bar1' ); 264 265 $this->assertTrue( bp_xprofile_delete_meta( $g1, 'group', 'foo', '', true ) ); 266 $this->assertSame( '', bp_xprofile_get_meta( $g1, 'group', 'foo' ) ); 267 $this->assertSame( '', bp_xprofile_get_meta( $g2, 'group', 'foo' ) ); 268 $this->assertSame( 'bar1', bp_xprofile_get_meta( $g1, 'group', 'foo1' ) ); 269 $this->assertSame( 'bar1', bp_xprofile_get_meta( $g2, 'group', 'foo1' ) ); 270 } 271 272 /** 273 * @group xprofilemeta 274 * @group bp_xprofile_get_meta 275 */ 276 public function test_bp_xprofile_get_meta_empty_object_id() { 277 $this->assertFalse( bp_xprofile_get_meta( 0, 'group' ) ); 278 } 279 280 /** 281 * @group xprofilemeta 282 * @group bp_xprofile_get_meta 283 */ 284 public function test_bp_xprofile_get_meta_empty_object_type() { 285 $this->assertFalse( bp_xprofile_get_meta( 1, '' ) ); 286 } 287 288 /** 289 * @group xprofilemeta 290 * @group bp_xprofile_get_meta 291 */ 292 public function test_bp_xprofile_get_meta_illegal_object_type() { 293 $this->assertFalse( bp_xprofile_get_meta( 1, 'foo' ) ); 294 } 295 296 /** 297 * @group xprofilemeta 298 * @group bp_xprofile_get_meta 299 */ 300 public function test_bp_xprofile_get_meta_no_meta_key() { 301 $g = self::factory()->xprofile_group->create(); 302 bp_xprofile_update_meta( $g, 'group', 'foo', 'bar' ); 303 bp_xprofile_update_meta( $g, 'group', 'foo2', 'bar' ); 304 305 $expected = array( 306 'foo' => array( 307 'bar', 308 ), 309 'foo2' => array( 310 'bar', 311 ), 312 ); 313 $this->assertSame( $expected, bp_xprofile_get_meta( $g, 'group' ) ); 314 } 315 316 /** 317 * @group xprofilemeta 318 * @group bp_xprofile_get_meta 319 */ 320 public function test_bp_xprofile_get_meta_single_true() { 321 $g = self::factory()->xprofile_group->create(); 322 bp_xprofile_add_meta( $g, 'group', 'foo', 'bar' ); 323 bp_xprofile_add_meta( $g, 'group', 'foo', 'baz' ); 324 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); // default is true 325 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo', true ) ); 326 } 327 328 /** 329 * @group xprofilemeta 330 * @group bp_xprofile_get_meta 331 */ 332 public function test_bp_xprofile_get_meta_single_false() { 333 $g = self::factory()->xprofile_group->create(); 334 bp_xprofile_add_meta( $g, 'group', 'foo', 'bar' ); 335 bp_xprofile_add_meta( $g, 'group', 'foo', 'baz' ); 336 $this->assertSame( array( 'bar', 'baz' ), bp_xprofile_get_meta( $g, 'group', 'foo', false ) ); 337 } 338 339 /** 340 * @group xprofilemeta 341 * @group bp_xprofile_get_meta 342 */ 343 public function test_bp_xprofile_get_meta_no_meta_key_no_results() { 344 $g = self::factory()->xprofile_group->create(); 345 346 $expected = array(); 347 $this->assertSame( $expected, bp_xprofile_get_meta( $g, 'group' ) ); 348 } 349 350 /** 351 * @group xprofilemeta 352 * @group bp_xprofile_update_meta 353 */ 354 public function test_bp_xprofile_update_meta_no_object_id() { 355 $this->assertFalse( bp_xprofile_update_meta( 0, 'group', 'foo', 'bar' ) ); 356 } 357 358 /** 359 * @group xprofilemeta 360 * @group bp_xprofile_update_meta 361 */ 362 public function test_bp_xprofile_update_meta_no_object_type() { 363 $this->assertFalse( bp_xprofile_update_meta( 1, '', 'foo', 'bar' ) ); 364 } 365 366 /** 367 * @group xprofilemeta 368 * @group bp_xprofile_update_meta 369 */ 370 public function test_bp_xprofile_update_meta_illegal_object_type() { 371 $this->assertFalse( bp_xprofile_update_meta( 1, 'foo', 'foo', 'bar' ) ); 372 } 373 374 /** 375 * @group xprofilemeta 376 * @group bp_xprofile_update_meta 377 * @ticket BP5399 378 */ 379 public function test_bp_xprofile_update_meta_illegal_characters() { 380 $g = self::factory()->xprofile_group->create(); 381 $krazy_key = ' f!@#$%^o *(){}o?+'; 382 bp_xprofile_update_meta( $g, 'group', $krazy_key, 'bar' ); 383 $this->assertSame( '', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 384 } 385 386 /** 387 * @group xprofilemeta 388 * @group bp_xprofile_update_meta 389 */ 390 public function test_bp_xprofile_update_meta_stripslashes() { 391 $g = self::factory()->xprofile_group->create(); 392 $v = "Totally \'tubular\'"; 393 bp_xprofile_update_meta( $g, 'group', 'foo', $v ); 394 $this->assertSame( stripslashes( $v ), bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 395 } 396 397 /** 398 * @group xprofilemeta 399 * @group bp_xprofile_update_meta 400 */ 401 public function test_bp_xprofile_update_meta_empty_value_delete() { 402 $g = self::factory()->xprofile_group->create(); 403 bp_xprofile_update_meta( $g, 'group', 'foo', 'bar' ); 404 bp_xprofile_update_meta( $g, 'group', 'foo', '' ); 405 $this->assertSame( '', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 406 } 407 408 /** 409 * @group xprofilemeta 410 * @group bp_xprofile_update_meta 411 */ 412 public function test_bp_xprofile_update_meta_new() { 413 $g = self::factory()->xprofile_group->create(); 414 $this->assertSame( '', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 415 $this->assertNotEmpty( bp_xprofile_update_meta( $g, 'group', 'foo', 'bar' ) ); 416 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 417 } 418 419 /** 420 * @group xprofilemeta 421 * @group bp_xprofile_update_meta 422 */ 423 public function test_bp_xprofile_update_meta_existing() { 424 $g = self::factory()->xprofile_group->create(); 425 bp_xprofile_update_meta( $g, 'group', 'foo', 'bar' ); 426 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 427 $this->assertTrue( bp_xprofile_update_meta( $g, 'group', 'foo', 'baz' ) ); 428 $this->assertSame( 'baz', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 429 } 430 431 /** 432 * @group xprofilemeta 433 * @group bp_xprofile_update_meta 434 */ 435 public function test_bp_xprofile_update_meta_same_value() { 436 $g = self::factory()->xprofile_group->create(); 437 bp_xprofile_update_meta( $g, 'group', 'foo', 'bar' ); 438 $this->assertSame( 'bar', bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 439 $this->assertFalse( bp_xprofile_update_meta( $g, 'group', 'foo', 'bar' ) ); 440 } 441 442 /** 443 * @group xprofilemeta 444 * @group bp_xprofile_update_meta 445 */ 446 public function test_bp_xprofile_update_meta_prev_value() { 447 $g = self::factory()->xprofile_group->create(); 448 bp_xprofile_add_meta( $g, 'group', 'foo', 'bar' ); 449 450 // In earlier versions of WordPress, bp_activity_update_meta() 451 // returns true even on failure. However, we know that in these 452 // cases the update is failing as expected, so we skip this 453 // assertion just to keep our tests passing 454 // See https://core.trac.wordpress.org/ticket/24933 455 if ( version_compare( $GLOBALS['wp_version'], '3.7', '>=' ) ) { 456 $this->assertFalse( bp_xprofile_update_meta( $g, 'group', 'foo', 'bar2', 'baz' ) ); 457 } 458 459 $this->assertTrue( bp_xprofile_update_meta( $g, 'group', 'foo', 'bar2', 'bar' ) ); 460 } 461 462 /** 463 * @group xprofilemeta 464 * @group bp_xprofile_update_meta 465 * @ticket BP5919 466 */ 467 public function test_bp_xprofile_update_meta_where_sql_filter_keywords_are_in_quoted_value() { 468 $g = self::factory()->xprofile_group->create(); 469 $value = "SELECT object_id FROM wp_bp_xprofile_groups WHERE \"foo\" VALUES (foo = 'bar'"; 470 bp_xprofile_add_meta( $g, 'group', 'foo', 'bar' ); 471 bp_xprofile_update_meta( $g, 'group', 'foo', $value ); 472 $this->assertSame( $value, bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 473 } 474 475 /** 476 * @group xprofilemeta 477 * @group bp_xprofile_update_meta 478 * @ticket BP5919 479 */ 480 public function test_bp_xprofile_update_meta_where_meta_id_is_in_quoted_value() { 481 $g = self::factory()->xprofile_group->create(); 482 $value = "foo meta_id bar"; 483 bp_xprofile_add_meta( $g, 'group', 'foo', 'bar' ); 484 bp_xprofile_update_meta( $g, 'group', 'foo', $value ); 485 $this->assertSame( $value, bp_xprofile_get_meta( $g, 'group', 'foo' ) ); 486 } 487 488 /** 489 * @group xprofilemeta 490 * @group bp_xprofile_add_meta 491 */ 492 public function test_bp_xprofile_add_meta_no_meta_key() { 493 $this->assertFalse( bp_xprofile_add_meta( 1, 'group', '', 'bar' ) ); 494 } 495 496 /** 497 * @group xprofilemeta 498 * @group bp_xprofile_add_meta 499 */ 500 public function test_bp_xprofile_add_meta_empty_object_id() { 501 $this->assertFalse( bp_xprofile_add_meta( 0, 'group', 'foo', 'bar' ) ); 502 } 503 504 /** 505 * @group xprofilemeta 506 * @group bp_xprofile_add_meta 507 */ 508 public function test_bp_xprofile_add_meta_existing_unique() { 509 $g = self::factory()->xprofile_group->create(); 510 bp_xprofile_add_meta( $g, 'group', 'foo', 'bar' ); 511 $this->assertFalse( bp_xprofile_add_meta( $g, 'group', 'foo', 'baz', true ) ); 512 } 513 514 /** 515 * @group xprofilemeta 516 * @group bp_xprofile_add_meta 517 */ 518 public function test_bp_xprofile_add_meta_existing_not_unique() { 519 $g = self::factory()->xprofile_group->create(); 520 bp_xprofile_add_meta( $g, 'group', 'foo', 'bar' ); 521 $this->assertNotEmpty( bp_xprofile_add_meta( $g, 'group', 'foo', 'baz' ) ); 522 } 523 524 /** 525 * @group bp_get_member_profile_data 526 */ 527 public function test_bp_get_member_profile_data_inside_loop() { 528 $u = self::factory()->user->create(); 529 $g = self::factory()->xprofile_group->create(); 530 $f = self::factory()->xprofile_field->create( array( 531 'field_group_id' => $g, 532 'name' => 'Neato', 533 ) ); 534 xprofile_set_field_data( $f, $u, 'foo' ); 535 536 if ( bp_has_members() ) : while ( bp_members() ) : bp_the_member(); 537 $found = bp_get_member_profile_data( array( 538 'user_id' => $u, 539 'field' => 'Neato', 540 ) ); 541 endwhile; endif; 542 543 // Cleanup 544 unset( $GLOBALS['members_template'] ); 545 546 $this->assertSame( 'foo', $found ); 547 } 548 /** 549 * @group bp_get_member_profile_data 550 */ 551 public function test_bp_get_member_profile_data_outside_of_loop() { 552 $u = self::factory()->user->create(); 553 $g = self::factory()->xprofile_group->create(); 554 $f = self::factory()->xprofile_field->create( array( 555 'field_group_id' => $g, 556 'name' => 'Kewl', 557 ) ); 558 xprofile_set_field_data( $f, $u, 'foo' ); 559 560 $found = bp_get_member_profile_data( array( 561 'user_id' => $u, 562 'field' => 'Kewl', 563 ) ); 564 565 $this->assertSame( 'foo', $found ); 566 } 567 568 /** 569 * @group xprofile_set_field_data 570 */ 571 public function test_get_field_data_integer_zero() { 572 $u = self::factory()->user->create(); 573 $g = self::factory()->xprofile_group->create(); 574 $f = self::factory()->xprofile_field->create( array( 575 'field_group_id' => $g, 576 'type' => 'number', 577 'name' => 'Pens', 578 ) ); 579 xprofile_set_field_data( $f, $u, 0 ); 580 581 $this->assertEquals( 0, xprofile_get_field_data( 'Pens', $u ) ); 582 } 583 584 /** 585 * @group xprofile_set_field_data 586 * @ticket BP5836 587 */ 588 public function test_xprofile_sync_bp_profile_new_user() { 589 $post_vars = $_POST; 590 591 $_POST = array( 592 'user_login' => 'foobar', 593 'pass1' => 'password', 594 'pass2' => 'password', 595 'role' => 'subscriber', 596 'email' => 'foo@bar.com', 597 'first_name' => 'Foo', 598 'last_name' => 'Bar', 599 ); 600 601 $id = add_user(); 602 603 $display_name = 'Bar Foo'; 604 605 $_POST = array( 606 'display_name' => $display_name, 607 'email' => 'foo@bar.com', 608 'nickname' => 'foobar', 609 ); 610 611 $id = edit_user( $id ); 612 613 // clean up post vars 614 $_POST = $post_vars; 615 616 $this->assertEquals( $display_name, xprofile_get_field_data( bp_xprofile_fullname_field_id(), $id ) ); 617 } 618 619 /** 620 * @group xprofile_insert_field 621 */ 622 public function test_xprofile_insert_field_type_option() { 623 $g = self::factory()->xprofile_group->create(); 624 $parent = self::factory()->xprofile_field->create( array( 625 'field_group_id' => $g, 626 'type' => 'selectbox', 627 'name' => 'Parent', 628 ) ); 629 630 $f = xprofile_insert_field( array( 631 'field_group_id' => $g, 632 'parent_id' => $parent, 633 'type' => 'option', 634 'name' => 'Option 1', 635 'field_order' => 5, 636 ) ); 637 638 $this->assertNotEmpty( $f ); 639 } 640 641 /** 642 * @group xprofile_insert_field 643 * @ticket BP6354 644 */ 645 public function test_xprofile_insert_field_should_process_falsey_values_for_boolean_params_on_existing_fields() { 646 $g = self::factory()->xprofile_group->create(); 647 $f = xprofile_insert_field( array( 648 'field_group_id' => $g, 649 'type' => 'textbox', 650 'name' => 'Foo', 651 'is_required' => true, 652 'can_delete' => true, 653 'is_default_option' => true, 654 'parent_id' => 13, 655 'field_order' => 5, 656 'option_order' => 8, 657 'description' => 'foo', 658 'order_by' => 'custom', 659 ) ); 660 661 $this->assertNotEmpty( $f ); 662 663 $field = new BP_XProfile_Field( $f ); 664 $this->assertEquals( 1, $field->is_required ); 665 $this->assertEquals( 1, $field->can_delete ); 666 $this->assertEquals( 1, $field->is_default_option ); 667 $this->assertEquals( 13, $field->parent_id ); 668 $this->assertEquals( 5, $field->field_order ); 669 $this->assertEquals( 8, $field->option_order ); 670 $this->assertEquals( 'foo', $field->description ); 671 $this->assertEquals( 'custom', $field->order_by ); 672 673 $f = xprofile_insert_field( array( 674 'field_group_id' => $g, 675 'type' => 'textbox', 676 'name' => 'Foo', 677 'is_required' => false, 678 'can_delete' => false, 679 'is_default_option' => false, 680 'parent_id' => 0, 681 'field_order' => 0, 682 'option_order' => 0, 683 'description' => '', 684 'order_by' => '', 685 ) ); 686 687 $this->assertNotEmpty( $f ); 688 689 $field = new BP_XProfile_Field( $f ); 690 $this->assertEquals( 0, $field->is_required ); 691 $this->assertEquals( 0, $field->can_delete ); 692 $this->assertEquals( 0, $field->is_default_option ); 693 $this->assertEquals( 0, $field->parent_id ); 694 $this->assertEquals( 0, $field->field_order ); 695 $this->assertEquals( 0, $field->option_order ); 696 $this->assertEquals( '', $field->description ); 697 $this->assertEquals( '', $field->order_by ); 698 } 699 700 /** 701 * @group xprofile_insert_field 702 */ 703 public function test_xprofile_insert_field_type_option_option_order() { 704 $g = self::factory()->xprofile_group->create(); 705 $parent = self::factory()->xprofile_field->create( array( 706 'field_group_id' => $g, 707 'type' => 'selectbox', 708 'name' => 'Parent', 709 ) ); 710 711 $f = xprofile_insert_field( array( 712 'field_group_id' => $g, 713 'parent_id' => $parent, 714 'type' => 'option', 715 'name' => 'Option 1', 716 'option_order' => 5, 717 ) ); 718 719 $field = new BP_XProfile_Field( $f ); 720 721 $this->assertEquals( 5, $field->option_order ); 722 } 723 724 /** 725 * @group xprofile_insert_field 726 * @ticket BP6137 727 */ 728 public function test_xprofile_insert_field_should_set_is_default_option_to_false_for_new_option() { 729 $g = self::factory()->xprofile_group->create(); 730 $parent = self::factory()->xprofile_field->create( array( 731 'field_group_id' => $g, 732 'type' => 'selectbox', 733 'name' => 'Parent', 734 ) ); 735 736 $f = xprofile_insert_field( array( 737 'field_group_id' => $g, 738 'parent_id' => $parent, 739 'type' => 'option', 740 'name' => 'Option 1', 741 'field_order' => 5, 742 'is_default_option' => false, 743 ) ); 744 745 $this->assertNotEmpty( $f ); 746 $field = new BP_XProfile_Field( $f ); 747 $this->assertEquals( 0, $field->is_default_option ); 748 } 749 750 /** 751 * @group xprofile_insert_field 752 * @ticket BP6137 753 */ 754 public function test_xprofile_insert_field_should_set_is_default_option_to_true_for_new_option() { 755 $g = self::factory()->xprofile_group->create(); 756 $parent = self::factory()->xprofile_field->create( array( 757 'field_group_id' => $g, 758 'type' => 'selectbox', 759 'name' => 'Parent', 760 ) ); 761 762 $f = xprofile_insert_field( array( 763 'field_group_id' => $g, 764 'parent_id' => $parent, 765 'type' => 'option', 766 'name' => 'Option 1', 767 'field_order' => 5, 768 'is_default_option' => true, 769 ) ); 770 771 $this->assertNotEmpty( $f ); 772 $field = new BP_XProfile_Field( $f ); 773 $this->assertEquals( 1, $field->is_default_option ); 774 } 775 776 /** 777 * @group xprofile_insert_field 778 * @ticket BP6137 779 */ 780 public function test_xprofile_insert_field_should_set_is_default_option_to_false_for_existing_option() { 781 $g = self::factory()->xprofile_group->create(); 782 $parent = self::factory()->xprofile_field->create( array( 783 'field_group_id' => $g, 784 'type' => 'selectbox', 785 'name' => 'Parent', 786 ) ); 787 788 $f = xprofile_insert_field( array( 789 'field_group_id' => $g, 790 'parent_id' => $parent, 791 'type' => 'option', 792 'name' => 'Option 1', 793 'field_order' => 5, 794 'is_default_option' => true, 795 ) ); 796 797 $this->assertNotEmpty( $f ); 798 $field = new BP_XProfile_Field( $f ); 799 $this->assertEquals( 1, $field->is_default_option ); 800 801 $f = xprofile_insert_field( array( 802 'field_id' => $f, 803 'field_group_id' => $g, 804 'type' => 'textbox', 805 'is_default_option' => false, 806 ) ); 807 808 $field2 = new BP_XProfile_Field( $f ); 809 $this->assertEquals( 0, $field2->is_default_option ); 810 } 811 812 /** 813 * @group xprofile_insert_field 814 * @ticket BP6137 815 */ 816 public function test_xprofile_insert_field_should_set_is_default_option_to_true_for_existing_option() { 817 $g = self::factory()->xprofile_group->create(); 818 $parent = self::factory()->xprofile_field->create( array( 819 'field_group_id' => $g, 820 'type' => 'selectbox', 821 'name' => 'Parent', 822 ) ); 823 824 $f = xprofile_insert_field( array( 825 'field_group_id' => $g, 826 'parent_id' => $parent, 827 'type' => 'option', 828 'name' => 'Option 1', 829 'field_order' => 5, 830 'is_default_option' => false, 831 ) ); 832 833 $this->assertNotEmpty( $f ); 834 $field = new BP_XProfile_Field( $f ); 835 $this->assertEquals( 0, $field->is_default_option ); 836 837 $f = xprofile_insert_field( array( 838 'field_id' => $f, 839 'field_group_id' => $g, 840 'type' => 'textbox', 841 'is_default_option' => true, 842 ) ); 843 844 $field2 = new BP_XProfile_Field( $f ); 845 846 $this->assertEquals( 1, $field2->is_default_option ); 847 } 848 849 /** 850 * @group xprofile_update_field_group_position 851 * @group bp_profile_get_field_groups 852 */ 853 public function test_bp_profile_get_field_groups_update_position() { 854 $g1 = self::factory()->xprofile_group->create(); 855 $g2 = self::factory()->xprofile_group->create(); 856 $g3 = self::factory()->xprofile_group->create(); 857 858 // prime the cache 859 bp_profile_get_field_groups(); 860 861 // switch the field group positions for the last two groups 862 xprofile_update_field_group_position( $g2, 3 ); 863 xprofile_update_field_group_position( $g3, 2 ); 864 865 // now refetch field groups 866 $field_groups = bp_profile_get_field_groups(); 867 868 // assert! 869 $this->assertEquals( array( 1, $g1, $g3, $g2 ), wp_list_pluck( $field_groups, 'id' ) ); 870 } 871 872 /** 873 * @ticket BP6638 874 */ 875 public function test_xprofile_get_field_should_return_bp_xprofile_field_object() { 876 global $wpdb; 877 878 $g = self::factory()->xprofile_group->create(); 879 $f = self::factory()->xprofile_field->create( array( 880 'field_group_id' => $g, 881 'type' => 'selectbox', 882 'name' => 'Foo', 883 ) ); 884 885 $field = xprofile_get_field( $f ); 886 887 $this->assertTrue( $field instanceof BP_XProfile_Field ); 888 } 889 890 /** 891 * @ticket BP6638 892 * @group cache 893 */ 894 public function test_xprofile_get_field_should_prime_field_cache() { 895 global $wpdb; 896 897 $g = self::factory()->xprofile_group->create(); 898 $f = self::factory()->xprofile_field->create( array( 899 'field_group_id' => $g, 900 'type' => 'selectbox', 901 'name' => 'Foo', 902 ) ); 903 904 $num_queries = $wpdb->num_queries; 905 906 // Prime the cache. 907 $field_1 = xprofile_get_field( $f ); 908 $num_queries++; 909 $this->assertSame( $num_queries, $wpdb->num_queries ); 910 911 // No more queries. 912 $field_2 = xprofile_get_field( $f ); 913 $this->assertEquals( $field_1, $field_2 ); 914 $this->assertSame( $num_queries, $wpdb->num_queries ); 915 } 916 917 /** 918 * @ticket BP5625 919 */ 920 public function test_bp_xprofie_is_richtext_enabled_for_field_should_default_to_true_for_textareas() { 921 $g = self::factory()->xprofile_group->create(); 922 $f = self::factory()->xprofile_field->create( array( 923 'field_group_id' => $g, 924 'type' => 'textarea', 925 ) ); 926 927 $this->assertTrue( bp_xprofile_is_richtext_enabled_for_field( $f ) ); 928 } 929 930 /** 931 * @ticket BP5625 932 */ 933 public function test_bp_xprofie_is_richtext_enabled_for_field_should_default_to_false_for_non_textareas() { 934 $g = self::factory()->xprofile_group->create(); 935 $f = self::factory()->xprofile_field->create( array( 936 'field_group_id' => $g, 937 'type' => 'radio', 938 ) ); 939 940 $this->assertFalse( bp_xprofile_is_richtext_enabled_for_field( $f ) ); 941 } 942 943 /** 944 * @group bp_get_field_css_class 945 */ 946 public function test_bp_get_field_css_class_empty_param() { 947 // Fake the global 948 global $profile_template; 949 $reset_profile_template = $profile_template; 950 951 $profile_template = new stdClass; 952 // Avoid the 'alt' class being added 953 $profile_template->current_field = 2; 954 $profile_template->field = new stdClass; 955 $profile_template->field->id = 145; 956 $profile_template->field->name = 'Pie'; 957 $profile_template->field->type = 'textbox'; 958 959 $expected_classes = array( 960 'optional-field', 961 'field_' . $profile_template->field->id, 962 'field_' . sanitize_title( $profile_template->field->name ), 963 'field_type_' . sanitize_title( $profile_template->field->type ), 964 'visibility-public' 965 ); 966 967 $classes = bp_get_field_css_class(); 968 preg_match( '/class=["\']?([^"\']*)["\' ]/is', $classes, $matches ); 969 $ret_classes = explode( ' ', $matches[1] ); 970 $this->assertEqualSets( $expected_classes, $ret_classes ); 971 972 // Clean up! 973 $profile_template = $reset_profile_template; 974 } 975 976 /** 977 * @group bp_get_field_css_class 978 */ 979 public function test_bp_get_field_css_class_space_delimited_string() { 980 // Fake the global 981 global $profile_template; 982 $reset_profile_template = $profile_template; 983 984 $profile_template = new stdClass; 985 // Avoid the 'alt' class being added 986 $profile_template->current_field = 2; 987 $profile_template->field = new stdClass; 988 $profile_template->field->id = 145; 989 $profile_template->field->name = 'Pie'; 990 $profile_template->field->type = 'textbox'; 991 992 $expected_classes = array( 993 'optional-field', 994 'field_' . $profile_template->field->id, 995 'field_' . sanitize_title( $profile_template->field->name ), 996 'field_type_' . sanitize_title( $profile_template->field->type ), 997 'visibility-public', 998 'rhubarb', 999 'apple' 1000 ); 1001 1002 $classes = bp_get_field_css_class( 'rhubarb apple' ); 1003 preg_match( '/class=["\']?([^"\']*)["\' ]/is', $classes, $matches ); 1004 $ret_classes = explode( ' ', $matches[1] ); 1005 $this->assertEqualSets( $expected_classes, $ret_classes ); 1006 1007 // Clean up! 1008 $profile_template = $reset_profile_template; 1009 } 1010 1011 /** 1012 * @group bp_get_field_css_class 1013 */ 1014 public function test_bp_get_field_css_class_array() { 1015 // Fake the global 1016 global $profile_template; 1017 $reset_profile_template = $profile_template; 1018 1019 $profile_template = new stdClass; 1020 // Avoid the 'alt' class being added 1021 $profile_template->current_field = 2; 1022 $profile_template->field = new stdClass; 1023 $profile_template->field->id = 145; 1024 $profile_template->field->name = 'Pie'; 1025 $profile_template->field->type = 'textbox'; 1026 1027 $expected_classes = array( 1028 'optional-field', 1029 'field_' . $profile_template->field->id, 1030 'field_' . sanitize_title( $profile_template->field->name ), 1031 'field_type_' . sanitize_title( $profile_template->field->type ), 1032 'visibility-public', 1033 'blueberry', 1034 'gooseberry' 1035 ); 1036 1037 $classes = bp_get_field_css_class( array( 'blueberry', 'gooseberry' ) ); 1038 preg_match( '/class=["\']?([^"\']*)["\' ]/is', $classes, $matches ); 1039 $ret_classes = explode( ' ', $matches[1] ); 1040 $this->assertEqualSets( $expected_classes, $ret_classes ); 1041 1042 // Clean up! 1043 $profile_template = $reset_profile_template; 1044 } 1045 1046 /** 1047 * @group xprofile_filter_link_profile_data 1048 */ 1049 public function test_field_comma_seperated_values_are_autolinked() { 1050 $field_group_id = self::factory()->xprofile_group->create(); 1051 $field_id = self::factory()->xprofile_field->create( array( 'field_group_id' => $field_group_id ) ); 1052 $GLOBALS['field'] = new BP_XProfile_Field( $field_id ); 1053 $GLOBALS['field']->do_autolink = true; 1054 1055 $output = xprofile_filter_link_profile_data( 'Hello world this is a test; with, some, words', 'textbox' ); 1056 $regex = '#^Hello world this is a test; with, <a href="([^"]+)" rel="nofollow">some</a>, <a href="([^"]+)" rel="nofollow">words</a>$#i'; 1057 1058 $this->assertRegExp( $regex, $output ); 1059 unset( $GLOBALS['field'] ); 1060 } 1061 1062 /** 1063 * @group xprofile_filter_link_profile_data 1064 */ 1065 public function test_field_semicolon_seperated_values_are_autolinked() { 1066 $field_group_id = self::factory()->xprofile_group->create(); 1067 $field_id = self::factory()->xprofile_field->create( array( 'field_group_id' => $field_group_id ) ); 1068 $GLOBALS['field'] = new BP_XProfile_Field( $field_id ); 1069 $GLOBALS['field']->do_autolink = true; 1070 1071 $output = xprofile_filter_link_profile_data( 'Hello world this is a test with; some; words', 'textbox' ); 1072 $regex = '#^Hello world this is a test with; <a href="([^"]+)" rel="nofollow">some</a>; <a href="([^"]+)" rel="nofollow">words</a>$#i'; 1073 1074 $this->assertRegExp( $regex, $output ); 1075 unset( $GLOBALS['field'] ); 1076 } 1077 1078 /** 1079 * @ticket BP7817 1080 * @ticket BP7698 1081 */ 1082 public function test_bp_xprofile_personal_data_exporter() { 1083 $u = self::factory()->user->create(); 1084 1085 $field_group_id = self::factory()->xprofile_group->create(); 1086 $f1 = self::factory()->xprofile_field->create( 1087 array( 1088 'field_group_id' => $field_group_id, 1089 ) 1090 ); 1091 $f2 = self::factory()->xprofile_field->create( 1092 array( 1093 'field_group_id' => $field_group_id, 1094 'type' => 'checkbox', 1095 ) 1096 ); 1097 1098 $option1 = xprofile_insert_field( array( 1099 'field_group_id' => $field_group_id, 1100 'parent_id' => $f2, 1101 'type' => 'option', 1102 'name' => 'Option 1', 1103 ) ); 1104 1105 $option2 = xprofile_insert_field( array( 1106 'field_group_id' => $field_group_id, 1107 'parent_id' => $f2, 1108 'type' => 'option', 1109 'name' => 'Option 2', 1110 ) ); 1111 1112 $option3 = xprofile_insert_field( array( 1113 'field_group_id' => $field_group_id, 1114 'parent_id' => $f2, 1115 'type' => 'option', 1116 'name' => 'Option 3', 1117 ) ); 1118 1119 xprofile_set_field_data( $f1, $u, 'foo' ); 1120 xprofile_set_field_data( $f2, $u, array( 'Option 1', 'Option 3' ) ); 1121 1122 $test_user = new WP_User( $u ); 1123 1124 $actual = bp_xprofile_personal_data_exporter( $test_user->user_email ); 1125 1126 $this->assertTrue( $actual['done'] ); 1127 1128 // Number of exported users. 1129 $this->assertSame( 1, count( $actual['data'] ) ); 1130 1131 // Number of exported user properties. 1132 $this->assertSame( 3, count( $actual['data'][0]['data'] ) ); 1133 } 1134 1135 /** 1136 * @ticket BP8175 1137 */ 1138 public function test_xprofile_data_should_be_deleted_on_user_delete_non_multisite() { 1139 if ( is_multisite() ) { 1140 $this->markTestSkipped( __METHOD__ . ' requires non-multisite.' ); 1141 } 1142 1143 $u = self::factory()->user->create(); 1144 1145 $fg = self::factory()->xprofile_group->create(); 1146 $f1 = self::factory()->xprofile_field->create( 1147 array( 1148 'field_group_id' => $fg, 1149 ) 1150 ); 1151 1152 xprofile_set_field_data( $f1, $u, 'foo' ); 1153 $this->assertSame( 'foo', xprofile_get_field_data( $f1, $u ) ); 1154 1155 wp_delete_user( $u ); 1156 1157 $this->assertSame( '', xprofile_get_field_data( $f1, $u ) ); 1158 } 1159 1160 /** 1161 * @ticket BP8175 1162 */ 1163 public function test_xprofile_data_should_be_deleted_on_user_delete_multisite() { 1164 if ( ! is_multisite() ) { 1165 $this->markTestSkipped( __METHOD__ . ' requires multisite.' ); 1166 } 1167 1168 $u = self::factory()->user->create(); 1169 1170 $fg = self::factory()->xprofile_group->create(); 1171 $f1 = self::factory()->xprofile_field->create( 1172 array( 1173 'field_group_id' => $fg, 1174 ) 1175 ); 1176 1177 xprofile_set_field_data( $f1, $u, 'foo' ); 1178 $this->assertSame( 'foo', xprofile_get_field_data( $f1, $u ) ); 1179 1180 wpmu_delete_user( $u ); 1181 1182 $this->assertSame( '', xprofile_get_field_data( $f1, $u ) ); 1183 } 1184 1185 /** 1186 * @ticket BP8175 1187 */ 1188 public function test_xprofile_data_should_not_be_deleted_on_wp_delete_user_multisite() { 1189 if ( ! is_multisite() ) { 1190 $this->markTestSkipped( __METHOD__ . ' requires multisite.' ); 1191 } 1192 1193 $u = self::factory()->user->create(); 1194 1195 $fg = self::factory()->xprofile_group->create(); 1196 $f1 = self::factory()->xprofile_field->create( 1197 array( 1198 'field_group_id' => $fg, 1199 ) 1200 ); 1201 1202 xprofile_set_field_data( $f1, $u, 'foo' ); 1203 $this->assertSame( 'foo', xprofile_get_field_data( $f1, $u ) ); 1204 1205 wp_delete_user( $u ); 1206 1207 $this->assertSame( 'foo', xprofile_get_field_data( $f1, $u ) ); 1208 } 1209 1210 /** 1211 * @ticket BP8568 1212 */ 1213 public function test_xprofile_sync_wp_profile_signup_with_wp_first_and_last_name_fields() { 1214 add_filter( 'bp_disable_profile_sync', '__return_true' ); 1215 1216 $u = self::factory()->user->create_and_get( 1217 array( 1218 'user_login' => 'foobar', 1219 'user_email' => 'foo@bar.email', 1220 ) 1221 ); 1222 1223 $field_fn = self::factory()->xprofile_field->create( 1224 array( 1225 'field_group_id' => 1, 1226 'type' => 'wp-textbox', 1227 'name' => 'WP First Name', 1228 ) 1229 ); 1230 1231 // Set the WP User Key. 1232 bp_xprofile_update_meta( $field_fn, 'field', 'wp_user_key', 'first_name' ); 1233 1234 $field_ln = self::factory()->xprofile_field->create( 1235 array( 1236 'field_group_id' => 1, 1237 'type' => 'wp-textbox', 1238 'name' => 'WP Last Name', 1239 ) 1240 ); 1241 1242 // Set the WP User Key. 1243 bp_xprofile_update_meta( $field_ln, 'field', 'wp_user_key', 'last_name' ); 1244 1245 $field_n = bp_xprofile_fullname_field_id(); 1246 $usermeta = array( 1247 'field_' . $field_n => 'foobar', 1248 'field_' . $field_fn => 'Foo', 1249 'field_' . $field_ln => 'Bar', 1250 'profile_field_ids' => $field_n . ',' . $field_fn . ',' . $field_ln, 1251 ); 1252 1253 remove_filter( 'bp_disable_profile_sync', '__return_true' ); 1254 1255 // simulates do_action( 'bp_core_signup_user', $user_id, $user_login, $user_password, $user_email, $usermeta ); 1256 xprofile_sync_wp_profile( $u->ID, $u->user_login, $u->user_pass, $u->user_email, $usermeta ); 1257 1258 $updated_u = get_user_by( 'id', $u->ID ); 1259 1260 $this->assertEquals( 'Foo', $updated_u->first_name ); 1261 $this->assertEquals( 'Bar', $updated_u->last_name ); 1262 } 1263 1264 /** 1265 * @ticket BP8568 1266 */ 1267 public function test_xprofile_sync_wp_profile_signup_without_wp_first_and_last_name_fields() { 1268 add_filter( 'bp_disable_profile_sync', '__return_true' ); 1269 1270 $u = self::factory()->user->create_and_get( 1271 array( 1272 'user_login' => 'foobar', 1273 'user_email' => 'foo@bar.email', 1274 ) 1275 ); 1276 1277 $field_n = bp_xprofile_fullname_field_id(); 1278 $usermeta = array( 1279 'field_' . $field_n => 'foobar', 1280 'profile_field_ids' => $field_n, 1281 ); 1282 1283 remove_filter( 'bp_disable_profile_sync', '__return_true' ); 1284 1285 // simulates do_action( 'bp_core_signup_user', $user_id, $user_login, $user_password, $user_email, $usermeta ); 1286 xprofile_sync_wp_profile( $u->ID, $u->user_login, $u->user_pass, $u->user_email, $usermeta ); 1287 1288 $updated_u = get_user_by( 'id', $u->ID ); 1289 1290 $this->assertEquals( 'foobar', $updated_u->first_name ); 1291 $this->assertEquals( '', $updated_u->last_name ); 1292 } 1293 1294 /** 1295 * @ticket BP8568 1296 */ 1297 public function test_xprofile_sync_wp_profile_activate_signup_with_wp_first_and_last_name_fields() { 1298 add_filter( 'bp_disable_profile_sync', '__return_true' ); 1299 1300 $u = self::factory()->user->create_and_get( 1301 array( 1302 'user_login' => 'barfoo', 1303 'user_email' => 'bar@foo.email', 1304 ) 1305 ); 1306 1307 $field_fn = self::factory()->xprofile_field->create( 1308 array( 1309 'field_group_id' => 1, 1310 'type' => 'wp-textbox', 1311 'name' => 'WP First Name', 1312 ) 1313 ); 1314 1315 // Set the WP User Key. 1316 bp_xprofile_update_meta( $field_fn, 'field', 'wp_user_key', 'first_name' ); 1317 1318 $field_ln = self::factory()->xprofile_field->create( 1319 array( 1320 'field_group_id' => 1, 1321 'type' => 'wp-textbox', 1322 'name' => 'WP Last Name', 1323 ) 1324 ); 1325 1326 // Set the WP User Key. 1327 bp_xprofile_update_meta( $field_ln, 'field', 'wp_user_key', 'last_name' ); 1328 1329 $field_n = bp_xprofile_fullname_field_id(); 1330 1331 $user = array( 1332 'user_id' => $u->ID, 1333 'password' => $u->user_pass, 1334 'meta' => array( 1335 'field_' . $field_n => 'barfoo', 1336 'field_' . $field_fn => 'Bar', 1337 'field_' . $field_ln => 'Foo', 1338 'profile_field_ids' => $field_n . ',' . $field_fn . ',' . $field_ln, 1339 ), 1340 ); 1341 1342 remove_filter( 'bp_disable_profile_sync', '__return_true' ); 1343 1344 // simulates do_action( 'bp_core_activated_user', $user_id, $key, $user ); 1345 xprofile_sync_wp_profile( $u->ID, 'randomkey', $user ); 1346 1347 $updated_u = get_user_by( 'id', $u->ID ); 1348 1349 $this->assertEquals( 'Bar', $updated_u->first_name ); 1350 $this->assertEquals( 'Foo', $updated_u->last_name ); 1351 } 1352 1353 /** 1354 * @ticket BP8568 1355 */ 1356 public function test_xprofile_sync_wp_profile_activate_signup_without_wp_first_and_last_name_fields() { 1357 add_filter( 'bp_disable_profile_sync', '__return_true' ); 1358 1359 $u = self::factory()->user->create_and_get( 1360 array( 1361 'user_login' => 'barfoo', 1362 'user_email' => 'bar@foo.email', 1363 ) 1364 ); 1365 1366 $field_n = bp_xprofile_fullname_field_id(); 1367 1368 $user = array( 1369 'user_id' => $u->ID, 1370 'password' => $u->user_pass, 1371 'meta' => array( 1372 'field_' . $field_n => 'barfoo', 1373 'profile_field_ids' => $field_n, 1374 ), 1375 ); 1376 1377 remove_filter( 'bp_disable_profile_sync', '__return_true' ); 1378 1379 // simulates do_action( 'bp_core_activated_user', $user_id, $key, $user ); 1380 xprofile_sync_wp_profile( $u->ID, 'randomkey', $user ); 1381 1382 $updated_u = get_user_by( 'id', $u->ID ); 1383 1384 $this->assertEquals( 'barfoo', $updated_u->first_name ); 1385 $this->assertEquals( '', $updated_u->last_name ); 1386 } 1387 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
| Generated: Sat Oct 25 01:00:55 2025 | Cross-referenced by PHPXref 0.7.1 |