SlugifyTest.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <?php
  2. /**
  3. * The MIT License (MIT)
  4. * Copyright (c) 2012 Florian Eckerstorfer
  5. *
  6. * Permission is hereby granted, free of charge, to any person obtaining a copy
  7. * of this software and associated documentation files (the "Software"), to
  8. * deal in the Software without restriction, including without limitation the
  9. * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
  10. * sell copies of the Software, and to permit persons to whom the Software is
  11. * furnished to do so, subject to the following conditions:
  12. *
  13. * The above copyright notice and this permission notice shall be included in
  14. * all copies or substantial portions of the Software.
  15. *
  16. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  17. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  18. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  19. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  20. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  21. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  22. * IN THE SOFTWARE.
  23. *
  24. * @package org.cocur.slugify
  25. * @category tests
  26. */
  27. namespace Cocur\Tests\Slugify;
  28. use Cocur\Slugify\Slugify;
  29. require_once __DIR__ . '/../../../../src/Cocur/Slugify/Slugify.php';
  30. /**
  31. * @package org.cocur.slugify
  32. * @category tests
  33. * @author Florian Eckerstorfer <florian@theroadtojoy.at>
  34. * @copyright 2012 Florian Eckerstorfer
  35. * @license http://www.opensource.org/licenses/MIT The MIT License
  36. */
  37. class SlugifyTest extends \PHPUnit_Framework_TestCase
  38. {
  39. /**
  40. * @param string $string
  41. * @param string $slug
  42. * @dataProvider provider
  43. */
  44. public function testSlugify($string, $slug) {
  45. $slugify = new Slugify();
  46. $this->assertEquals($slug, $slugify->slugify($string), '->slugify() transforms the string in a correct slug.');
  47. }
  48. /**
  49. * @return array
  50. */
  51. public function provider()
  52. {
  53. return array(
  54. array('Hello', 'hello'),
  55. array('Hello World', 'hello-world'),
  56. array('Hello: World', 'hello-world'),
  57. array(': World', 'world'),
  58. array('Hello World!', 'hello-world'),
  59. array('Ä ä Ö ö Ü ü ß', 'ae-ae-oe-oe-ue-ue-ss'),
  60. array('Á À á à É È é è Ó Ò ó ò Ñ ñ Ú Ù ú ù', 'a-a-a-a-e-e-e-e-o-o-o-o-n-n-u-u-u-u'),
  61. array('Â â Ê ê Ô ô Û û', 'a-a-e-e-o-o-u-u')
  62. );
  63. }
  64. }