Strings.toAscii().phpt 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. <?php
  2. /**
  3. * Test: Nette\Utils\Strings::toAscii()
  4. */
  5. declare(strict_types=1);
  6. use Nette\Utils\Strings;
  7. use Tester\Assert;
  8. require __DIR__ . '/../bootstrap.php';
  9. Assert::same('ZLUTOUCKY KUN oeooo--', Strings::toAscii("\u{17D}LU\u{164}OU\u{10C}K\u{DD} K\u{16E}\u{147} \u{F6}\u{151}\u{F4}o\x2d\u{2013}")); // ŽLUŤOUČKÝ KŮŇ öőôo
  10. Assert::same('Zlutoucky kun', Strings::toAscii("Z\u{30C}lut\u{30C}ouc\u{30C}ky\u{301} ku\u{30A}n\u{30C}")); // Žluťoučký kůň with combining characters
  11. Assert::same('Z `\'"^~?', Strings::toAscii("\u{17D} `'\"^~?"));
  12. Assert::same('"""\'\'\'>><<^', Strings::toAscii("\u{201E}\u{201C}\u{201D}\u{201A}\u{2018}\u{2019}\u{BB}\u{AB}\u{B0}")); // „“”‚‘’»«°
  13. Assert::same('', Strings::toAscii("\u{10000}")); // U+10000
  14. Assert::same('', Strings::toAscii("\u{A4}")); // non-ASCII char
  15. Assert::same('a b', Strings::toAscii("a\u{A0}b")); // non-breaking space
  16. Assert::same('Tarikh', Strings::toAscii("Ta\u{2BE}rikh")); // Taʾrikh
  17. Assert::exception(
  18. fn() => Strings::toAscii("0123456789\xFF"),
  19. Nette\Utils\RegexpException::class,
  20. null,
  21. PREG_BAD_UTF8_ERROR,
  22. );
  23. if (class_exists('Transliterator') && Transliterator::create('Any-Latin; Latin-ASCII')) {
  24. Assert::same('Athena->Moskva', Strings::toAscii("\u{391}\u{3B8}\u{3AE}\u{3BD}\u{3B1}\u{2192}\u{41C}\u{43E}\u{441}\u{43A}\u{432}\u{430}")); // Αθήνα→Москва
  25. }
  26. Assert::same('Ya ya Yu yu', Strings::toAscii("\u{42F} \u{44F} \u{42E} \u{44E}")); // Я я Ю ю
  27. Assert::same('Ae Oe Ue Ss ae oe ue ss', Strings::toAscii("\u{c4} \u{d6} \u{dc} \u{1e9e} \u{e4} \u{f6} \u{fc} \u{df}")); // Ä Ö Ü ẞ ä ö ü ß