wordpress-develop/tests/phpunit/tests/formatting/JSEscape.php
Sergey Biryukov cfc3b57488 Docs: Improve inline comments per the documentation standards.
Includes minor code layout fixes for better readability.

See #48303.

git-svn-id: https://develop.svn.wordpress.org/trunk@47122 602fd350-edb4-49c9-b593-d223f7449a82
2020-01-29 00:43:23 +00:00

47 lines
1.2 KiB
PHP

<?php
/**
* @group formatting
*/
class Tests_Formatting_JSEscape extends WP_UnitTestCase {
function test_js_escape_simple() {
$out = esc_js( 'foo bar baz();' );
$this->assertEquals( 'foo bar baz();', $out );
}
function test_js_escape_quotes() {
$out = esc_js( 'foo "bar" \'baz\'' );
// Does it make any sense to change " into &quot;? Why not \"?
$this->assertEquals( "foo &quot;bar&quot; \'baz\'", $out );
}
function test_js_escape_backslash() {
$bs = '\\';
$out = esc_js( 'foo ' . $bs . 't bar ' . $bs . $bs . ' baz' );
// \t becomes t - bug?
$this->assertEquals( 'foo t bar ' . $bs . $bs . ' baz', $out );
}
function test_js_escape_amp() {
$out = esc_js( 'foo & bar &baz; &nbsp;' );
$this->assertEquals( 'foo &amp; bar &amp;baz; &nbsp;', $out );
}
function test_js_escape_quote_entity() {
$out = esc_js( 'foo &#x27; bar &#39; baz &#x26;' );
$this->assertEquals( "foo \\' bar \\' baz &#x26;", $out );
}
function test_js_no_carriage_return() {
$out = esc_js( "foo\rbar\nbaz\r" );
// \r is stripped.
$this->assertequals( "foobar\\nbaz", $out );
}
function test_js_escape_rn() {
$out = esc_js( "foo\r\nbar\nbaz\r\n" );
// \r is stripped.
$this->assertequals( "foo\\nbar\\nbaz\\n", $out );
}
}