*
* @copyright Copyright (c) 2015, ownCloud, Inc.
* @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
*
*/
namespace Test;
use OC\CapabilitiesManager;
use OCP\AppFramework\QueryException;
use OCP\Capabilities\ICapability;
use OCP\Capabilities\IPublicCapability;
use Psr\Log\LoggerInterface;
class CapabilitiesManagerTest extends TestCase {
/** @var CapabilitiesManager */
private $manager;
/** @var LoggerInterface */
private $logger;
protected function setUp(): void {
parent::setUp();
$this->logger = $this->getMockBuilder(LoggerInterface::class)->getMock();
$this->manager = new CapabilitiesManager($this->logger);
}
/**
* Test no capabilities
*/
public function testNoCapabilities() {
$res = $this->manager->getCapabilities();
$this->assertEmpty($res);
}
/**
* Test a valid capabilitie
*/
public function testValidCapability() {
$this->manager->registerCapability(function () {
return new SimpleCapability();
});
$res = $this->manager->getCapabilities();
$this->assertEquals(['foo' => 1], $res);
}
/**
* Test a public capabilitie
*/
public function testPublicCapability() {
$this->manager->registerCapability(function () {
return new PublicSimpleCapability1();
});
$this->manager->registerCapability(function () {
return new SimpleCapability2();
});
$this->manager->registerCapability(function () {
return new SimpleCapability3();
});
$res = $this->manager->getCapabilities(true);
$this->assertEquals(['foo' => 1], $res);
}
/**
* Test that we need something that implents ICapability
*/
public function testNoICapability() {
$this->expectException(\InvalidArgumentException::class);
$this->expectExceptionMessage('The given Capability (Test\\NoCapability) does not implement the ICapability interface');
$this->manager->registerCapability(function () {
return new NoCapability();
});
$res = $this->manager->getCapabilities();
$this->assertEquals([], $res);
}
/**
* Test a bunch of merged Capabilities
*/
public function testMergedCapabilities() {
$this->manager->registerCapability(function () {
return new SimpleCapability();
});
$this->manager->registerCapability(function () {
return new SimpleCapability2();
});
$this->manager->registerCapability(function () {
return new SimpleCapability3();
});
$res = $this->manager->getCapabilities();
$expected = [
'foo' => 1,
'bar' => [
'x' => 1,
'y' => 2
]
];
$this->assertEquals($expected, $res);
}
/**
* Test deep identical capabilities
*/
public function testDeepIdenticalCapabilities() {
$this->manager->registerCapability(function () {
return new DeepCapability();
});
$this->manager->registerCapability(function () {
return new DeepCapability();
});
$res = $this->manager->getCapabilities();
$expected = [
'foo' => [
'bar' => [
'baz' => true
]
]
];
$this->assertEquals($expected, $res);
}
public function testInvalidCapability() {
$this->manager->registerCapability(function () {
throw new QueryException();
});
$this->logger->expects($this->once())
->method('error');
$res = $this->manager->getCapabilities();
$this->assertEquals([], $res);
}
}
class SimpleCapability implements ICapability {
public function getCapabilities() {
return [
'foo' => 1
];
}
}
class SimpleCapability2 implements ICapability {
public function getCapabilities() {
return [
'bar' => ['x' => 1]
];
}
}
class SimpleCapability3 implements ICapability {
public function getCapabilities() {
return [
'bar' => ['y' => 2]
];
}
}
class PublicSimpleCapability1 implements IPublicCapability {
public function getCapabilities() {
return [
'foo' => 1
];
}
}
class NoCapability {
public function getCapabilities() {
return [
'baz' => 'z'
];
}
}
class DeepCapability implements ICapability {
public function getCapabilities() {
return [
'foo' => [
'bar' => [
'baz' => true
]
]
];
}
}
ns-f50e11107c&id=9ef415042598ad978414f832b7bf52f20c67cce1'>root/ui/effect-puff.js
blob: ac3f90a64d242f315beac5df9bfd041c7cb53bee (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
/*!
* jQuery UI Effects Puff @VERSION
* http://jqueryui.com
*
* Copyright jQuery Foundation and other contributors
* Released under the MIT license.
* http://jquery.org/license
*/
//>>label: Puff Effect
//>>group: Effects
//>>description: Creates a puff effect by scaling the element up and hiding it at the same time.
//>>docs: http://api.jqueryui.com/puff-effect/
//>>demos: http://jqueryui.com/effect/
( function( factory ) {
if ( typeof define === "function" && define.amd ) {
// AMD. Register as an anonymous module.
define( [
"jquery",
"./effect",
"./effect-scale"
], factory );
} else {
// Browser globals
factory( jQuery );
}
}( function( $ ) {
return $.effects.define( "puff", "hide", function( options, done ) {
var newOptions = $.extend( true, {}, options, {
fade: true,
percent: parseInt( options.percent, 10 ) || 150
} );
$.effects.effect.scale.call( this, newOptions, done );
} );
} ) );
|