a00dd2d5d6
This reverts commit b66d38ecae
.
224 lines
8.8 KiB
PHP
224 lines
8.8 KiB
PHP
<?php
|
|
/**
|
|
* Copyright (c) 2012 Sam Tuke <samtuke@owncloud.com>,
|
|
* and Robin Appelman <icewind@owncloud.com>
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
* later.
|
|
* See the COPYING-README file.
|
|
*/
|
|
|
|
require_once "PHPUnit/Framework/TestCase.php";
|
|
require_once realpath( dirname(__FILE__).'/../../../lib/base.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/Generator.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/MockInterface.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/Mock.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/Container.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/Configuration.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/CompositeExpectation.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/ExpectationDirector.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/Expectation.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/Exception.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/CountValidator/CountValidatorAbstract.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/CountValidator/Exception.php' );
|
|
require_once realpath( dirname(__FILE__).'/../../../3rdparty/mockery/Mockery/CountValidator/Exact.php' );
|
|
|
|
use \Mockery as m;
|
|
use OCA\Encryption;
|
|
|
|
class Test_Util extends \PHPUnit_Framework_TestCase {
|
|
|
|
public function setUp() {
|
|
|
|
$this->proxy = new Encryption\Proxy();
|
|
|
|
$this->tmpFileName = "tmpFile-".time();
|
|
|
|
$this->privateKey = file_get_contents( realpath( dirname(__FILE__).'/data/admin.public.key' ) );
|
|
$this->publicKey = file_get_contents( realpath( dirname(__FILE__).'/data/admin.private.key' ) );
|
|
$this->encDataShort = file_get_contents( realpath( dirname(__FILE__).'/data/yoga-manchester-enc' ) );
|
|
$this->encDataShortKey = file_get_contents( realpath( dirname(__FILE__).'/data/yoga-manchester.key' ) );
|
|
|
|
$this->dataShort = file_get_contents( realpath( dirname(__FILE__).'/data/yoga-manchester' ) );
|
|
$this->dataLong = file_get_contents( realpath( dirname(__FILE__).'/../lib/crypt.php' ) );
|
|
$this->longDataPath = realpath( dirname(__FILE__).'/../lib/crypt.php' );
|
|
|
|
$this->data1 = file_get_contents( realpath( dirname(__FILE__).'/../../../data/admin/files/enc-test.txt' ) );
|
|
|
|
\OC_FileProxy::$enabled = false;
|
|
$this->Encdata1 = file_get_contents( realpath( dirname(__FILE__).'/../../../data/admin/files/enc-test.txt' ) );
|
|
\OC_FileProxy::$enabled = true;
|
|
|
|
$this->userId = 'admin';
|
|
$this->pass = 'admin';
|
|
|
|
$this->session = new Encryption\Session();
|
|
|
|
$this->session->setPrivateKey(
|
|
'-----BEGIN PRIVATE KEY-----
|
|
MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQDiH3EA4EpFA7Fx
|
|
s2dyyfL5jwXeYXrTqQJ6DqKgGn8VsbT3eu8R9KzM2XitVwZe8c8L52DvJ06o5vg0
|
|
GqPYxilFdOFJe/ggac5Tq8UmJiZS4EqYEMwxBIfIyWTxeGV06/0HOwnVAkqHMcBz
|
|
64qldtgi5O8kZMEM2/gKBgU0kMLJzM+8oEWhL1+gsUWQhxd8cKLXypS6iWgqFJrz
|
|
f/X0hJsJR+gyYxNpahtnjzd/LxLAETrOMsl2tue+BAxmjbAM0aG0NEM0div+b59s
|
|
2uz/iWbxImp5pOdYVKcVW89D4XBMyGegR40trV2VwiuX1blKCfdjMsJhiaL9pymp
|
|
ug1wzyQFAgMBAAECggEAK6c+PZkPPXuVCgpEcliiW6NM0r2m5K3AGKgypQ34csu3
|
|
z/8foCvIIFPrhCtEw5eTDQ1CHWlNOjY8vHJYJ0U6Onpx86nHIRrMBkMm8FJ1G5LJ
|
|
U8oKYXwqaozWu/cuPwA//OFc6I5krOzh5n8WaRMkbrgbor8AtebRX74By0AXGrXe
|
|
cswJI7zR96oFn4Dm7Pgvpg5Zhk1vFJ+w6QtH+4DDJ6PBvlZsRkGxYBLGVd/3qhAI
|
|
sBAyjFlSzuP4eCRhHOhHC/e4gmAH9evFVXB88jFyRZm3K+jQ5W5CwrVRBCV2lph6
|
|
2B6P7CBJN+IjGKMhy+75y13UvvKPv9IwH8Fzl2x1gQKBgQD8qQOr7a6KhSj16wQE
|
|
jim2xqt9gQ2jH5No405NrKs/PFQQZnzD4YseQsiK//NUjOJiUhaT+L5jhIpzINHt
|
|
RJpt3bGkEZmLyjdjgTpB3GwZdXa28DNK9VdXZ19qIl/ZH0qAjKmJCRahUDASMnVi
|
|
M4Pkk9yx9ZIKkri4TcuMWqc0DQKBgQDlHKBTITZq/arYPD6Nl3NsoOdqVRqJrGay
|
|
0TjXAVbBXe46+z5lnMsqwXb79nx14hdmSEsZULrw/3f+MnQbdjMTYLFP24visZg9
|
|
MN8vAiALiiiR1a+Crz+DTA1Q8sGOMVCMqMDmD7QBys3ZuWxuapm0txAiIYUtsjJZ
|
|
XN76T4nZ2QKBgQCHaT3igzwsWTmesxowJtEMeGWomeXpKx8h89EfqA8PkRGsyIDN
|
|
qq+YxEoe1RZgljEuaLhZDdNcGsjo8woPk9kAUPTH7fbRCMuutK+4ZJ469s1tNkcH
|
|
QX5SBcEJbOrZvv967ehe3VQXmJZq6kgnHVzuwKBjcC2ZJRGDFY6l5l/+cQKBgCqh
|
|
+Adf/8NK7paMJ0urqfPFwSodKfICXZ3apswDWMRkmSbqh4La+Uc8dsqN5Dz/VEFZ
|
|
JHhSeGbN8uMfOlG93eU2MehdPxtw1pZUWMNjjtj23XO9ooob2CKzbSrp8TBnZsi1
|
|
widNNr66oTFpeo7VUUK6acsgF6sYJJxSVr+XO1yJAoGAEhvitq8shNKcEY0xCipS
|
|
k1kbgyS7KKB7opVxI5+ChEqyUDijS3Y9FZixrRIWE6i2uGu86UG+v2lbKvSbM4Qm
|
|
xvbOcX9OVMnlRb7n8woOP10UMY+ZE2x+YEUXQTLtPYq7F66e1OfxltstMxLQA+3d
|
|
Y1d5piFV8PXK3Fg2F+Cj5qg=
|
|
-----END PRIVATE KEY-----
|
|
'
|
|
, $this->userId
|
|
);
|
|
|
|
\OC_User::setUserId( $this->userId );
|
|
|
|
}
|
|
|
|
public function testpreFile_get_contents() {
|
|
|
|
// This won't work for now because mocking of the static keymanager class isn't working :(
|
|
|
|
// $mock = m::mock( 'alias:OCA\Encryption\Keymanager' );
|
|
//
|
|
// $mock->shouldReceive( 'getFileKey' )->times(2)->andReturn( $this->encDataShort );
|
|
//
|
|
// $encrypted = $this->proxy->postFile_get_contents( 'data/'.$this->tmpFileName, $this->encDataShortKey );
|
|
//
|
|
// $this->assertNotEquals( $this->dataShort, $encrypted );
|
|
//
|
|
// var_dump($encrypted);
|
|
|
|
$decrypted = $this->proxy->postFile_get_contents( 'data/admin/files/enc-test.txt', $this->data1 );
|
|
|
|
var_dump($decrypted);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// class Test_CryptProxy extends UnitTestCase {
|
|
// private $oldConfig;
|
|
// private $oldKey;
|
|
//
|
|
// public function setUp(){
|
|
// $user=OC_User::getUser();
|
|
//
|
|
// $this->oldConfig=OCP\Config::getAppValue('files_encryption','enable_encryption','true');
|
|
// OCP\Config::setAppValue('files_encryption','enable_encryption','true');
|
|
// $this->oldKey=isset($_SESSION['privateKey'])?$_SESSION['privateKey']:null;
|
|
//
|
|
//
|
|
// //set testing key
|
|
// $_SESSION['privateKey']=md5(time());
|
|
//
|
|
// //clear all proxies and hooks so we can do clean testing
|
|
// OC_FileProxy::clearProxies();
|
|
// OC_Hook::clear('OC_Filesystem');
|
|
//
|
|
// //enable only the encryption hook
|
|
// OC_FileProxy::register(new OC_FileProxy_Encryption());
|
|
//
|
|
// //set up temporary storage
|
|
// OC_Filesystem::clearMounts();
|
|
// OC_Filesystem::mount('OC_Filestorage_Temporary',array(),'/');
|
|
//
|
|
// OC_Filesystem::init('/'.$user.'/files');
|
|
//
|
|
// //set up the users home folder in the temp storage
|
|
// $rootView=new OC_FilesystemView('');
|
|
// $rootView->mkdir('/'.$user);
|
|
// $rootView->mkdir('/'.$user.'/files');
|
|
// }
|
|
//
|
|
// public function tearDown(){
|
|
// OCP\Config::setAppValue('files_encryption','enable_encryption',$this->oldConfig);
|
|
// if(!is_null($this->oldKey)){
|
|
// $_SESSION['privateKey']=$this->oldKey;
|
|
// }
|
|
// }
|
|
//
|
|
// public function testSimple(){
|
|
// $file=OC::$SERVERROOT.'/3rdparty/MDB2.php';
|
|
// $original=file_get_contents($file);
|
|
//
|
|
// OC_Filesystem::file_put_contents('/file',$original);
|
|
//
|
|
// OC_FileProxy::$enabled=false;
|
|
// $stored=OC_Filesystem::file_get_contents('/file');
|
|
// OC_FileProxy::$enabled=true;
|
|
//
|
|
// $fromFile=OC_Filesystem::file_get_contents('/file');
|
|
// $this->assertNotEqual($original,$stored);
|
|
// $this->assertEqual(strlen($original),strlen($fromFile));
|
|
// $this->assertEqual($original,$fromFile);
|
|
//
|
|
// }
|
|
//
|
|
// public function testView(){
|
|
// $file=OC::$SERVERROOT.'/3rdparty/MDB2.php';
|
|
// $original=file_get_contents($file);
|
|
//
|
|
// $rootView=new OC_FilesystemView('');
|
|
// $view=new OC_FilesystemView('/'.OC_User::getUser());
|
|
// $userDir='/'.OC_User::getUser().'/files';
|
|
//
|
|
// $rootView->file_put_contents($userDir.'/file',$original);
|
|
//
|
|
// OC_FileProxy::$enabled=false;
|
|
// $stored=$rootView->file_get_contents($userDir.'/file');
|
|
// OC_FileProxy::$enabled=true;
|
|
//
|
|
// $this->assertNotEqual($original,$stored);
|
|
// $fromFile=$rootView->file_get_contents($userDir.'/file');
|
|
// $this->assertEqual($original,$fromFile);
|
|
//
|
|
// $fromFile=$view->file_get_contents('files/file');
|
|
// $this->assertEqual($original,$fromFile);
|
|
// }
|
|
//
|
|
// public function testBinary(){
|
|
// $file=__DIR__.'/binary';
|
|
// $original=file_get_contents($file);
|
|
//
|
|
// OC_Filesystem::file_put_contents('/file',$original);
|
|
//
|
|
// OC_FileProxy::$enabled=false;
|
|
// $stored=OC_Filesystem::file_get_contents('/file');
|
|
// OC_FileProxy::$enabled=true;
|
|
//
|
|
// $fromFile=OC_Filesystem::file_get_contents('/file');
|
|
// $this->assertNotEqual($original,$stored);
|
|
// $this->assertEqual(strlen($original),strlen($fromFile));
|
|
// $this->assertEqual($original,$fromFile);
|
|
//
|
|
// $file=__DIR__.'/zeros';
|
|
// $original=file_get_contents($file);
|
|
//
|
|
// OC_Filesystem::file_put_contents('/file',$original);
|
|
//
|
|
// OC_FileProxy::$enabled=false;
|
|
// $stored=OC_Filesystem::file_get_contents('/file');
|
|
// OC_FileProxy::$enabled=true;
|
|
//
|
|
// $fromFile=OC_Filesystem::file_get_contents('/file');
|
|
// $this->assertNotEqual($original,$stored);
|
|
// $this->assertEqual(strlen($original),strlen($fromFile));
|
|
// }
|
|
// }
|