diff options
author | Robin Appelman <icewind@owncloud.com> | 2012-03-02 18:42:04 +0100 |
---|---|---|
committer | Robin Appelman <icewind@owncloud.com> | 2012-03-02 18:42:57 +0100 |
commit | e8afe4f1588ad5697b8ef6627417dfeb4a6c0573 (patch) | |
tree | 594b6aa8ff154866c6371d30963c401cb11625d1 | |
parent | 4daedda35a3a8cffb283e47b37e66f5b0524cbd8 (diff) | |
download | nextcloud-server-e8afe4f1588ad5697b8ef6627417dfeb4a6c0573.tar.gz nextcloud-server-e8afe4f1588ad5697b8ef6627417dfeb4a6c0573.zip |
add search implementation to filestorage common
-rw-r--r-- | lib/filestorage/common.php | 21 | ||||
-rw-r--r-- | lib/filestorage/commontest.php | 3 | ||||
-rw-r--r-- | tests/lib/filestorage.php | 20 |
3 files changed, 37 insertions, 7 deletions
diff --git a/lib/filestorage/common.php b/lib/filestorage/common.php index fa14d7e99fd..fa0e7babf56 100644 --- a/lib/filestorage/common.php +++ b/lib/filestorage/common.php @@ -106,7 +106,9 @@ abstract class OC_Filestorage_Common extends OC_Filestorage { return $hash; } // abstract public function free_space($path); -// abstract public function search($query); + public function search($query){ + return $this->searchInDir($query); + } public function getLocalFile($path){ return $this->toTmpFile($path); } @@ -122,4 +124,21 @@ abstract class OC_Filestorage_Common extends OC_Filestorage { return $tmpFile; } // abstract public function touch($path, $mtime=null); + + protected function searchInDir($query,$dir=''){ + $files=array(); + $dh=$this->opendir($dir); + if($dh){ + while($item=readdir($dh)){ + if ($item == '.' || $item == '..') continue; + if(strstr(strtolower($item),strtolower($query))!==false){ + $files[]=$dir.'/'.$item; + } + if($this->is_dir($dir.'/'.$item)){ + $files=array_merge($files,$this->searchInDir($query,$dir.'/'.$item)); + } + } + } + return $files; + } } diff --git a/lib/filestorage/commontest.php b/lib/filestorage/commontest.php index 512e7c1b66d..1b01ff856a3 100644 --- a/lib/filestorage/commontest.php +++ b/lib/filestorage/commontest.php @@ -69,9 +69,6 @@ class OC_Filestorage_CommonTest extends OC_Filestorage_Common{ public function free_space($path){ return $this->storage->free_space($path); } - public function search($query){ - return $this->storage->search($query); - } public function touch($path, $mtime=null){ return $this->storage->touch($path,$mtime); } diff --git a/tests/lib/filestorage.php b/tests/lib/filestorage.php index 6296d7abf99..f8d4d9c4395 100644 --- a/tests/lib/filestorage.php +++ b/tests/lib/filestorage.php @@ -156,9 +156,10 @@ abstract class Test_FileStorage extends UnitTestCase { $this->assertTrue($mTime<=$mtimeEnd); $this->assertEqual($cTime,$originalCTime); - $this->instance->touch('/lorem.txt',100); - $mTime=$this->instance->filemtime('/lorem.txt'); - $this->assertEqual($mTime,100); + if($this->instance->touch('/lorem.txt',100)!==false){ + $mTime=$this->instance->filemtime('/lorem.txt'); + $this->assertEqual($mTime,100); + } $mtimeStart=time(); $fh=$this->instance->fopen('/lorem.txt','a'); @@ -171,4 +172,17 @@ abstract class Test_FileStorage extends UnitTestCase { $this->assertTrue($mtimeStart<=$mTime); $this->assertTrue($mTime<=$mtimeEnd); } + + public function testSearch(){ + $textFile=OC::$SERVERROOT.'/tests/data/lorem.txt'; + $this->instance->file_put_contents('/lorem.txt',file_get_contents($textFile,'r')); + $pngFile=OC::$SERVERROOT.'/tests/data/logo-wide.png'; + $this->instance->file_put_contents('/logo-wide.png',file_get_contents($pngFile,'r')); + $svgFile=OC::$SERVERROOT.'/tests/data/logo-wide.svg'; + $this->instance->file_put_contents('/logo-wide.svg',file_get_contents($svgFile,'r')); + $result=$this->instance->search('logo'); + $this->assertEqual(2,count($result)); + $this->assertNotIdentical(false,array_search('/logo-wide.svg',$result)); + $this->assertNotIdentical(false,array_search('/logo-wide.png',$result)); + } } |