XdebugHandlerTest.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. <?php
  2. /*
  3. * This file is part of Composer.
  4. *
  5. * (c) Nils Adermann <naderman@naderman.de>
  6. * Jordi Boggiano <j.boggiano@seld.be>
  7. *
  8. * For the full copyright and license information, please view the LICENSE
  9. * file that was distributed with this source code.
  10. */
  11. namespace Composer\Test;
  12. use Composer\Test\Mock\XdebugHandlerMock;
  13. /**
  14. * @author John Stevenson <john-stevenson@blueyonder.co.uk>
  15. *
  16. * We use PHP_BINARY which only became available in PHP 5.4 *
  17. * @requires PHP 5.4
  18. */
  19. class XdebugHandlerTest extends \PHPUnit_Framework_TestCase
  20. {
  21. public static $envAllow;
  22. public static $envIniScanDir;
  23. public function testRestartWhenLoaded()
  24. {
  25. $loaded = true;
  26. $xdebug = new XdebugHandlerMock($loaded);
  27. $xdebug->check();
  28. $this->assertTrue($xdebug->restarted);
  29. }
  30. public function testNoRestartWhenNotLoaded()
  31. {
  32. $loaded = false;
  33. $xdebug = new XdebugHandlerMock($loaded);
  34. $xdebug->check();
  35. $this->assertFalse($xdebug->restarted);
  36. }
  37. public function testNoRestartWhenLoadedAndAllowed()
  38. {
  39. $loaded = true;
  40. putenv(XdebugHandlerMock::ENV_ALLOW.'=1');
  41. $xdebug = new XdebugHandlerMock($loaded);
  42. $xdebug->check();
  43. $this->assertFalse($xdebug->restarted);
  44. }
  45. public function testEnvAllow()
  46. {
  47. $loaded = true;
  48. $xdebug = new XdebugHandlerMock($loaded);
  49. $xdebug->check();
  50. $expected = XdebugHandlerMock::RESTART_ID;
  51. $this->assertEquals($expected, getenv(XdebugHandlerMock::ENV_ALLOW));
  52. // Mimic restart
  53. $xdebug = new XdebugHandlerMock($loaded);
  54. $xdebug->check();
  55. $this->assertFalse($xdebug->restarted);
  56. $this->assertFalse(getenv(XdebugHandlerMock::ENV_ALLOW));
  57. }
  58. public function testEnvAllowWithScanDir()
  59. {
  60. $loaded = true;
  61. $dir = '/some/where';
  62. putenv('PHP_INI_SCAN_DIR='.$dir);
  63. $xdebug = new XdebugHandlerMock($loaded);
  64. $xdebug->check();
  65. $expected = XdebugHandlerMock::RESTART_ID.'|'.$dir;
  66. $this->assertEquals($expected, getenv(XdebugHandlerMock::ENV_ALLOW));
  67. // Mimic setting scan dir and restart
  68. putenv('PHP_INI_SCAN_DIR=');
  69. $xdebug = new XdebugHandlerMock($loaded);
  70. $xdebug->check();
  71. $this->assertEquals($dir, getenv('PHP_INI_SCAN_DIR'));
  72. }
  73. public function testEnvAllowWithEmptyScanDir()
  74. {
  75. $loaded = true;
  76. putenv('PHP_INI_SCAN_DIR=');
  77. $xdebug = new XdebugHandlerMock($loaded);
  78. $xdebug->check();
  79. $expected = XdebugHandlerMock::RESTART_ID.'|';
  80. $this->assertEquals($expected, getenv(XdebugHandlerMock::ENV_ALLOW));
  81. // Unset scan dir and mimic restart
  82. putenv('PHP_INI_SCAN_DIR');
  83. $xdebug = new XdebugHandlerMock($loaded);
  84. $xdebug->check();
  85. $this->assertEquals('', getenv('PHP_INI_SCAN_DIR'));
  86. }
  87. public static function setUpBeforeClass()
  88. {
  89. self::$envAllow = getenv(XdebugHandlerMock::ENV_ALLOW);
  90. self::$envIniScanDir = getenv('PHP_INI_SCAN_DIR');
  91. }
  92. public static function tearDownAfterClass()
  93. {
  94. if (false !== self::$envAllow) {
  95. putenv(XdebugHandlerMock::ENV_ALLOW.'='.self::$envAllow);
  96. } else {
  97. putenv(XdebugHandlerMock::ENV_ALLOW);
  98. }
  99. if (false !== self::$envIniScanDir) {
  100. putenv('PHP_INI_SCAN_DIR='.self::$envIniScanDir);
  101. } else {
  102. putenv('PHP_INI_SCAN_DIR');
  103. }
  104. }
  105. protected function setUp()
  106. {
  107. putenv(XdebugHandlerMock::ENV_ALLOW);
  108. putenv('PHP_INI_SCAN_DIR');
  109. }
  110. }