Tests: Move wp_set_object_terms()
tests to their own file.
This is a redo of [37642], this time not done in the not right place. See #37009. git-svn-id: https://develop.svn.wordpress.org/trunk@37644 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
b189d26960
commit
cc7d91f141
@ -68,299 +68,6 @@ class Tests_Term extends WP_UnitTestCase {
|
||||
$this->assertEquals( 1, $count );
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 26570
|
||||
*/
|
||||
function test_set_object_terms() {
|
||||
$non_hier = rand_str( 10 );
|
||||
$hier = rand_str( 10 );
|
||||
|
||||
// Register taxonomies
|
||||
register_taxonomy( $non_hier, array() );
|
||||
register_taxonomy( $hier, array( 'hierarchical' => true ) );
|
||||
|
||||
// Create a post.
|
||||
$post_id = self::$post_ids[0];
|
||||
|
||||
/*
|
||||
* Set a single term (non-hierarchical) by ID.
|
||||
*/
|
||||
$tag = wp_insert_term( 'Foo', $non_hier );
|
||||
$this->assertFalse( has_term( $tag['term_id'], $non_hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, $tag['term_id'], $non_hier );
|
||||
$this->assertTrue( has_term( $tag['term_id'], $non_hier, $post_id ) );
|
||||
|
||||
/*
|
||||
* Set a single term (non-hierarchical) by slug.
|
||||
*/
|
||||
$tag = wp_insert_term( 'Bar', $non_hier );
|
||||
$tag = get_term( $tag['term_id'], $non_hier );
|
||||
|
||||
$this->assertFalse( has_term( $tag->slug, $non_hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, $tag->slug, $non_hier );
|
||||
$this->assertTrue( has_term( $tag->slug, $non_hier, $post_id ) );
|
||||
|
||||
/*
|
||||
* Set a single term (hierarchical) by ID.
|
||||
*/
|
||||
$cat = wp_insert_term( 'Baz', $hier );
|
||||
$this->assertFalse( has_term( $cat['term_id'], $hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, $cat['term_id'], $hier );
|
||||
$this->assertTrue( has_term( $cat['term_id'], $hier, $post_id ) );
|
||||
|
||||
/*
|
||||
* Set a single term (hierarchical) by slug.
|
||||
*/
|
||||
$cat = wp_insert_term( 'Qux', $hier );
|
||||
$cat = get_term( $cat['term_id'], $hier );
|
||||
|
||||
$this->assertFalse( has_term( $cat->slug, $hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, $cat->slug, $hier );
|
||||
$this->assertTrue( has_term( $cat->slug, $hier, $post_id ) );
|
||||
|
||||
/*
|
||||
* Set an array of term IDs (non-hierarchical) by ID.
|
||||
*/
|
||||
$tag1 = wp_insert_term( '_tag1', $non_hier );
|
||||
$this->assertFalse( has_term( $tag1['term_id'], $non_hier, $post_id ) );
|
||||
|
||||
$tag2 = wp_insert_term( '_tag2', $non_hier );
|
||||
$this->assertFalse( has_term( $tag2['term_id'], $non_hier, $post_id ) );
|
||||
|
||||
$tag3 = wp_insert_term( '_tag3', $non_hier );
|
||||
$this->assertFalse( has_term( $tag3['term_id'], $non_hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, array( $tag1['term_id'], $tag2['term_id'], $tag3['term_id'] ), $non_hier );
|
||||
$this->assertTrue( has_term( array( $tag1['term_id'], $tag2['term_id'], $tag3['term_id'] ), $non_hier, $post_id ) );
|
||||
|
||||
/*
|
||||
* Set an array of term slugs (hierarchical) by slug.
|
||||
*/
|
||||
$cat1 = wp_insert_term( '_cat1', $hier );
|
||||
$cat1 = get_term( $cat1['term_id'], $hier );
|
||||
$this->assertFalse( has_term( $cat1->slug, $hier, $post_id ) );
|
||||
|
||||
$cat2 = wp_insert_term( '_cat2', $hier );
|
||||
$cat2 = get_term( $cat2['term_id'], $hier );
|
||||
$this->assertFalse( has_term( $cat2->slug, $hier, $post_id ) );
|
||||
|
||||
$cat3 = wp_insert_term( '_cat3', $hier );
|
||||
$cat3 = get_term( $cat3['term_id'], $hier );
|
||||
$this->assertFalse( has_term( $cat3->slug, $hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, array( $cat1->slug, $cat2->slug, $cat3->slug ), $hier );
|
||||
$this->assertTrue( has_term( array( $cat1->slug, $cat2->slug, $cat3->slug ), $hier, $post_id ) );
|
||||
}
|
||||
|
||||
function test_set_object_terms_by_id() {
|
||||
$ids = self::$post_ids;
|
||||
|
||||
$terms = array();
|
||||
for ($i=0; $i<3; $i++ ) {
|
||||
$term = rand_str();
|
||||
$result = wp_insert_term( $term, $this->taxonomy );
|
||||
$this->assertInternalType( 'array', $result );
|
||||
$term_id[$term] = $result['term_id'];
|
||||
}
|
||||
|
||||
foreach ($ids as $id) {
|
||||
$tt = wp_set_object_terms( $id, array_values($term_id), $this->taxonomy );
|
||||
// should return three term taxonomy ids
|
||||
$this->assertEquals( 3, count($tt) );
|
||||
}
|
||||
|
||||
// each term should be associated with every post
|
||||
foreach ($term_id as $term=>$id) {
|
||||
$actual = get_objects_in_term($id, $this->taxonomy);
|
||||
$this->assertEquals( $ids, array_map('intval', $actual) );
|
||||
}
|
||||
|
||||
// each term should have a count of 5
|
||||
foreach (array_keys($term_id) as $term) {
|
||||
$t = get_term_by('name', $term, $this->taxonomy);
|
||||
$this->assertEquals( 5, $t->count );
|
||||
}
|
||||
}
|
||||
|
||||
function test_set_object_terms_by_name() {
|
||||
$ids = self::$post_ids;
|
||||
|
||||
$terms = array(
|
||||
rand_str(),
|
||||
rand_str(),
|
||||
rand_str()
|
||||
);
|
||||
|
||||
foreach ($ids as $id) {
|
||||
$tt = wp_set_object_terms( $id, $terms, $this->taxonomy );
|
||||
// should return three term taxonomy ids
|
||||
$this->assertEquals( 3, count($tt) );
|
||||
// remember which term has which term_id
|
||||
for ($i=0; $i<3; $i++) {
|
||||
$term = get_term_by('name', $terms[$i], $this->taxonomy);
|
||||
$term_id[$terms[$i]] = intval($term->term_id);
|
||||
}
|
||||
}
|
||||
|
||||
// each term should be associated with every post
|
||||
foreach ($term_id as $term=>$id) {
|
||||
$actual = get_objects_in_term($id, $this->taxonomy);
|
||||
$this->assertEquals( $ids, array_map('intval', $actual) );
|
||||
}
|
||||
|
||||
// each term should have a count of 5
|
||||
foreach ($terms as $term) {
|
||||
$t = get_term_by('name', $term, $this->taxonomy);
|
||||
$this->assertEquals( 5, $t->count );
|
||||
}
|
||||
}
|
||||
|
||||
function test_set_object_terms_invalid() {
|
||||
// bogus taxonomy
|
||||
$result = wp_set_object_terms( self::$post_ids[0], array(rand_str()), rand_str() );
|
||||
$this->assertTrue( is_wp_error($result) );
|
||||
}
|
||||
|
||||
public function test_wp_set_object_terms_append_true() {
|
||||
register_taxonomy( 'wptests_tax', 'post' );
|
||||
$p = self::$post_ids[0];
|
||||
$t1 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
$t2 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
|
||||
$added1 = wp_set_object_terms( $p, array( $t1 ), 'wptests_tax' );
|
||||
$this->assertNotEmpty( $added1 );
|
||||
$this->assertEqualSets( array( $t1 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
$added2 = wp_set_object_terms( $p, array( $t2 ), 'wptests_tax', true );
|
||||
$this->assertNotEmpty( $added2 );
|
||||
$this->assertEqualSets( array( $t1, $t2 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
_unregister_taxonomy( 'wptests_tax' );
|
||||
}
|
||||
|
||||
public function test_wp_set_object_terms_append_false() {
|
||||
register_taxonomy( 'wptests_tax', 'post' );
|
||||
$p = self::$post_ids[0];
|
||||
$t1 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
$t2 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
|
||||
$added1 = wp_set_object_terms( $p, array( $t1 ), 'wptests_tax' );
|
||||
$this->assertNotEmpty( $added1 );
|
||||
$this->assertEqualSets( array( $t1 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
$added2 = wp_set_object_terms( $p, array( $t2 ), 'wptests_tax', false );
|
||||
$this->assertNotEmpty( $added2 );
|
||||
$this->assertEqualSets( array( $t2 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
_unregister_taxonomy( 'wptests_tax' );
|
||||
}
|
||||
|
||||
public function test_wp_set_object_terms_append_default_to_false() {
|
||||
register_taxonomy( 'wptests_tax', 'post' );
|
||||
$p = self::$post_ids[0];
|
||||
$t1 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
$t2 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
|
||||
$added1 = wp_set_object_terms( $p, array( $t1 ), 'wptests_tax' );
|
||||
$this->assertNotEmpty( $added1 );
|
||||
$this->assertEqualSets( array( $t1 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
$added2 = wp_set_object_terms( $p, array( $t2 ), 'wptests_tax' );
|
||||
$this->assertNotEmpty( $added2 );
|
||||
$this->assertEqualSets( array( $t2 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
_unregister_taxonomy( 'wptests_tax' );
|
||||
}
|
||||
|
||||
function test_change_object_terms_by_id() {
|
||||
// set some terms on an object; then change them while leaving one intact
|
||||
|
||||
$post_id = self::$post_ids[0];
|
||||
|
||||
// first set: 3 terms
|
||||
$terms_1 = array();
|
||||
for ($i=0; $i<3; $i++ ) {
|
||||
$term = rand_str();
|
||||
$result = wp_insert_term( $term, $this->taxonomy );
|
||||
$this->assertInternalType( 'array', $result );
|
||||
$terms_1[$i] = $result['term_id'];
|
||||
}
|
||||
|
||||
// second set: one of the original terms, plus one new term
|
||||
$terms_2 = array();
|
||||
$terms_2[0] = $terms_1[1];
|
||||
|
||||
$term = rand_str();
|
||||
$result = wp_insert_term( $term, $this->taxonomy );
|
||||
$terms_2[1] = $result['term_id'];
|
||||
|
||||
|
||||
// set the initial terms
|
||||
$tt_1 = wp_set_object_terms( $post_id, $terms_1, $this->taxonomy );
|
||||
$this->assertEquals( 3, count($tt_1) );
|
||||
|
||||
// make sure they're correct
|
||||
$terms = wp_get_object_terms($post_id, $this->taxonomy, array('fields' => 'ids', 'orderby' => 't.term_id'));
|
||||
$this->assertEquals( $terms_1, $terms );
|
||||
|
||||
// change the terms
|
||||
$tt_2 = wp_set_object_terms( $post_id, $terms_2, $this->taxonomy );
|
||||
$this->assertEquals( 2, count($tt_2) );
|
||||
|
||||
// make sure they're correct
|
||||
$terms = wp_get_object_terms($post_id, $this->taxonomy, array('fields' => 'ids', 'orderby' => 't.term_id'));
|
||||
$this->assertEquals( $terms_2, $terms );
|
||||
|
||||
// make sure the tt id for 'bar' matches
|
||||
$this->assertEquals( $tt_1[1], $tt_2[0] );
|
||||
|
||||
}
|
||||
|
||||
function test_change_object_terms_by_name() {
|
||||
// set some terms on an object; then change them while leaving one intact
|
||||
|
||||
$post_id = self::$post_ids[0];
|
||||
|
||||
$terms_1 = array('foo', 'bar', 'baz');
|
||||
$terms_2 = array('bar', 'bing');
|
||||
|
||||
// set the initial terms
|
||||
$tt_1 = wp_set_object_terms( $post_id, $terms_1, $this->taxonomy );
|
||||
$this->assertEquals( 3, count($tt_1) );
|
||||
|
||||
// make sure they're correct
|
||||
$terms = wp_get_object_terms($post_id, $this->taxonomy, array('fields' => 'names', 'orderby' => 't.term_id'));
|
||||
$this->assertEquals( $terms_1, $terms );
|
||||
|
||||
// change the terms
|
||||
$tt_2 = wp_set_object_terms( $post_id, $terms_2, $this->taxonomy );
|
||||
$this->assertEquals( 2, count($tt_2) );
|
||||
|
||||
// make sure they're correct
|
||||
$terms = wp_get_object_terms($post_id, $this->taxonomy, array('fields' => 'names', 'orderby' => 't.term_id'));
|
||||
$this->assertEquals( $terms_2, $terms );
|
||||
|
||||
// make sure the tt id for 'bar' matches
|
||||
$this->assertEquals( $tt_1[1], $tt_2[0] );
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 15475
|
||||
*/
|
||||
|
312
tests/phpunit/tests/term/wpSetObjectTerms.php
Normal file
312
tests/phpunit/tests/term/wpSetObjectTerms.php
Normal file
@ -0,0 +1,312 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* @group taxonomy
|
||||
*/
|
||||
class Tests_Term_WpSetObjectTerms extends WP_UnitTestCase {
|
||||
protected $taxonomy = 'category';
|
||||
protected static $post_ids = array();
|
||||
|
||||
public static function wpSetUpBeforeClass( $factory ) {
|
||||
self::$post_ids = $factory->post->create_many( 5 );
|
||||
}
|
||||
|
||||
public static function wpTearDownAfterClass() {
|
||||
foreach ( self::$post_ids as $post_id ) {
|
||||
wp_delete_post( $post_id, true );
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 26570
|
||||
*/
|
||||
function test_set_object_terms() {
|
||||
$non_hier = rand_str( 10 );
|
||||
$hier = rand_str( 10 );
|
||||
|
||||
// Register taxonomies
|
||||
register_taxonomy( $non_hier, array() );
|
||||
register_taxonomy( $hier, array( 'hierarchical' => true ) );
|
||||
|
||||
// Create a post.
|
||||
$post_id = self::$post_ids[0];
|
||||
|
||||
/*
|
||||
* Set a single term (non-hierarchical) by ID.
|
||||
*/
|
||||
$tag = wp_insert_term( 'Foo', $non_hier );
|
||||
$this->assertFalse( has_term( $tag['term_id'], $non_hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, $tag['term_id'], $non_hier );
|
||||
$this->assertTrue( has_term( $tag['term_id'], $non_hier, $post_id ) );
|
||||
|
||||
/*
|
||||
* Set a single term (non-hierarchical) by slug.
|
||||
*/
|
||||
$tag = wp_insert_term( 'Bar', $non_hier );
|
||||
$tag = get_term( $tag['term_id'], $non_hier );
|
||||
|
||||
$this->assertFalse( has_term( $tag->slug, $non_hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, $tag->slug, $non_hier );
|
||||
$this->assertTrue( has_term( $tag->slug, $non_hier, $post_id ) );
|
||||
|
||||
/*
|
||||
* Set a single term (hierarchical) by ID.
|
||||
*/
|
||||
$cat = wp_insert_term( 'Baz', $hier );
|
||||
$this->assertFalse( has_term( $cat['term_id'], $hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, $cat['term_id'], $hier );
|
||||
$this->assertTrue( has_term( $cat['term_id'], $hier, $post_id ) );
|
||||
|
||||
/*
|
||||
* Set a single term (hierarchical) by slug.
|
||||
*/
|
||||
$cat = wp_insert_term( 'Qux', $hier );
|
||||
$cat = get_term( $cat['term_id'], $hier );
|
||||
|
||||
$this->assertFalse( has_term( $cat->slug, $hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, $cat->slug, $hier );
|
||||
$this->assertTrue( has_term( $cat->slug, $hier, $post_id ) );
|
||||
|
||||
/*
|
||||
* Set an array of term IDs (non-hierarchical) by ID.
|
||||
*/
|
||||
$tag1 = wp_insert_term( '_tag1', $non_hier );
|
||||
$this->assertFalse( has_term( $tag1['term_id'], $non_hier, $post_id ) );
|
||||
|
||||
$tag2 = wp_insert_term( '_tag2', $non_hier );
|
||||
$this->assertFalse( has_term( $tag2['term_id'], $non_hier, $post_id ) );
|
||||
|
||||
$tag3 = wp_insert_term( '_tag3', $non_hier );
|
||||
$this->assertFalse( has_term( $tag3['term_id'], $non_hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, array( $tag1['term_id'], $tag2['term_id'], $tag3['term_id'] ), $non_hier );
|
||||
$this->assertTrue( has_term( array( $tag1['term_id'], $tag2['term_id'], $tag3['term_id'] ), $non_hier, $post_id ) );
|
||||
|
||||
/*
|
||||
* Set an array of term slugs (hierarchical) by slug.
|
||||
*/
|
||||
$cat1 = wp_insert_term( '_cat1', $hier );
|
||||
$cat1 = get_term( $cat1['term_id'], $hier );
|
||||
$this->assertFalse( has_term( $cat1->slug, $hier, $post_id ) );
|
||||
|
||||
$cat2 = wp_insert_term( '_cat2', $hier );
|
||||
$cat2 = get_term( $cat2['term_id'], $hier );
|
||||
$this->assertFalse( has_term( $cat2->slug, $hier, $post_id ) );
|
||||
|
||||
$cat3 = wp_insert_term( '_cat3', $hier );
|
||||
$cat3 = get_term( $cat3['term_id'], $hier );
|
||||
$this->assertFalse( has_term( $cat3->slug, $hier, $post_id ) );
|
||||
|
||||
wp_set_object_terms( $post_id, array( $cat1->slug, $cat2->slug, $cat3->slug ), $hier );
|
||||
$this->assertTrue( has_term( array( $cat1->slug, $cat2->slug, $cat3->slug ), $hier, $post_id ) );
|
||||
}
|
||||
|
||||
function test_set_object_terms_by_id() {
|
||||
$ids = self::$post_ids;
|
||||
|
||||
$terms = array();
|
||||
for ($i=0; $i<3; $i++ ) {
|
||||
$term = rand_str();
|
||||
$result = wp_insert_term( $term, $this->taxonomy );
|
||||
$this->assertInternalType( 'array', $result );
|
||||
$term_id[$term] = $result['term_id'];
|
||||
}
|
||||
|
||||
foreach ($ids as $id) {
|
||||
$tt = wp_set_object_terms( $id, array_values($term_id), $this->taxonomy );
|
||||
// should return three term taxonomy ids
|
||||
$this->assertEquals( 3, count($tt) );
|
||||
}
|
||||
|
||||
// each term should be associated with every post
|
||||
foreach ($term_id as $term=>$id) {
|
||||
$actual = get_objects_in_term($id, $this->taxonomy);
|
||||
$this->assertEquals( $ids, array_map('intval', $actual) );
|
||||
}
|
||||
|
||||
// each term should have a count of 5
|
||||
foreach (array_keys($term_id) as $term) {
|
||||
$t = get_term_by('name', $term, $this->taxonomy);
|
||||
$this->assertEquals( 5, $t->count );
|
||||
}
|
||||
}
|
||||
|
||||
function test_set_object_terms_by_name() {
|
||||
$ids = self::$post_ids;
|
||||
|
||||
$terms = array(
|
||||
rand_str(),
|
||||
rand_str(),
|
||||
rand_str()
|
||||
);
|
||||
|
||||
foreach ($ids as $id) {
|
||||
$tt = wp_set_object_terms( $id, $terms, $this->taxonomy );
|
||||
// should return three term taxonomy ids
|
||||
$this->assertEquals( 3, count($tt) );
|
||||
// remember which term has which term_id
|
||||
for ($i=0; $i<3; $i++) {
|
||||
$term = get_term_by('name', $terms[$i], $this->taxonomy);
|
||||
$term_id[$terms[$i]] = intval($term->term_id);
|
||||
}
|
||||
}
|
||||
|
||||
// each term should be associated with every post
|
||||
foreach ($term_id as $term=>$id) {
|
||||
$actual = get_objects_in_term($id, $this->taxonomy);
|
||||
$this->assertEquals( $ids, array_map('intval', $actual) );
|
||||
}
|
||||
|
||||
// each term should have a count of 5
|
||||
foreach ($terms as $term) {
|
||||
$t = get_term_by('name', $term, $this->taxonomy);
|
||||
$this->assertEquals( 5, $t->count );
|
||||
}
|
||||
}
|
||||
|
||||
function test_set_object_terms_invalid() {
|
||||
// bogus taxonomy
|
||||
$result = wp_set_object_terms( self::$post_ids[0], array(rand_str()), rand_str() );
|
||||
$this->assertTrue( is_wp_error($result) );
|
||||
}
|
||||
|
||||
public function test_wp_set_object_terms_append_true() {
|
||||
register_taxonomy( 'wptests_tax', 'post' );
|
||||
$p = self::$post_ids[0];
|
||||
$t1 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
$t2 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
|
||||
$added1 = wp_set_object_terms( $p, array( $t1 ), 'wptests_tax' );
|
||||
$this->assertNotEmpty( $added1 );
|
||||
$this->assertEqualSets( array( $t1 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
$added2 = wp_set_object_terms( $p, array( $t2 ), 'wptests_tax', true );
|
||||
$this->assertNotEmpty( $added2 );
|
||||
$this->assertEqualSets( array( $t1, $t2 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
_unregister_taxonomy( 'wptests_tax' );
|
||||
}
|
||||
|
||||
public function test_wp_set_object_terms_append_false() {
|
||||
register_taxonomy( 'wptests_tax', 'post' );
|
||||
$p = self::$post_ids[0];
|
||||
$t1 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
$t2 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
|
||||
$added1 = wp_set_object_terms( $p, array( $t1 ), 'wptests_tax' );
|
||||
$this->assertNotEmpty( $added1 );
|
||||
$this->assertEqualSets( array( $t1 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
$added2 = wp_set_object_terms( $p, array( $t2 ), 'wptests_tax', false );
|
||||
$this->assertNotEmpty( $added2 );
|
||||
$this->assertEqualSets( array( $t2 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
_unregister_taxonomy( 'wptests_tax' );
|
||||
}
|
||||
|
||||
public function test_wp_set_object_terms_append_default_to_false() {
|
||||
register_taxonomy( 'wptests_tax', 'post' );
|
||||
$p = self::$post_ids[0];
|
||||
$t1 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
$t2 = self::factory()->term->create( array(
|
||||
'taxonomy' => 'wptests_tax',
|
||||
) );
|
||||
|
||||
$added1 = wp_set_object_terms( $p, array( $t1 ), 'wptests_tax' );
|
||||
$this->assertNotEmpty( $added1 );
|
||||
$this->assertEqualSets( array( $t1 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
$added2 = wp_set_object_terms( $p, array( $t2 ), 'wptests_tax' );
|
||||
$this->assertNotEmpty( $added2 );
|
||||
$this->assertEqualSets( array( $t2 ), wp_get_object_terms( $p, 'wptests_tax', array( 'fields' => 'ids' ) ) );
|
||||
|
||||
_unregister_taxonomy( 'wptests_tax' );
|
||||
}
|
||||
|
||||
function test_change_object_terms_by_id() {
|
||||
// set some terms on an object; then change them while leaving one intact
|
||||
|
||||
$post_id = self::$post_ids[0];
|
||||
|
||||
// first set: 3 terms
|
||||
$terms_1 = array();
|
||||
for ($i=0; $i<3; $i++ ) {
|
||||
$term = rand_str();
|
||||
$result = wp_insert_term( $term, $this->taxonomy );
|
||||
$this->assertInternalType( 'array', $result );
|
||||
$terms_1[$i] = $result['term_id'];
|
||||
}
|
||||
|
||||
// second set: one of the original terms, plus one new term
|
||||
$terms_2 = array();
|
||||
$terms_2[0] = $terms_1[1];
|
||||
|
||||
$term = rand_str();
|
||||
$result = wp_insert_term( $term, $this->taxonomy );
|
||||
$terms_2[1] = $result['term_id'];
|
||||
|
||||
|
||||
// set the initial terms
|
||||
$tt_1 = wp_set_object_terms( $post_id, $terms_1, $this->taxonomy );
|
||||
$this->assertEquals( 3, count($tt_1) );
|
||||
|
||||
// make sure they're correct
|
||||
$terms = wp_get_object_terms($post_id, $this->taxonomy, array('fields' => 'ids', 'orderby' => 't.term_id'));
|
||||
$this->assertEquals( $terms_1, $terms );
|
||||
|
||||
// change the terms
|
||||
$tt_2 = wp_set_object_terms( $post_id, $terms_2, $this->taxonomy );
|
||||
$this->assertEquals( 2, count($tt_2) );
|
||||
|
||||
// make sure they're correct
|
||||
$terms = wp_get_object_terms($post_id, $this->taxonomy, array('fields' => 'ids', 'orderby' => 't.term_id'));
|
||||
$this->assertEquals( $terms_2, $terms );
|
||||
|
||||
// make sure the tt id for 'bar' matches
|
||||
$this->assertEquals( $tt_1[1], $tt_2[0] );
|
||||
|
||||
}
|
||||
|
||||
function test_change_object_terms_by_name() {
|
||||
// set some terms on an object; then change them while leaving one intact
|
||||
|
||||
$post_id = self::$post_ids[0];
|
||||
|
||||
$terms_1 = array('foo', 'bar', 'baz');
|
||||
$terms_2 = array('bar', 'bing');
|
||||
|
||||
// set the initial terms
|
||||
$tt_1 = wp_set_object_terms( $post_id, $terms_1, $this->taxonomy );
|
||||
$this->assertEquals( 3, count($tt_1) );
|
||||
|
||||
// make sure they're correct
|
||||
$terms = wp_get_object_terms($post_id, $this->taxonomy, array('fields' => 'names', 'orderby' => 't.term_id'));
|
||||
$this->assertEquals( $terms_1, $terms );
|
||||
|
||||
// change the terms
|
||||
$tt_2 = wp_set_object_terms( $post_id, $terms_2, $this->taxonomy );
|
||||
$this->assertEquals( 2, count($tt_2) );
|
||||
|
||||
// make sure they're correct
|
||||
$terms = wp_get_object_terms($post_id, $this->taxonomy, array('fields' => 'names', 'orderby' => 't.term_id'));
|
||||
$this->assertEquals( $terms_2, $terms );
|
||||
|
||||
// make sure the tt id for 'bar' matches
|
||||
$this->assertEquals( $tt_1[1], $tt_2[0] );
|
||||
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user