diff options
author | Joas Schilling <nickvergessen@owncloud.com> | 2016-01-18 09:53:25 +0100 |
---|---|---|
committer | Joas Schilling <nickvergessen@owncloud.com> | 2016-01-26 14:02:32 +0100 |
commit | 70396581eb4c33b380962d4589ce183f01dfc090 (patch) | |
tree | e44d93cdcea7080d858316ca8126ce95f49b782c /tests | |
parent | fe411788b7ee45e2da551fd20aded030b762eecc (diff) | |
download | nextcloud-server-70396581eb4c33b380962d4589ce183f01dfc090.tar.gz nextcloud-server-70396581eb4c33b380962d4589ce183f01dfc090.zip |
Add tests for findLanguage()
Diffstat (limited to 'tests')
-rw-r--r-- | tests/lib/l10n/factorytest.php | 99 | ||||
-rw-r--r-- | tests/lib/testcase.php | 40 |
2 files changed, 133 insertions, 6 deletions
diff --git a/tests/lib/l10n/factorytest.php b/tests/lib/l10n/factorytest.php index 3af1627159a..1cdc094043b 100644 --- a/tests/lib/l10n/factorytest.php +++ b/tests/lib/l10n/factorytest.php @@ -13,16 +13,27 @@ use OC\L10N\Factory; use Test\TestCase; /** - * Class Test_L10n + * Class FactoryTest + * + * @package Test\L10N * @group DB */ class FactoryTest extends TestCase { + + /** @var \OCP\IConfig|\PHPUnit_Framework_MockObject_MockObject */ + protected $config; + /** @var \OCP\IRequest|\PHPUnit_Framework_MockObject_MockObject */ protected $request; public function setUp() { parent::setUp(); + /** @var \OCP\IConfig $request */ + $this->config = $this->getMockBuilder('OCP\IConfig') + ->disableOriginalConstructor() + ->getMock(); + /** @var \OCP\IRequest $request */ $this->request = $this->getMockBuilder('OCP\IRequest') ->disableOriginalConstructor() @@ -34,22 +45,98 @@ class FactoryTest extends TestCase { * @return Factory|\PHPUnit_Framework_MockObject_MockObject */ protected function getFactory(array $methods = []) { - /** @var \OCP\IConfig $config */ - $config = $this->getMock('OCP\IConfig'); - if (!empty($methods)) { return $this->getMockBuilder('OC\L10N\Factory') ->setConstructorArgs([ - $config, + $this->config, $this->request, ]) ->setMethods($methods) ->getMock(); } else { - return new Factory($config, $this->request); + return new Factory($this->config, $this->request); } } + public function dataFindLanguage() { + return [ + [null, false, 1, 'de', true, null, null, null, null, null, 'de'], + [null, 'test', 2, 'de', false, 'ru', true, null, null, null, 'ru'], + [null, 'test', 1, '', null, 'ru', true, null, null, null, 'ru'], + [null, 'test', 3, 'de', false, 'ru', false, 'cz', true, null, 'cz'], + [null, 'test', 2, '', null, 'ru', false, 'cz', true, null, 'cz'], + [null, 'test', 1, '', null, '', null, 'cz', true, null, 'cz'], + [null, 'test', 3, 'de', false, 'ru', false, 'cz', false, 'ar', 'ar'], + [null, 'test', 2, '', null, 'ru', false, 'cz', false, 'ar', 'ar'], + [null, 'test', 1, '', null, '', null, 'cz', false, 'ar', 'ar'], + [null, 'test', 0, '', null, '', null, false, null, 'ar', 'ar'], + ]; + } + + /** + * @dataProvider dataFindLanguage + * + * @param string|null $app + * @param string|null $user + * @param int $existsCalls + * @param string $storedRequestLang + * @param bool $srlExists + * @param string|null $userLang + * @param bool $ulExists + * @param string|false $defaultLang + * @param bool $dlExists + * @param string|null $requestLang + * @param string $expected + */ + public function testFindLanguage($app, $user, $existsCalls, $storedRequestLang, $srlExists, $userLang, $ulExists, $defaultLang, $dlExists, $requestLang, $expected) { + $factory = $this->getFactory([ + 'languageExists', + 'setLanguageFromRequest', + ]); + + $session = $this->getMockBuilder('OCP\ISession') + ->disableOriginalConstructor() + ->getMock(); + $session->expects($this->any()) + ->method('get') + ->with('user_id') + ->willReturn($user); + $userSession = $this->getMockBuilder('OC\User\Session') + ->disableOriginalConstructor() + ->getMock(); + $userSession->expects($this->any()) + ->method('getSession') + ->willReturn($session); + + $this->invokePrivate($factory, 'requestLanguage', [$storedRequestLang]); + + $factory->expects($this->exactly($existsCalls)) + ->method('languageExists') + ->willReturnMap([ + [$app, $storedRequestLang, $srlExists], + [$app, $userLang, $ulExists], + [$app, $defaultLang, $dlExists], + ]); + + $factory->expects($requestLang !== null ? $this->once() : $this->never()) + ->method('setLanguageFromRequest') + ->willReturn($requestLang); + + $this->config->expects($userLang !== null ? $this->any() : $this->never()) + ->method('getUserValue') + ->with($this->anything(), 'core', 'lang') + ->willReturn($userLang); + + $this->config->expects($defaultLang !== null ? $this->once() : $this->never()) + ->method('getSystemValue') + ->with('default_language', false) + ->willReturn($defaultLang); + + $this->overwriteService('UserSession', $userSession); + $this->assertSame($expected, $factory->findLanguage($app)); + $this->restoreService('UserSession'); + } + public function dataLanguageExists() { return [ [null, 'en', [], true], diff --git a/tests/lib/testcase.php b/tests/lib/testcase.php index 38d5cf49320..008b96b3417 100644 --- a/tests/lib/testcase.php +++ b/tests/lib/testcase.php @@ -36,6 +36,46 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase { static protected $realDatabase = null; static private $wasDatabaseAllowed = false; + /** @var array */ + protected $services = []; + + /** + * @param string $name + * @param mixed $newService + * @return bool + */ + public function overwriteService($name, $newService) { + if (isset($this->services[$name])) { + return false; + } + + $this->services[$name] = \OC::$server->query($name); + \OC::$server->registerService($name, function () use ($newService) { + return $newService; + }); + + return true; + } + + /** + * @param string $name + * @return bool + */ + public function restoreService($name) { + if (isset($this->services[$name])) { + $oldService = $this->services[$name]; + \OC::$server->registerService($name, function () use ($oldService) { + return $oldService; + }); + + + unset($this->services[$name]); + return true; + } + + return false; + } + protected function getTestTraits() { $traits = []; $class = $this; |