Add Unit Tests for i18n and wptexturize(). Don't confuse closing single quotes and apostrophes.

See #27426.


git-svn-id: https://develop.svn.wordpress.org/trunk@28762 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Scott Taylor 2014-06-17 17:56:08 +00:00
parent 03a6e5f1fb
commit 14f3b15d69
2 changed files with 236 additions and 16 deletions

View File

@ -24,19 +24,21 @@
* @uses $wp_cockneyreplace Array of formatted entities for certain common phrases * @uses $wp_cockneyreplace Array of formatted entities for certain common phrases
* *
* @param string $text The text to be formatted * @param string $text The text to be formatted
* @param bool $reset Set to true for unit testing. Translated patterns will reset.
* @return string The string replaced with html entities * @return string The string replaced with html entities
*/ */
function wptexturize($text) { function wptexturize($text, $reset = false) {
global $wp_cockneyreplace; global $wp_cockneyreplace;
static $static_characters, $static_replacements, $dynamic_characters, $dynamic_replacements, static $static_characters, $static_replacements, $dynamic_characters, $dynamic_replacements,
$default_no_texturize_tags, $default_no_texturize_shortcodes, $run_texturize = true; $default_no_texturize_tags, $default_no_texturize_shortcodes, $run_texturize = true;
if ( false === $run_texturize ) { // If there's nothing to do, just stop.
if ( empty( $text ) || false === $run_texturize ) {
return $text; return $text;
} }
// No need to set up these static variables more than once // Set up static variables. Run once only.
if ( ! isset( $static_characters ) ) { if ( $reset || ! isset( $static_characters ) ) {
/** /**
* Filter whether to skip running `wptexturize()`. * Filter whether to skip running `wptexturize()`.
* *
@ -123,9 +125,9 @@ function wptexturize($text) {
$dynamic[ '/(?<=\A|[([{<"\-]|' . $spaces . ')\'/' ] = $opening_single_quote; $dynamic[ '/(?<=\A|[([{<"\-]|' . $spaces . ')\'/' ] = $opening_single_quote;
} }
// Apostrophe in a word. No spaces or double apostrophes. // Apostrophe in a word. No spaces, double apostrophes, or other punctuation.
if ( "'" != $apos ) { if ( "'" != $apos ) {
$dynamic[ '/(?<!' . $spaces . ')\'(?!\Z|\'|' . $spaces . ')/' ] = $apos; $dynamic[ '/(?<!' . $spaces . ')\'(?!\Z|[.,:;"\'(){}<>[\]\-]|' . $spaces . ')/' ] = $apos;
} }
// 9" (double prime) // 9" (double prime)
@ -148,9 +150,9 @@ function wptexturize($text) {
$dynamic[ '/"/' ] = $closing_quote; $dynamic[ '/"/' ] = $closing_quote;
} }
// Single quotes followed by spaces or a period. // Single quotes followed by spaces or ending punctuation.
if ( "'" !== $closing_single_quote ) { if ( "'" != $closing_single_quote ) {
$dynamic[ '/\'(?=\Z|\.|' . $spaces . ')/' ] = $closing_single_quote; $dynamic[ '/\'(?=\Z|[.,)}>\-\]]|' . $spaces . ')/' ] = $closing_single_quote;
} }
// Dashes and spaces // Dashes and spaces
@ -163,11 +165,6 @@ function wptexturize($text) {
$dynamic_replacements = array_values( $dynamic ); $dynamic_replacements = array_values( $dynamic );
} }
// If there's nothing to do, just stop.
if ( empty( $text ) ) {
return $text;
}
// Transform into regexp sub-expression used in _wptexturize_pushpop_element // Transform into regexp sub-expression used in _wptexturize_pushpop_element
// Must do this every time in case plugins use these filters in a context sensitive manner // Must do this every time in case plugins use these filters in a context sensitive manner
/** /**

View File

@ -189,7 +189,7 @@ class Tests_Formatting_WPTexturize extends WP_UnitTestCase {
function test_spaces_around_hyphens() { function test_spaces_around_hyphens() {
$nbsp = "\xC2\xA0"; $nbsp = "\xC2\xA0";
$this->assertEquals( ' &#8211; ', wptexturize( ' - ' ) ); $this->assertEquals( ' &#8211; ', wptexturize( ' - ' ) );
$this->assertEquals( '&nbsp;&#8211;&nbsp;', wptexturize( '&nbsp;-&nbsp;' ) ); $this->assertEquals( '&nbsp;&#8211;&nbsp;', wptexturize( '&nbsp;-&nbsp;' ) );
$this->assertEquals( ' &#8211;&nbsp;', wptexturize( ' -&nbsp;' ) ); $this->assertEquals( ' &#8211;&nbsp;', wptexturize( ' -&nbsp;' ) );
$this->assertEquals( '&nbsp;&#8211; ', wptexturize( '&nbsp;- ') ); $this->assertEquals( '&nbsp;&#8211; ', wptexturize( '&nbsp;- ') );
@ -197,7 +197,7 @@ class Tests_Formatting_WPTexturize extends WP_UnitTestCase {
$this->assertEquals( " &#8211;$nbsp", wptexturize( " -$nbsp" ) ); $this->assertEquals( " &#8211;$nbsp", wptexturize( " -$nbsp" ) );
$this->assertEquals( "$nbsp&#8211; ", wptexturize( "$nbsp- ") ); $this->assertEquals( "$nbsp&#8211; ", wptexturize( "$nbsp- ") );
$this->assertEquals( ' &#8212; ', wptexturize( ' -- ' ) ); $this->assertEquals( ' &#8212; ', wptexturize( ' -- ' ) );
$this->assertEquals( '&nbsp;&#8212;&nbsp;', wptexturize( '&nbsp;--&nbsp;' ) ); $this->assertEquals( '&nbsp;&#8212;&nbsp;', wptexturize( '&nbsp;--&nbsp;' ) );
$this->assertEquals( ' &#8212;&nbsp;', wptexturize( ' --&nbsp;' ) ); $this->assertEquals( ' &#8212;&nbsp;', wptexturize( ' --&nbsp;' ) );
$this->assertEquals( '&nbsp;&#8212; ', wptexturize( '&nbsp;-- ') ); $this->assertEquals( '&nbsp;&#8212; ', wptexturize( '&nbsp;-- ') );
@ -723,6 +723,10 @@ class Tests_Formatting_WPTexturize extends WP_UnitTestCase {
"word word'.word", "word word'.word",
"word word&#8217;.word", "word word&#8217;.word",
), ),
array(
"word word', she said",
"word word&#8217;, she said",
),
array( array(
"word word'", "word word'",
"word word&#8217;", "word word&#8217;",
@ -1362,4 +1366,223 @@ class Tests_Formatting_WPTexturize extends WP_UnitTestCase {
), ),
); );
} }
/**
* Make sure translation actually works.
*
* Also make sure apostrophes and closing quotes aren't being confused by default.
*
* @ticket 27426
* @dataProvider data_tag_avoidance
*/
function test_translate( $input, $output ) {
add_filter( 'gettext_with_context', array( $this, 'filter_translate' ), 10, 4 );
$result = wptexturize( $input, true );
remove_filter( 'gettext_with_context', array( $this, 'filter_translate' ), 10, 4 );
wptexturize( 'reset', true );
return $this->assertEquals( $output, $result );
}
function filter_translate( $translations, $text, $context, $domain ) {
switch ($text) {
case '&#8211;' : return '!endash!';
case '&#8212;' : return '!emdash!';
case '&#8216;' : return '!openq1!';
case '&#8217;' :
if ( 'apostrophe' == $context ) {
return '!apos!';
} else {
return '!closeq1!';
}
case '&#8220;' : return '!openq2!';
case '&#8221;' : return '!closeq2!';
case '&#8242;' : return '!prime1!';
case '&#8243;' : return '!prime2!';
default : return $translations;
}
}
function data_translate() {
return array(
array(
"word '99 word",
"word !apos!99 word",
),
array(
"word'99 word",
"word!apos!99 word",
),
array(
"word 'test sentence' word",
"word !openq1!test sentence!closeq1! word",
),
array(
"'test sentence'",
"!openq1!test sentence!closeq1!",
),
array(
'word "test sentence" word',
'word !openq2!test sentence!closeq2! word',
),
array(
'"test sentence"',
'!openq2!test sentence!closeq2!',
),
array(
"word 'word word",
"word !openq1!word word",
),
array(
"word ('word word",
"word (!openq1!word word",
),
array(
"word ['word word",
"word [!openq1!word word",
),
array(
'word 99" word',
'word 99!prime2! word',
),
array(
'word 99"word',
'word 99!prime2!word',
),
array(
'word99" word',
'word99!prime2! word',
),
array(
'word99"word',
'word99!prime2!word',
),
array(
"word 99' word",
"word 99!prime1! word",
),
array(
"word99' word",
"word99!prime1! word",
),
array(
"word word's word",
"word word!apos!s word",
),
array(
"word word'. word",
"word word!closeq1!. word",
),
array(
"word ]'. word",
"word ]!closeq1!. word",
),
array(
'word "word word',
'word !openq2!word word',
),
array(
'word ("word word',
'word (!openq2!word word',
),
array(
'word ["word word',
'word [!openq2!word word',
),
array(
'word word" word',
'word word!closeq2! word',
),
array(
'word word") word',
'word word!closeq2!) word',
),
array(
'word word"] word',
'word word!closeq2!] word',
),
array(
'word word"',
'word word!closeq2!',
),
array(
'word word"word',
'word word!closeq2!word',
),
array(
'test sentence".',
'test sentence!closeq2!.',
),
array(
'test sentence."',
'test sentence.!closeq2!',
),
array(
'test sentence." word',
'test sentence.!closeq2! word',
),
array(
"word word' word",
"word word!closeq1! word",
),
array(
"word word'. word",
"word word!closeq1!. word",
),
array(
"word word'.word",
"word word!closeq1!.word",
),
array(
"word word'",
"word word!closeq1!",
),
array(
"test sentence'.",
"test sentence!closeq1!.",
),
array(
"test sentence.'",
"test sentence.!closeq1!",
),
array(
"test sentence'. word",
"test sentence!closeq1!. word",
),
array(
"test sentence.' word",
"test sentence.!closeq1! word",
),
array(
"word 'tain't word",
"word !apos!tain!apos!t word",
),
array(
"word 'twere word",
"word !apos!twere word",
),
array(
'word "42.00" word',
'word !openq2!42.00!closeq2! word',
),
array(
"word '42.00' word",
"word !openq1!42.00!closeq1! word",
),
array(
"word word'. word",
"word word!closeq1!. word",
),
array(
"word word'.word",
"word word!closeq1!.word",
),
array(
"word word', she said",
"word word!closeq1!, she said",
),
);
}
} }