silverstripe-framework/tests/PhpSyntaxTest.php

53 lines
1.6 KiB
PHP
Raw Permalink Normal View History

<?php
/**
* @package framework
* @subpackage tests
2014-08-15 18:53:05 +12:00
*
* @group sanitychecks
2014-08-15 18:53:05 +12:00
*
* Test the syntax of the PHP files with various settings
*/
class PhpSyntaxTest extends SapphireTest {
public function setUp() {
parent::setUp();
$this->markTestSkipped('This needs to be written to include only core php files, not test/thirdparty files');
}
2014-08-15 18:53:05 +12:00
public function testShortTagsOffWillWork() {
// Ignore this test completely if running the test suite on windows
// TODO: Make it work on all platforms, by building an alternative to find | grep.
$returnCode = 0;
$output = array();
exec("which find && which grep && which php", $output, $returnCode);
if($returnCode != 0) return;
$settingTests = array('short_open_tag=Off','short_open_tag=On -d asp_tags=On');
2014-08-15 18:53:05 +12:00
$files = $this->getAllFiles('php');
$files[] = FRAMEWORK_PATH.'/dev/install/config-form.html';
2014-08-15 18:53:05 +12:00
foreach($files as $i => $file) {
$CLI_file = escapeshellarg($file);
foreach($settingTests as $settingTest) {
$returnCode = 0;
$output = array();
exec("php -l -d $settingTest $CLI_file", $output, $returnCode);
2014-08-15 18:53:05 +12:00
$hasErrors = ($returnCode != 0
&& strpos('No syntax errors detected', implode("\n", $output)) === FALSE);
$this->assertFalse($hasErrors, "Syntax error parsing $CLI_file with setting $settingTest:\n"
. implode("\n", $output) . " (Returned: {$returnCode})");
}
}
}
2014-08-15 18:53:05 +12:00
public function getAllFiles($ext = 'php') {
// TODO: Unix only
$cmd = sprintf(
2014-08-15 18:53:05 +12:00
'find %s | grep %s',
BASE_PATH,
escapeshellarg("\.$ext\$")
);
return explode("\n", trim(`$cmd`));
}
}