X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=tools%2Fscripts%2Fphpunit;h=2e682bc0db51253824050b4d71b2a6a467c760d8;hb=54744051dea726c2b1495f24fc1cf7ba7fa25e11;hp=fd28402746a7617d88f7d99411b5c490d80ebffa;hpb=db3034eba9b65bda5bfba6642679c7631746578b;p=civicrm-core.git diff --git a/tools/scripts/phpunit b/tools/scripts/phpunit index fd28402746..2e682bc0db 100755 --- a/tools/scripts/phpunit +++ b/tools/scripts/phpunit @@ -50,7 +50,7 @@ array_shift($argv); // Convert class names to file names $CIVICRM_UF = 'UnitTests'; foreach ($argv as $k => $v) { - if (preg_match('/^(CRM_|api_v3_|EnvTest|WebTest_|E2E_)/', $v)) { + if (preg_match('/^(CRM_|api_v3_|api_v4_|EnvTest|WebTest_|E2E_)/', $v)) { $argv[$k] = 'tests/phpunit/' . strtr($v, '_', '/') . '.php'; } elseif (preg_match('/^Civi\\\\/', $v)) { @@ -87,12 +87,20 @@ $cmd = passthru($cmd); function findPhp() { - if (defined('PHP_BINARY')) { - return PHP_BINARY; // php 5.4+ - } elseif (defined('PHP_BINDIR') && file_exists(PHP_BINDIR . '/php')) { - return PHP_BINDIR . '/php'; // php 5.3 - } else { - die("Failed to determine active PHP version."); + // The autodetect behavior here is a potential point of contention. These two cases are hard to reconcile: + // 1. `php` is actually a wrapper script which delegates to another PHP binary and + // passes options (such as INI's and PECL extensions). Subprocesses should use the wrapper script. + // Examples: bitnami, bknix + // 2. There are multiple PHP binaries (eg `php55`, `php70`). Subprocesses should use + // the final executable (regardless of its name). + // Example: using MAMP and adding 'ln -s /Application/MAMP/.../php7.1.2/bin/php ~/bin/php71` + // Since the test infra uses a wrapper script like (1), we use autodetect logic that works there. + // If you're in situation (2), then set an env-var or just skip on using `tools/scripts/phpunit`. + if (getenv('PHP')) { + return getenv('PHP'); + } + else { + return 'php'; } }