123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- <?php namespace Laravel\CLI\Tasks\Test;
- use Laravel\File;
- use Laravel\Bundle;
- use Laravel\Request;
- use Laravel\CLI\Tasks\Task;
- class Runner extends Task {
- /**
- * Run all of the unit tests for the application.
- *
- * @return void
- */
- public function run($bundles = array())
- {
- if (count($bundles) == 0) $bundles = array(DEFAULT_BUNDLE);
- $this->bundle($bundles);
- }
- /**
- * Run the tests for the Laravel framework.
- *
- * @return void
- */
- public function core()
- {
- if ( ! is_dir(path('bundle').'laravel-tests'))
- {
- throw new \Exception("The bundle [laravel-tests] has not been installed!");
- }
- // When testing the Laravel core, we will just stub the path directly
- // so the test bundle is not required to be registered in the bundle
- // configuration, as it is kind of a unique bundle.
- $this->stub(path('bundle').'laravel-tests/cases');
- $path = path('bundle').'laravel-tests/';
- $this->test();
- }
- /**
- * Run the tests for a given bundle.
- *
- * @param array $bundles
- * @return void
- */
- public function bundle($bundles = array())
- {
- if (count($bundles) == 0)
- {
- $bundles = Bundle::names();
- }
- foreach ($bundles as $bundle)
- {
- // To run PHPUnit for the application, bundles, and the framework
- // from one task, we'll dynamically stub PHPUnit.xml files via
- // the task and point the test suite to the correct directory
- // based on what was requested.
- if (is_dir($path = Bundle::path($bundle).'tests'))
- {
- $this->stub($path);
- $this->test();
- }
- }
- }
- /**
- * Run PHPUnit with the temporary XML configuration.
- *
- * @return void
- */
- protected function test()
- {
- // We'll simply fire off PHPUnit with the configuration switch
- // pointing to our temporary configuration file. This allows
- // us to flexibly run tests for any setup.
- $path = path('base').'phpunit.xml';
-
- // fix the spaced directories problem when using the command line
- // strings with spaces inside should be wrapped in quotes.
- $path = escapeshellarg($path);
- passthru('phpunit --configuration '.$path);
- @unlink($path);
- }
- /**
- * Write a stub phpunit.xml file to the base directory.
- *
- * @param string $directory
- * @return void
- */
- protected function stub($directory)
- {
- $path = path('sys').'cli/tasks/test/';
- $stub = File::get($path.'stub.xml');
- // The PHPUnit bootstrap file contains several items that are swapped
- // at test time. This allows us to point PHPUnit at a few different
- // locations depending on what the developer wants to test.
- foreach (array('bootstrap', 'directory') as $item)
- {
- $stub = $this->{"swap_{$item}"}($stub, $path, $directory);
- }
- File::put(path('base').'phpunit.xml', $stub);
- }
- /**
- * Swap the bootstrap file in the stub.
- *
- * @param string $stub
- * @param string $path
- * @param string $directory
- * @return string
- */
- protected function swap_bootstrap($stub, $path, $directory)
- {
- return str_replace('{{bootstrap}}', $path.'phpunit.php', $stub);
- }
- /**
- * Swap the directory in the stub.
- *
- * @param string $stub
- * @param string $path
- * @param string $directory
- * @return string
- */
- protected function swap_directory($stub, $path, $directory)
- {
- return str_replace('{{directory}}', $directory, $stub);
- }
- }
|