summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorRobin Appelman <icewind@owncloud.com>2012-09-02 15:26:32 +0200
committerRobin Appelman <icewind@owncloud.com>2012-09-05 19:42:26 +0200
commit9f1c76beef44fb841e6a4137c409ccb941c9236b (patch)
treebd89d4cb18fbd07e0058a11cc93bb96c708361ab /tests
parentaa8cee1afa3e1bacf195610b75dbfd1103bf48c3 (diff)
downloadnextcloud-server-9f1c76beef44fb841e6a4137c409ccb941c9236b.tar.gz
nextcloud-server-9f1c76beef44fb841e6a4137c409ccb941c9236b.zip
fix running test cases in multiply app dirs
Diffstat (limited to 'tests')
-rw-r--r--tests/index.php20
1 files changed, 12 insertions, 8 deletions
diff --git a/tests/index.php b/tests/index.php
index 0be27ee3fd7..032689970fa 100644
--- a/tests/index.php
+++ b/tests/index.php
@@ -20,6 +20,8 @@
*
*/
+//to run only specific tests, use the test parameter to specify an app or 'lib'. e.g. http://localhost/owncloud/tests/?test=user_external
+
require_once '../lib/base.php';
require_once 'simpletest/unit_tester.php';
require_once 'simpletest/mock_objects.php';
@@ -49,7 +51,7 @@ if(OC::$CLI){
$testSuite=new TestSuite($testSuiteName);
//load core test cases
-loadTests(dirname(__FILE__), $testSuite, $test);
+loadTests(dirname(__FILE__), $testSuite, $test, 'lib');
//load app test cases
@@ -59,8 +61,9 @@ loadTests(dirname(__FILE__), $testSuite, $test);
$apps=OC_App::getEnabledApps();
foreach($apps as $app){
- if(is_dir(OC::$SERVERROOT.'/apps/'.$app.'/tests')){
- loadTests(OC::$SERVERROOT.'/apps/'.$app.'/tests', $testSuite, $test);
+ $testDir=OC_App::getAppPath($app).'/tests';
+ if(is_dir($testDir)){
+ loadTests($testDir, $testSuite, $test, $app);
}
}
@@ -70,15 +73,16 @@ if($testSuite->getSize()>0){
}
// helper below
-function loadTests($dir,$testSuite, $test){
+function loadTests($dir,$testSuite, $test, $app){
+ $root=($app=='lib')?OC::$SERVERROOT.'/tests/lib/':OC_App::getAppPath($app).'/tests/';
if($dh=opendir($dir)){
while($name=readdir($dh)){
if($name[0]!='.'){//no hidden files, '.' or '..'
$file=$dir.'/'.$name;
if(is_dir($file)){
- loadTests($file, $testSuite, $test);
+ loadTests($file, $testSuite, $test, $app);
}elseif(substr($file,-4)=='.php' and $file!=__FILE__){
- $name=getTestName($file);
+ $name=$app.'/'.getTestName($file,$root);
if($test===false or $test==$name or substr($name,0,strlen($test))==$test){
$extractor = new SimpleFileLoader();
$loadedSuite=$extractor->load($file);
@@ -91,8 +95,8 @@ function loadTests($dir,$testSuite, $test){
}
}
-function getTestName($file){
+function getTestName($file,$root){
// //TODO: get better test names
- $file=substr($file,strlen(OC::$SERVERROOT));
+ $file=substr($file,strlen($root));
return substr($file,0,-4);//strip .php
}