From 48fe85d9bd7fc6a82f54d23befe06c2457b590bc Mon Sep 17 00:00:00 2001 From: Robin Appelman Date: Fri, 2 Mar 2012 18:42:23 +0100 Subject: add streamwrapper that provides a callback on stream close --- tests/lib/streamwrappers.php | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) (limited to 'tests/lib') diff --git a/tests/lib/streamwrappers.php b/tests/lib/streamwrappers.php index c4784a62976..17a92c6658c 100644 --- a/tests/lib/streamwrappers.php +++ b/tests/lib/streamwrappers.php @@ -44,4 +44,35 @@ class Test_StreamWrappers extends UnitTestCase { clearstatcache(); $this->assertFalse(file_exists($staticFile)); } + + public function testCloseStream(){ + //ensure all basic stream stuff works + $sourceFile=OC::$SERVERROOT.'/tests/data/lorem.txt'; + $tmpFile=OC_Helper::TmpFile('.txt'); + $file='close://'.$tmpFile; + $this->assertTrue(file_exists($file)); + file_put_contents($file,file_get_contents($sourceFile)); + $this->assertEqual(file_get_contents($sourceFile),file_get_contents($file)); + unlink($file); + clearstatcache(); + $this->assertFalse(file_exists($file)); + + //test callback + $tmpFile=OC_Helper::TmpFile('.txt'); + $file='close://'.$tmpFile; + OC_CloseStreamWrapper::$callBacks[$tmpFile]=array('Test_StreamWrappers','closeCallBack'); + $fh=fopen($file,'w'); + fwrite($fh,'asd'); + try{ + fclose($fh); + $this->fail('Expected exception'); + }catch(Exception $e){ + $path=$e->getMessage(); + $this->assertEqual($path,$tmpFile); + } + } + + public static function closeCallBack($path){ + throw new Exception($path); + } } \ No newline at end of file -- cgit v1.2.3