diff options
author | Thomas Müller <thomas.mueller@tmit.eu> | 2013-10-14 21:33:23 +0200 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2013-10-14 21:33:23 +0200 |
commit | 6df5c7ebd533f0c499197c83e04c4edc786db192 (patch) | |
tree | fa189c20fbeedd69aeb1032644d3b600a0b1e72c | |
parent | c97b52090e2b917b29d19d5973bfe2784feaf9b4 (diff) | |
download | nextcloud-server-6df5c7ebd533f0c499197c83e04c4edc786db192.tar.gz nextcloud-server-6df5c7ebd533f0c499197c83e04c4edc786db192.zip |
streamCopy() should return proper structure.
Callers of streamCopy() expect an array to be returned containing count and result.
-rw-r--r-- | lib/private/helper.php | 4 | ||||
-rw-r--r-- | tests/lib/helper.php | 34 |
2 files changed, 36 insertions, 2 deletions
diff --git a/lib/private/helper.php b/lib/private/helper.php index a34640d8e36..1236e748256 100644 --- a/lib/private/helper.php +++ b/lib/private/helper.php @@ -509,11 +509,11 @@ class OC_Helper { * * @param resource $source * @param resource $target - * @return int the number of bytes copied + * @return array the number of bytes copied and result */ public static function streamCopy($source, $target) { if (!$source or !$target) { - return false; + return array(0, false); } $result = true; $count = 0; diff --git a/tests/lib/helper.php b/tests/lib/helper.php index b4d896e5196..babafab52c0 100644 --- a/tests/lib/helper.php +++ b/tests/lib/helper.php @@ -208,4 +208,38 @@ class Test_Helper extends PHPUnit_Framework_TestCase { ->will($this->returnValue(true)); // filename(1) (2) (3).ext exists $this->assertEquals('dir/filename(1) (2) (4).ext', OC_Helper::buildNotExistingFileNameForView('dir', 'filename(1) (2) (3).ext', $viewMock)); } + + /** + * @dataProvider streamCopyDataProvider + */ + public function testStreamCopy($expectedCount, $expectedResult, $source, $target) { + + if (is_string($source)) { + $source = fopen($source, 'r'); + } + if (is_string($target)) { + $target = fopen($target, 'w'); + } + + list($count, $result) = \OC_Helper::streamCopy($source, $target); + + if (is_resource($source)) { + fclose($source); + } + if (is_resource($target)) { + fclose($target); + } + + $this->assertSame($expectedCount, $count); + $this->assertSame($expectedResult, $result); + } + + + function streamCopyDataProvider() { + return array( + array(0, false, false, false), + array(0, false, \OC::$SERVERROOT . '/tests/data/lorem.txt', false), + array(446, true, \OC::$SERVERROOT . '/tests/data/lorem.txt', \OC::$SERVERROOT . '/tests/data/lorem-copy.txt'), + ); + } } |