Browse Source

Merge pull request #22027 from nextcloud/bugfix/noid/fix-overwrite-service-for-apps

Fix overwriteService() for apps
tags/v20.0.0beta1
Joas Schilling 3 years ago
parent
commit
4824e5e1a7
No account linked to committer's email address
2 changed files with 17 additions and 5 deletions
  1. 6
    1
      lib/private/ServerContainer.php
  2. 11
    4
      tests/lib/TestCase.php

+ 6
- 1
lib/private/ServerContainer.php View File

@@ -156,7 +156,12 @@ class ServerContainer extends SimpleContainer {
return parent::query($name, $autoload);
}

private function getAppContainerForService(string $id): ?DIContainer {
/**
* @internal
* @param string $id
* @return DIContainer|null
*/
public function getAppContainerForService(string $id): ?DIContainer {
if (strpos($id, 'OCA\\') !== 0 || substr_count($id, '\\') < 2) {
return null;
}

+ 11
- 4
tests/lib/TestCase.php View File

@@ -51,13 +51,16 @@ abstract class TestCase extends \PHPUnit\Framework\TestCase {
* @param mixed $newService
* @return bool
*/
public function overwriteService($name, $newService) {
public function overwriteService(string $name, $newService): bool {
if (isset($this->services[$name])) {
return false;
}

$this->services[$name] = \OC::$server->query($name);
\OC::$server->registerService($name, function () use ($newService) {
$container = \OC::$server->getAppContainerForService($name);
$container = $container ?? \OC::$server;

$container->registerService($name, function () use ($newService) {
return $newService;
});

@@ -68,10 +71,14 @@ abstract class TestCase extends \PHPUnit\Framework\TestCase {
* @param string $name
* @return bool
*/
public function restoreService($name) {
public function restoreService(string $name): bool {
if (isset($this->services[$name])) {
$oldService = $this->services[$name];
\OC::$server->registerService($name, function () use ($oldService) {

$container = \OC::$server->getAppContainerForService($name);
$container = $container ?? \OC::$server;

$container->registerService($name, function () use ($oldService) {
return $oldService;
});


Loading…
Cancel
Save