2015-08-12 12:00:37 +03:00
|
|
|
<?php
|
|
|
|
/**
|
2016-07-21 17:49:16 +03:00
|
|
|
* @copyright Copyright (c) 2016, ownCloud, Inc.
|
|
|
|
*
|
2017-11-06 17:56:42 +03:00
|
|
|
* @author Morris Jobke <hey@morrisjobke.de>
|
2016-01-12 17:02:16 +03:00
|
|
|
* @author Robin McCorkell <robin@mccorkell.me.uk>
|
2015-08-12 12:00:37 +03:00
|
|
|
*
|
|
|
|
* @license AGPL-3.0
|
|
|
|
*
|
|
|
|
* This code is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License, version 3,
|
|
|
|
* as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program 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, version 3,
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OCA\Files_External\Tests\Auth;
|
|
|
|
|
2017-10-24 16:26:53 +03:00
|
|
|
use OCA\Files_External\Lib\Auth\AuthMechanism;
|
|
|
|
use OCA\Files_External\Lib\Backend\Backend;
|
|
|
|
use OCA\Files_External\Lib\StorageConfig;
|
|
|
|
|
2015-08-12 12:00:37 +03:00
|
|
|
class AuthMechanismTest extends \Test\TestCase {
|
|
|
|
|
|
|
|
public function testJsonSerialization() {
|
2017-10-24 16:26:53 +03:00
|
|
|
$mechanism = $this->getMockBuilder(AuthMechanism::class)
|
2015-08-12 12:00:37 +03:00
|
|
|
->setMethods(['jsonSerializeDefinition'])
|
|
|
|
->getMock();
|
|
|
|
$mechanism->expects($this->once())
|
|
|
|
->method('jsonSerializeDefinition')
|
|
|
|
->willReturn(['foo' => 'bar']);
|
|
|
|
|
|
|
|
$mechanism->setScheme('scheme');
|
|
|
|
|
|
|
|
$json = $mechanism->jsonSerialize();
|
|
|
|
$this->assertEquals('bar', $json['foo']);
|
|
|
|
$this->assertEquals('scheme', $json['scheme']);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function validateStorageProvider() {
|
|
|
|
return [
|
|
|
|
[true, 'scheme', true],
|
|
|
|
[false, 'scheme', false],
|
|
|
|
[true, 'foobar', true],
|
|
|
|
[false, 'barfoo', true],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @dataProvider validateStorageProvider
|
|
|
|
*/
|
|
|
|
public function testValidateStorage($expectedSuccess, $scheme, $definitionSuccess) {
|
2017-10-24 16:26:53 +03:00
|
|
|
$mechanism = $this->getMockBuilder(AuthMechanism::class)
|
2015-08-12 12:00:37 +03:00
|
|
|
->setMethods(['validateStorageDefinition'])
|
|
|
|
->getMock();
|
|
|
|
$mechanism->expects($this->atMost(1))
|
|
|
|
->method('validateStorageDefinition')
|
|
|
|
->willReturn($definitionSuccess);
|
|
|
|
|
|
|
|
$mechanism->setScheme($scheme);
|
|
|
|
|
2017-10-24 16:26:53 +03:00
|
|
|
$backend = $this->getMockBuilder(Backend::class)
|
2015-08-12 12:00:37 +03:00
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
$backend->expects($this->once())
|
|
|
|
->method('getAuthSchemes')
|
|
|
|
->willReturn(['scheme' => true, 'foobar' => true]);
|
|
|
|
|
2017-10-24 16:26:53 +03:00
|
|
|
$storageConfig = $this->getMockBuilder(StorageConfig::class)
|
2015-08-12 12:00:37 +03:00
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
$storageConfig->expects($this->once())
|
|
|
|
->method('getBackend')
|
|
|
|
->willReturn($backend);
|
|
|
|
|
|
|
|
$this->assertEquals($expectedSuccess, $mechanism->validateStorage($storageConfig));
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|