2012-02-12 17:06:32 +00:00
< ? php
/**
2012-10-11 17:30:27 +00:00
* ownCloud
*
* @ author Robin Appelman
* @ copyright 2012 Robin Appelman icewind @ owncloud . com
*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
* License as published by the Free Software Foundation ; either
* version 3 of the License , or any later version .
*
* This library is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU AFFERO GENERAL PUBLIC LICENSE for more details .
*
* You should have received a copy of the GNU Affero General Public
* License along with this library . If not , see < http :// www . gnu . org / licenses />.
*
*/
2012-02-12 17:06:32 +00:00
2012-09-22 12:51:15 +00:00
namespace Test\Files\Storage ;
2013-01-26 17:49:45 +00:00
abstract class Storage extends \PHPUnit_Framework_TestCase {
2012-02-12 17:06:32 +00:00
/**
2012-09-07 16:30:48 +00:00
* @ var \OC\Files\Storage\Storage instance
2012-02-12 17:06:32 +00:00
*/
protected $instance ;
2014-01-31 15:06:11 +00:00
protected $waitDelay = 0 ;
/**
* Sleep for the number of seconds specified in the
* $waitDelay attribute
*/
protected function wait () {
if ( $this -> waitDelay > 0 ) {
sleep ( $this -> waitDelay );
}
}
2012-02-12 17:06:32 +00:00
/**
* the root folder of the storage should always exist , be readable and be recognized as a directory
*/
2012-09-07 13:22:01 +00:00
public function testRoot () {
2012-10-11 17:30:27 +00:00
$this -> assertTrue ( $this -> instance -> file_exists ( '/' ), 'Root folder does not exist' );
$this -> assertTrue ( $this -> instance -> isReadable ( '/' ), 'Root folder is not readable' );
$this -> assertTrue ( $this -> instance -> is_dir ( '/' ), 'Root folder is not a directory' );
$this -> assertFalse ( $this -> instance -> is_file ( '/' ), 'Root folder is a file' );
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( 'dir' , $this -> instance -> filetype ( '/' ));
2012-10-11 17:30:27 +00:00
2012-10-11 20:54:39 +00:00
//without this, any further testing would be useless, not an actual requirement for filestorage though
2012-10-11 17:30:27 +00:00
$this -> assertTrue ( $this -> instance -> isUpdatable ( '/' ), 'Root folder is not writable' );
2012-02-12 17:06:32 +00:00
}
2012-10-11 17:30:27 +00:00
2013-12-03 13:35:53 +00:00
/**
* Check that the test () function works
*/
public function testTestFunction () {
$this -> assertTrue ( $this -> instance -> test ());
}
2013-10-31 10:55:58 +00:00
/**
* @ dataProvider directoryProvider
*/
public function testDirectories ( $directory ) {
$this -> assertFalse ( $this -> instance -> file_exists ( '/' . $directory ));
2012-10-11 17:30:27 +00:00
2013-10-31 10:55:58 +00:00
$this -> assertTrue ( $this -> instance -> mkdir ( '/' . $directory ));
2012-10-11 17:30:27 +00:00
2013-10-31 10:55:58 +00:00
$this -> assertTrue ( $this -> instance -> file_exists ( '/' . $directory ));
$this -> assertTrue ( $this -> instance -> is_dir ( '/' . $directory ));
$this -> assertFalse ( $this -> instance -> is_file ( '/' . $directory ));
$this -> assertEquals ( 'dir' , $this -> instance -> filetype ( '/' . $directory ));
$this -> assertEquals ( 0 , $this -> instance -> filesize ( '/' . $directory ));
$this -> assertTrue ( $this -> instance -> isReadable ( '/' . $directory ));
$this -> assertTrue ( $this -> instance -> isUpdatable ( '/' . $directory ));
2012-10-11 17:30:27 +00:00
$dh = $this -> instance -> opendir ( '/' );
$content = array ();
while ( $file = readdir ( $dh )) {
if ( $file != '.' and $file != '..' ) {
$content [] = $file ;
2012-02-13 09:25:45 +00:00
}
}
2013-10-31 10:55:58 +00:00
$this -> assertEquals ( array ( $directory ), $content );
2012-10-11 17:30:27 +00:00
2013-10-31 10:55:58 +00:00
$this -> assertFalse ( $this -> instance -> mkdir ( '/' . $directory )); //cant create existing folders
$this -> assertTrue ( $this -> instance -> rmdir ( '/' . $directory ));
2012-10-11 17:30:27 +00:00
2014-01-31 15:06:11 +00:00
$this -> wait ();
2013-10-31 10:55:58 +00:00
$this -> assertFalse ( $this -> instance -> file_exists ( '/' . $directory ));
2012-10-11 17:30:27 +00:00
2013-10-31 10:55:58 +00:00
$this -> assertFalse ( $this -> instance -> rmdir ( '/' . $directory )); //cant remove non existing folders
2012-10-11 17:30:27 +00:00
$dh = $this -> instance -> opendir ( '/' );
$content = array ();
while ( $file = readdir ( $dh )) {
if ( $file != '.' and $file != '..' ) {
$content [] = $file ;
2012-04-18 18:46:00 +00:00
}
}
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( array (), $content );
2012-02-13 09:25:45 +00:00
}
2012-02-12 17:06:32 +00:00
2013-10-31 10:55:58 +00:00
public function directoryProvider ()
{
return array (
array ( 'folder' ),
array ( ' folder' ),
array ( 'folder ' ),
2014-01-31 15:06:11 +00:00
array ( 'folder with space' ),
array ( 'spéciäl földer' ),
2013-10-31 10:55:58 +00:00
);
}
2012-02-12 17:06:32 +00:00
/**
* test the various uses of file_get_contents and file_put_contents
*/
2012-09-07 13:22:01 +00:00
public function testGetPutContents () {
2012-10-11 20:54:39 +00:00
$sourceFile = \OC :: $SERVERROOT . '/tests/data/lorem.txt' ;
2012-10-11 17:30:27 +00:00
$sourceText = file_get_contents ( $sourceFile );
2012-02-12 17:06:32 +00:00
//fill a file with string data
2012-10-11 17:30:27 +00:00
$this -> instance -> file_put_contents ( '/lorem.txt' , $sourceText );
2012-05-17 23:54:02 +00:00
$this -> assertFalse ( $this -> instance -> is_dir ( '/lorem.txt' ));
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( $sourceText , $this -> instance -> file_get_contents ( '/lorem.txt' ), 'data returned from file_get_contents is not equal to the source data' );
2012-02-12 17:06:32 +00:00
//empty the file
2012-10-11 17:30:27 +00:00
$this -> instance -> file_put_contents ( '/lorem.txt' , '' );
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( '' , $this -> instance -> file_get_contents ( '/lorem.txt' ), 'file not emptied' );
2012-02-12 17:06:32 +00:00
}
2012-10-11 17:30:27 +00:00
2012-02-13 09:25:45 +00:00
/**
* test various known mimetypes
*/
2012-09-07 13:22:01 +00:00
public function testMimeType () {
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( 'httpd/unix-directory' , $this -> instance -> getMimeType ( '/' ));
$this -> assertEquals ( false , $this -> instance -> getMimeType ( '/non/existing/file' ));
2012-10-11 17:30:27 +00:00
2012-10-11 20:54:39 +00:00
$textFile = \OC :: $SERVERROOT . '/tests/data/lorem.txt' ;
2012-10-11 17:30:27 +00:00
$this -> instance -> file_put_contents ( '/lorem.txt' , file_get_contents ( $textFile , 'r' ));
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( 'text/plain' , $this -> instance -> getMimeType ( '/lorem.txt' ));
2012-10-11 17:30:27 +00:00
2012-10-11 20:54:39 +00:00
$pngFile = \OC :: $SERVERROOT . '/tests/data/logo-wide.png' ;
2012-10-11 17:30:27 +00:00
$this -> instance -> file_put_contents ( '/logo-wide.png' , file_get_contents ( $pngFile , 'r' ));
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( 'image/png' , $this -> instance -> getMimeType ( '/logo-wide.png' ));
2012-10-11 17:30:27 +00:00
2012-10-11 20:54:39 +00:00
$svgFile = \OC :: $SERVERROOT . '/tests/data/logo-wide.svg' ;
2012-10-11 17:30:27 +00:00
$this -> instance -> file_put_contents ( '/logo-wide.svg' , file_get_contents ( $svgFile , 'r' ));
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( 'image/svg+xml' , $this -> instance -> getMimeType ( '/logo-wide.svg' ));
2012-02-13 09:25:45 +00:00
}
2012-10-11 17:30:27 +00:00
2012-09-07 13:22:01 +00:00
public function testCopyAndMove () {
2012-10-11 20:54:39 +00:00
$textFile = \OC :: $SERVERROOT . '/tests/data/lorem.txt' ;
2012-10-11 17:30:27 +00:00
$this -> instance -> file_put_contents ( '/source.txt' , file_get_contents ( $textFile ));
$this -> instance -> copy ( '/source.txt' , '/target.txt' );
2012-02-27 11:20:47 +00:00
$this -> assertTrue ( $this -> instance -> file_exists ( '/target.txt' ));
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( $this -> instance -> file_get_contents ( '/source.txt' ), $this -> instance -> file_get_contents ( '/target.txt' ));
2012-10-11 17:30:27 +00:00
$this -> instance -> rename ( '/source.txt' , '/target2.txt' );
2014-01-31 15:06:11 +00:00
$this -> wait ();
2012-02-27 11:20:47 +00:00
$this -> assertTrue ( $this -> instance -> file_exists ( '/target2.txt' ));
$this -> assertFalse ( $this -> instance -> file_exists ( '/source.txt' ));
2013-11-25 17:52:14 +00:00
$this -> assertEquals ( file_get_contents ( $textFile ), $this -> instance -> file_get_contents ( '/target2.txt' ));
// move to overwrite
2013-11-25 17:54:58 +00:00
$testContents = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' ;
$this -> instance -> file_put_contents ( '/target3.txt' , $testContents );
$this -> instance -> rename ( '/target2.txt' , '/target3.txt' );
$this -> assertTrue ( $this -> instance -> file_exists ( '/target3.txt' ));
2013-11-25 17:52:14 +00:00
$this -> assertFalse ( $this -> instance -> file_exists ( '/target2.txt' ));
2013-11-25 17:54:58 +00:00
$this -> assertEquals ( file_get_contents ( $textFile ), $this -> instance -> file_get_contents ( '/target3.txt' ));
2012-02-27 11:20:47 +00:00
}
2012-10-11 17:30:27 +00:00
2012-09-07 13:22:01 +00:00
public function testLocal () {
2012-10-11 20:54:39 +00:00
$textFile = \OC :: $SERVERROOT . '/tests/data/lorem.txt' ;
2012-10-11 17:30:27 +00:00
$this -> instance -> file_put_contents ( '/lorem.txt' , file_get_contents ( $textFile ));
$localFile = $this -> instance -> getLocalFile ( '/lorem.txt' );
2012-02-28 11:06:34 +00:00
$this -> assertTrue ( file_exists ( $localFile ));
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( file_get_contents ( $localFile ), file_get_contents ( $textFile ));
2012-10-11 17:30:27 +00:00
2012-08-19 00:30:33 +00:00
$this -> instance -> mkdir ( '/folder' );
2012-10-11 17:30:27 +00:00
$this -> instance -> file_put_contents ( '/folder/lorem.txt' , file_get_contents ( $textFile ));
$this -> instance -> file_put_contents ( '/folder/bar.txt' , 'asd' );
2012-08-19 00:30:33 +00:00
$this -> instance -> mkdir ( '/folder/recursive' );
2012-10-11 17:30:27 +00:00
$this -> instance -> file_put_contents ( '/folder/recursive/file.txt' , 'foo' );
$localFolder = $this -> instance -> getLocalFolder ( '/folder' );
2012-08-19 00:30:33 +00:00
$this -> assertTrue ( is_dir ( $localFolder ));
2013-02-06 22:36:38 +00:00
// test below require to use instance->getLocalFile because the physical storage might be different
$localFile = $this -> instance -> getLocalFile ( '/folder/lorem.txt' );
$this -> assertTrue ( file_exists ( $localFile ));
$this -> assertEquals ( file_get_contents ( $localFile ), file_get_contents ( $textFile ));
$localFile = $this -> instance -> getLocalFile ( '/folder/bar.txt' );
$this -> assertTrue ( file_exists ( $localFile ));
$this -> assertEquals ( file_get_contents ( $localFile ), 'asd' );
$localFile = $this -> instance -> getLocalFile ( '/folder/recursive/file.txt' );
$this -> assertTrue ( file_exists ( $localFile ));
$this -> assertEquals ( file_get_contents ( $localFile ), 'foo' );
2012-02-28 11:06:34 +00:00
}
2012-02-29 22:47:53 +00:00
2012-09-07 13:22:01 +00:00
public function testStat () {
2012-10-11 20:54:39 +00:00
$textFile = \OC :: $SERVERROOT . '/tests/data/lorem.txt' ;
2012-10-11 17:30:27 +00:00
$ctimeStart = time ();
$this -> instance -> file_put_contents ( '/lorem.txt' , file_get_contents ( $textFile ));
2012-08-15 15:55:54 +00:00
$this -> assertTrue ( $this -> instance -> isReadable ( '/lorem.txt' ));
2012-10-11 17:30:27 +00:00
$ctimeEnd = time ();
$mTime = $this -> instance -> filemtime ( '/lorem.txt' );
2013-07-08 13:03:55 +00:00
$this -> assertTrue ( $this -> instance -> hasUpdated ( '/lorem.txt' , $ctimeStart - 5 ));
$this -> assertTrue ( $this -> instance -> hasUpdated ( '/' , $ctimeStart - 5 ));
2012-10-11 17:30:27 +00:00
2013-11-14 17:39:39 +00:00
// check that ($ctimeStart - 5) <= $mTime <= ($ctimeEnd + 1)
$this -> assertGreaterThanOrEqual (( $ctimeStart - 5 ), $mTime );
$this -> assertLessThanOrEqual (( $ctimeEnd + 1 ), $mTime );
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( filesize ( $textFile ), $this -> instance -> filesize ( '/lorem.txt' ));
2012-10-11 17:30:27 +00:00
$stat = $this -> instance -> stat ( '/lorem.txt' );
2013-07-16 21:04:07 +00:00
//only size and mtime are required in the result
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( $stat [ 'size' ], $this -> instance -> filesize ( '/lorem.txt' ));
$this -> assertEquals ( $stat [ 'mtime' ], $mTime );
2012-10-11 17:30:27 +00:00
2013-07-16 21:07:35 +00:00
if ( $this -> instance -> touch ( '/lorem.txt' , 100 ) !== false ) {
2012-10-11 17:30:27 +00:00
$mTime = $this -> instance -> filemtime ( '/lorem.txt' );
2013-07-16 21:07:35 +00:00
$this -> assertEquals ( $mTime , 100 );
2012-03-02 17:42:04 +00:00
}
2012-10-06 11:45:46 +00:00
2012-10-11 17:30:27 +00:00
$mtimeStart = time ();
2012-06-15 14:43:24 +00:00
$this -> instance -> unlink ( '/lorem.txt' );
2013-07-08 13:03:55 +00:00
$this -> assertTrue ( $this -> instance -> hasUpdated ( '/' , $mtimeStart - 5 ));
2012-02-29 22:47:53 +00:00
}
2012-03-02 17:42:04 +00:00
2013-11-14 17:39:39 +00:00
public function testUnlink () {
$textFile = \OC :: $SERVERROOT . '/tests/data/lorem.txt' ;
$this -> instance -> file_put_contents ( '/lorem.txt' , file_get_contents ( $textFile ));
$this -> assertTrue ( $this -> instance -> file_exists ( '/lorem.txt' ));
$this -> assertTrue ( $this -> instance -> unlink ( '/lorem.txt' ));
2014-01-31 15:06:11 +00:00
$this -> wait ();
2013-11-14 17:39:39 +00:00
$this -> assertFalse ( $this -> instance -> file_exists ( '/lorem.txt' ));
}
2012-10-11 17:38:32 +00:00
public function testFOpen () {
2012-10-11 20:54:39 +00:00
$textFile = \OC :: $SERVERROOT . '/tests/data/lorem.txt' ;
2012-10-11 17:38:32 +00:00
$fh = @ $this -> instance -> fopen ( 'foo' , 'r' );
if ( $fh ) {
fclose ( $fh );
}
$this -> assertFalse ( $fh );
$this -> assertFalse ( $this -> instance -> file_exists ( 'foo' ));
$fh = $this -> instance -> fopen ( 'foo' , 'w' );
fwrite ( $fh , file_get_contents ( $textFile ));
fclose ( $fh );
$this -> assertTrue ( $this -> instance -> file_exists ( 'foo' ));
$fh = $this -> instance -> fopen ( 'foo' , 'r' );
$content = stream_get_contents ( $fh );
2013-01-24 15:47:17 +00:00
$this -> assertEquals ( file_get_contents ( $textFile ), $content );
2012-03-02 17:42:04 +00:00
}
2013-04-10 11:45:36 +00:00
2013-06-06 18:47:20 +00:00
public function testTouchCreateFile () {
2013-04-10 11:45:36 +00:00
$this -> assertFalse ( $this -> instance -> file_exists ( 'foo' ));
2013-11-26 11:53:03 +00:00
// returns true on success
$this -> assertTrue ( $this -> instance -> touch ( 'foo' ));
2013-04-10 11:45:36 +00:00
$this -> assertTrue ( $this -> instance -> file_exists ( 'foo' ));
}
2013-06-06 18:47:20 +00:00
public function testRecursiveRmdir () {
$this -> instance -> mkdir ( 'folder' );
$this -> instance -> mkdir ( 'folder/bar' );
2014-01-31 15:06:11 +00:00
$this -> wait ();
2013-06-06 18:47:20 +00:00
$this -> instance -> file_put_contents ( 'folder/asd.txt' , 'foobar' );
$this -> instance -> file_put_contents ( 'folder/bar/foo.txt' , 'asd' );
2013-11-29 11:58:57 +00:00
$this -> assertTrue ( $this -> instance -> rmdir ( 'folder' ));
2014-01-31 15:06:11 +00:00
$this -> wait ();
2013-11-29 11:58:57 +00:00
$this -> assertFalse ( $this -> instance -> file_exists ( 'folder/asd.txt' ));
$this -> assertFalse ( $this -> instance -> file_exists ( 'folder/bar/foo.txt' ));
$this -> assertFalse ( $this -> instance -> file_exists ( 'folder/bar' ));
$this -> assertFalse ( $this -> instance -> file_exists ( 'folder' ));
}
public function testRecursiveUnlink () {
$this -> instance -> mkdir ( 'folder' );
$this -> instance -> mkdir ( 'folder/bar' );
$this -> instance -> file_put_contents ( 'folder/asd.txt' , 'foobar' );
$this -> instance -> file_put_contents ( 'folder/bar/foo.txt' , 'asd' );
$this -> assertTrue ( $this -> instance -> unlink ( 'folder' ));
2014-01-31 15:06:11 +00:00
$this -> wait ();
2013-06-06 18:47:20 +00:00
$this -> assertFalse ( $this -> instance -> file_exists ( 'folder/asd.txt' ));
$this -> assertFalse ( $this -> instance -> file_exists ( 'folder/bar/foo.txt' ));
$this -> assertFalse ( $this -> instance -> file_exists ( 'folder/bar' ));
$this -> assertFalse ( $this -> instance -> file_exists ( 'folder' ));
}
2012-02-12 17:06:32 +00:00
}