DirectoryResourceTest.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. *
  5. * (c) Fabien Potencier <fabien@symfony.com>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Symfony\Tests\Component\Config\Resource;
  11. use Symfony\Component\Config\Resource\DirectoryResource;
  12. class DirectoryResourceTest extends \PHPUnit_Framework_TestCase
  13. {
  14. protected $resource;
  15. protected $directory;
  16. protected function setUp()
  17. {
  18. $this->directory = sys_get_temp_dir().'/symfonyDirectoryIterator';
  19. if (!file_exists($this->directory)) {
  20. mkdir($this->directory);
  21. }
  22. touch($this->directory.'/tmp.xml');
  23. $this->resource = new DirectoryResource($this->directory);
  24. }
  25. protected function tearDown()
  26. {
  27. if (!is_dir($this->directory)) {
  28. return;
  29. }
  30. $this->removeDirectory($this->directory);
  31. }
  32. protected function removeDirectory($directory) {
  33. $iterator = new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator($directory), \RecursiveIteratorIterator::CHILD_FIRST);
  34. foreach ($iterator as $path) {
  35. if (preg_match('#/\.\.?$#', $path->__toString())) {
  36. continue;
  37. }
  38. if ($path->isDir()) {
  39. rmdir($path->__toString());
  40. } else {
  41. unlink($path->__toString());
  42. }
  43. }
  44. rmdir($directory);
  45. }
  46. /**
  47. * @covers Symfony\Component\Config\Resource\DirectoryResource::getResource
  48. */
  49. public function testGetResource()
  50. {
  51. $this->assertEquals(realpath($this->directory), $this->resource->getResource(), '->getResource() returns the path to the resource');
  52. }
  53. /**
  54. * @covers Symfony\Component\Config\Resource\DirectoryResource::isFresh
  55. */
  56. public function testIsFresh()
  57. {
  58. $this->assertTrue($this->resource->isFresh(time() + 10), '->isFresh() returns true if the resource has not changed');
  59. $this->assertFalse($this->resource->isFresh(time() - 86400), '->isFresh() returns false if the resource has been updated');
  60. $resource = new DirectoryResource('/____foo/foobar'.rand(1, 999999));
  61. $this->assertFalse($resource->isFresh(time()), '->isFresh() returns false if the resource does not exist');
  62. }
  63. /**
  64. * @covers Symfony\Component\Config\Resource\DirectoryResource::isFresh
  65. */
  66. public function testIsFreshUpdateFile()
  67. {
  68. touch($this->directory.'/tmp.xml', time() + 20);
  69. $this->assertFalse($this->resource->isFresh(time() + 10), '->isFresh() returns false if an existing file is modified');
  70. }
  71. /**
  72. * @covers Symfony\Component\Config\Resource\DirectoryResource::isFresh
  73. */
  74. public function testIsFreshNewFile()
  75. {
  76. touch($this->directory.'/new.xml', time() + 20);
  77. $this->assertFalse($this->resource->isFresh(time() + 10), '->isFresh() returns false if a new file is added');
  78. }
  79. /**
  80. * @covers Symfony\Component\Config\Resource\DirectoryResource::isFresh
  81. */
  82. public function testIsFreshDeleteFile()
  83. {
  84. unlink($this->directory.'/tmp.xml');
  85. $this->assertFalse($this->resource->isFresh(time()), '->isFresh() returns false if an existing file is removed');
  86. }
  87. /**
  88. * @covers Symfony\Component\Config\Resource\DirectoryResource::isFresh
  89. */
  90. public function testIsFreshDeleteDirectory()
  91. {
  92. $this->removeDirectory($this->directory);
  93. $this->assertFalse($this->resource->isFresh(time()), '->isFresh() returns false if the whole resource is removed');
  94. }
  95. /**
  96. * @covers Symfony\Component\Config\Resource\DirectoryResource::isFresh
  97. */
  98. public function testIsFreshCreateFileInSubdirectory()
  99. {
  100. $subdirectory = $this->directory.'/subdirectory';
  101. mkdir($subdirectory);
  102. $this->assertTrue($this->resource->isFresh(time() + 10), '->isFresh() returns true if an unmodified subdirectory exists');
  103. touch($subdirectory.'/newfile.xml', time() + 20);
  104. $this->assertFalse($this->resource->isFresh(time() + 10), '->isFresh() returns false if a new file in a subdirectory is added');
  105. }
  106. /**
  107. * @covers Symfony\Component\Config\Resource\DirectoryResource::isFresh
  108. */
  109. public function testIsFreshModifySubdirectory()
  110. {
  111. $subdirectory = $this->directory.'/subdirectory';
  112. mkdir($subdirectory);
  113. touch($subdirectory, time() + 20);
  114. $this->assertFalse($this->resource->isFresh(time() + 10), '->isFresh() returns false if a subdirectory is modified (e.g. a file gets deleted)');
  115. }
  116. /**
  117. * @covers Symfony\Component\Config\Resource\DirectoryResource::setFilterRegexList
  118. * @covers Symfony\Component\Config\Resource\DirectoryResource::getFilterRegexList
  119. */
  120. public function testSetFilterRegexList()
  121. {
  122. $regexes = array('#\.foo$#', '#\.xml$#');
  123. $this->resource->setFilterRegexList($regexes);
  124. $this->assertEquals($regexes, $this->resource->getFilterRegexList(), '->getFilterRegexList() returns the previously defined list of filter regexes');
  125. }
  126. /**
  127. * @covers Symfony\Component\Config\Resource\DirectoryResource::isFresh
  128. */
  129. public function testFilterRegexListNoMatch()
  130. {
  131. $regexes = array('#\.foo$#', '#\.xml$#');
  132. $this->resource->setFilterRegexList($regexes);
  133. touch($this->directory.'/new.bar', time() + 20);
  134. $this->assertTrue($this->resource->isFresh(time() + 10), '->isFresh() returns true if a new file not matching the filter regex is created');
  135. }
  136. /**
  137. * @covers Symfony\Component\Config\Resource\DirectoryResource::isFresh
  138. */
  139. public function testFilterRegexListMatch()
  140. {
  141. $regexes = array('#\.foo$#', '#\.xml$#');
  142. $this->resource->setFilterRegexList($regexes);
  143. touch($this->directory.'/new.xml', time() + 20);
  144. $this->assertFalse($this->resource->isFresh(time() + 10), '->isFresh() returns false if an new file matching the filter regex is created ');
  145. }
  146. }