mirror of
git://develop.git.wordpress.org/
synced 2025-01-17 21:08:44 +01:00
Use __trashed
suffix rather than -%trashed%
for trashed post slugs.
Percent signs are reserved characters in URIs. As such, it was impossible for plugins to route requests to trashed posts, as happens in bbPress. The new `__trashed` suffix should be sufficiently unique. Also adds a test that demonstrates that the `__trashed` suffix can be appended to slugs that contain the suffix somewhere other than the end of the string. Props netweb, ericlewis. Fixes #11863. git-svn-id: https://develop.svn.wordpress.org/trunk@37165 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
1a27ba9fd7
commit
f1c3ec9010
@ -6126,11 +6126,11 @@ function wp_add_trashed_suffix_to_post_name_for_post( $post ) {
|
||||
|
||||
$post = get_post( $post );
|
||||
|
||||
if ( strpos( $post->post_name, '-%trashed%' ) ) {
|
||||
if ( '__trashed' === substr( $post->post_name, -9 ) ) {
|
||||
return $post->post_name;
|
||||
}
|
||||
add_post_meta( $post->ID, '_wp_desired_post_slug', $post->post_name );
|
||||
$post_name = _truncate_post_slug( $post->post_name, 190 ) . '-%trashed%';
|
||||
$post_name = _truncate_post_slug( $post->post_name, 191 ) . '__trashed';
|
||||
$wpdb->update( $wpdb->posts, array( 'post_name' => $post_name ), array( 'ID' => $post->ID ) );
|
||||
clean_post_cache( $post->ID );
|
||||
return $post_name;
|
||||
|
@ -15,7 +15,21 @@ class Tests_WPInsertPost extends WP_UnitTestCase {
|
||||
'post_status' => 'publish'
|
||||
) );
|
||||
wp_trash_post( $trashed_about_page_id );
|
||||
$this->assertEquals( 'about-%trashed%', get_post( $trashed_about_page_id )->post_name );
|
||||
$this->assertEquals( 'about__trashed', get_post( $trashed_about_page_id )->post_name );
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 11863
|
||||
*/
|
||||
public function test_trashed_suffix_should_be_added_to_post_with__trashed_in_slug() {
|
||||
$trashed_about_page_id = self::factory()->post->create( array(
|
||||
'post_type' => 'page',
|
||||
'post_title' => 'About',
|
||||
'post_status' => 'publish',
|
||||
'post_name' => 'foo__trashed__foo',
|
||||
) );
|
||||
wp_trash_post( $trashed_about_page_id );
|
||||
$this->assertEquals( 'foo__trashed__foo__trashed', get_post( $trashed_about_page_id )->post_name );
|
||||
}
|
||||
|
||||
/**
|
||||
@ -49,7 +63,7 @@ class Tests_WPInsertPost extends WP_UnitTestCase {
|
||||
'post_status' => 'publish'
|
||||
) );
|
||||
|
||||
$this->assertEquals( 'about-%trashed%', get_post( $trashed_about_page_id )->post_name );
|
||||
$this->assertEquals( 'about__trashed', get_post( $trashed_about_page_id )->post_name );
|
||||
$this->assertEquals( 'about', get_post( $about_page_id )->post_name );
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user