X-Git-Url: http://www.aleph1.co.uk/gitweb/?p=yaffs-website;a=blobdiff_plain;f=web%2Fcore%2Fmodules%2Flocale%2Ftests%2Fsrc%2FFunctional%2FLocaleJavascriptTranslationTest.php;fp=web%2Fcore%2Fmodules%2Flocale%2Ftests%2Fsrc%2FFunctional%2FLocaleJavascriptTranslationTest.php;h=d46fa5ea91d31d515eeb8cff38cca2db19368548;hp=bbb825832b77324c3f9e1d4ecbf8e64419ce2c6b;hb=9917807b03b64faf00f6a1f29dcb6eafc454efa5;hpb=aea91e65e895364e460983b890e295aa5d5540a5 diff --git a/web/core/modules/locale/tests/src/Functional/LocaleJavascriptTranslationTest.php b/web/core/modules/locale/tests/src/Functional/LocaleJavascriptTranslationTest.php index bbb825832..d46fa5ea9 100644 --- a/web/core/modules/locale/tests/src/Functional/LocaleJavascriptTranslationTest.php +++ b/web/core/modules/locale/tests/src/Functional/LocaleJavascriptTranslationTest.php @@ -21,73 +21,86 @@ class LocaleJavascriptTranslationTest extends BrowserTestBase { public static $modules = ['locale', 'locale_test']; public function testFileParsing() { - $filename = __DIR__ . '/../../locale_test.js'; - // Parse the file to look for source strings. - _locale_parse_js_file($filename); - - // Get all of the source strings that were found. - $strings = $this->container - ->get('locale.storage') - ->getStrings([ - 'type' => 'javascript', - 'name' => $filename, - ]); - - $source_strings = []; - foreach ($strings as $string) { - $source_strings[$string->source] = $string->context; + // This test is for ensuring that the regular expression in + // _locale_parse_js_file() finds translatable source strings in all valid + // JavaScript syntax regardless of the coding style used, especially with + // respect to optional whitespace, line breaks, etc. + // - We test locale_test.es6.js, because that is the one that contains a + // variety of whitespace styles. + // - We also test the transpiled locale_test.js as an extra double-check + // that JavaScript transpilation doesn't change what + // _locale_parse_js_file() finds. + $files[] = __DIR__ . '/../../locale_test.es6.js'; + $files[] = __DIR__ . '/../../locale_test.js'; + + foreach ($files as $filename) { + // Parse the file to look for source strings. + _locale_parse_js_file($filename); + + // Get all of the source strings that were found. + $strings = $this->container + ->get('locale.storage') + ->getStrings([ + 'type' => 'javascript', + 'name' => $filename, + ]); + + $source_strings = []; + foreach ($strings as $string) { + $source_strings[$string->source] = $string->context; + } + + $etx = LOCALE_PLURAL_DELIMITER; + // List of all strings that should be in the file. + $test_strings = [ + 'Standard Call t' => '', + 'Whitespace Call t' => '', + + 'Single Quote t' => '', + "Single Quote \\'Escaped\\' t" => '', + 'Single Quote Concat strings t' => '', + + 'Double Quote t' => '', + "Double Quote \\\"Escaped\\\" t" => '', + 'Double Quote Concat strings t' => '', + + 'Context !key Args t' => 'Context string', + + 'Context Unquoted t' => 'Context string unquoted', + 'Context Single Quoted t' => 'Context string single quoted', + 'Context Double Quoted t' => 'Context string double quoted', + + "Standard Call plural{$etx}Standard Call @count plural" => '', + "Whitespace Call plural{$etx}Whitespace Call @count plural" => '', + + "Single Quote plural{$etx}Single Quote @count plural" => '', + "Single Quote \\'Escaped\\' plural{$etx}Single Quote \\'Escaped\\' @count plural" => '', + + "Double Quote plural{$etx}Double Quote @count plural" => '', + "Double Quote \\\"Escaped\\\" plural{$etx}Double Quote \\\"Escaped\\\" @count plural" => '', + + "Context !key Args plural{$etx}Context !key Args @count plural" => 'Context string', + + "Context Unquoted plural{$etx}Context Unquoted @count plural" => 'Context string unquoted', + "Context Single Quoted plural{$etx}Context Single Quoted @count plural" => 'Context string single quoted', + "Context Double Quoted plural{$etx}Context Double Quoted @count plural" => 'Context string double quoted', + ]; + + // Assert that all strings were found properly. + foreach ($test_strings as $str => $context) { + $args = ['%source' => $str, '%context' => $context]; + + // Make sure that the string was found in the file. + $this->assertTrue(isset($source_strings[$str]), SafeMarkup::format('Found source string: %source', $args)); + + // Make sure that the proper context was matched. + $message = $context ? SafeMarkup::format('Context for %source is %context', $args) : SafeMarkup::format('Context for %source is blank', $args); + $this->assertTrue(isset($source_strings[$str]) && $source_strings[$str] === $context, $message); + } + + $this->assertEqual(count($source_strings), count($test_strings), 'Found correct number of source strings.'); } - - $etx = LOCALE_PLURAL_DELIMITER; - // List of all strings that should be in the file. - $test_strings = [ - 'Standard Call t' => '', - 'Whitespace Call t' => '', - - 'Single Quote t' => '', - "Single Quote \\'Escaped\\' t" => '', - 'Single Quote Concat strings t' => '', - - 'Double Quote t' => '', - "Double Quote \\\"Escaped\\\" t" => '', - 'Double Quote Concat strings t' => '', - - 'Context !key Args t' => 'Context string', - - 'Context Unquoted t' => 'Context string unquoted', - 'Context Single Quoted t' => 'Context string single quoted', - 'Context Double Quoted t' => 'Context string double quoted', - - "Standard Call plural{$etx}Standard Call @count plural" => '', - "Whitespace Call plural{$etx}Whitespace Call @count plural" => '', - - "Single Quote plural{$etx}Single Quote @count plural" => '', - "Single Quote \\'Escaped\\' plural{$etx}Single Quote \\'Escaped\\' @count plural" => '', - - "Double Quote plural{$etx}Double Quote @count plural" => '', - "Double Quote \\\"Escaped\\\" plural{$etx}Double Quote \\\"Escaped\\\" @count plural" => '', - - "Context !key Args plural{$etx}Context !key Args @count plural" => 'Context string', - - "Context Unquoted plural{$etx}Context Unquoted @count plural" => 'Context string unquoted', - "Context Single Quoted plural{$etx}Context Single Quoted @count plural" => 'Context string single quoted', - "Context Double Quoted plural{$etx}Context Double Quoted @count plural" => 'Context string double quoted', - ]; - - // Assert that all strings were found properly. - foreach ($test_strings as $str => $context) { - $args = ['%source' => $str, '%context' => $context]; - - // Make sure that the string was found in the file. - $this->assertTrue(isset($source_strings[$str]), SafeMarkup::format('Found source string: %source', $args)); - - // Make sure that the proper context was matched. - $message = $context ? SafeMarkup::format('Context for %source is %context', $args) : SafeMarkup::format('Context for %source is blank', $args); - $this->assertTrue(isset($source_strings[$str]) && $source_strings[$str] === $context, $message); - } - - $this->assertEqual(count($source_strings), count($test_strings), 'Found correct number of source strings.'); } /**