aboutsummaryrefslogtreecommitdiffstats
path: root/tests/lib/Config/LexiconTest.php
diff options
context:
space:
mode:
Diffstat (limited to 'tests/lib/Config/LexiconTest.php')
-rw-r--r--tests/lib/Config/LexiconTest.php165
1 files changed, 124 insertions, 41 deletions
diff --git a/tests/lib/Config/LexiconTest.php b/tests/lib/Config/LexiconTest.php
index 5bcd3509b22..d7e9b12a1cf 100644
--- a/tests/lib/Config/LexiconTest.php
+++ b/tests/lib/Config/LexiconTest.php
@@ -7,10 +7,14 @@ declare(strict_types=1);
*/
namespace Tests\lib\Config;
-use NCU\Config\Exceptions\TypeConflictException;
-use NCU\Config\Exceptions\UnknownKeyException;
-use NCU\Config\IUserConfig;
+use OC\AppConfig;
use OC\AppFramework\Bootstrap\Coordinator;
+use OC\Config\ConfigManager;
+use OC\Config\PresetManager;
+use OCP\Config\Exceptions\TypeConflictException;
+use OCP\Config\Exceptions\UnknownKeyException;
+use OCP\Config\IUserConfig;
+use OCP\Config\Lexicon\Preset;
use OCP\Exceptions\AppConfigTypeConflictException;
use OCP\Exceptions\AppConfigUnknownKeyException;
use OCP\IAppConfig;
@@ -25,55 +29,60 @@ use Test\TestCase;
* @package Test
*/
class LexiconTest extends TestCase {
+ /** @var AppConfig */
private IAppConfig $appConfig;
private IUserConfig $userConfig;
+ private ConfigManager $configManager;
+ private PresetManager $presetManager;
protected function setUp(): void {
parent::setUp();
- $bootstrapCoordinator = \OCP\Server::get(Coordinator::class);
+ $bootstrapCoordinator = Server::get(Coordinator::class);
$bootstrapCoordinator->getRegistrationContext()?->registerConfigLexicon(TestConfigLexicon_I::APPID, TestConfigLexicon_I::class);
- $bootstrapCoordinator->getRegistrationContext()?->registerConfigLexicon(TestConfigLexicon_N::APPID, TestConfigLexicon_N::class);
- $bootstrapCoordinator->getRegistrationContext()?->registerConfigLexicon(TestConfigLexicon_W::APPID, TestConfigLexicon_W::class);
- $bootstrapCoordinator->getRegistrationContext()?->registerConfigLexicon(TestConfigLexicon_E::APPID, TestConfigLexicon_E::class);
+ $bootstrapCoordinator->getRegistrationContext()?->registerConfigLexicon(TestLexicon_N::APPID, TestLexicon_N::class);
+ $bootstrapCoordinator->getRegistrationContext()?->registerConfigLexicon(TestLexicon_W::APPID, TestLexicon_W::class);
+ $bootstrapCoordinator->getRegistrationContext()?->registerConfigLexicon(TestLexicon_E::APPID, TestLexicon_E::class);
$this->appConfig = Server::get(IAppConfig::class);
$this->userConfig = Server::get(IUserConfig::class);
+ $this->configManager = Server::get(ConfigManager::class);
+ $this->presetManager = Server::get(PresetManager::class);
}
protected function tearDown(): void {
parent::tearDown();
$this->appConfig->deleteApp(TestConfigLexicon_I::APPID);
- $this->appConfig->deleteApp(TestConfigLexicon_N::APPID);
- $this->appConfig->deleteApp(TestConfigLexicon_W::APPID);
- $this->appConfig->deleteApp(TestConfigLexicon_E::APPID);
+ $this->appConfig->deleteApp(TestLexicon_N::APPID);
+ $this->appConfig->deleteApp(TestLexicon_W::APPID);
+ $this->appConfig->deleteApp(TestLexicon_E::APPID);
$this->userConfig->deleteApp(TestConfigLexicon_I::APPID);
- $this->userConfig->deleteApp(TestConfigLexicon_N::APPID);
- $this->userConfig->deleteApp(TestConfigLexicon_W::APPID);
- $this->userConfig->deleteApp(TestConfigLexicon_E::APPID);
+ $this->userConfig->deleteApp(TestLexicon_N::APPID);
+ $this->userConfig->deleteApp(TestLexicon_W::APPID);
+ $this->userConfig->deleteApp(TestLexicon_E::APPID);
}
public function testAppLexiconSetCorrect() {
- $this->assertSame(true, $this->appConfig->setValueString(TestConfigLexicon_E::APPID, 'key1', 'new_value'));
- $this->assertSame(true, $this->appConfig->isLazy(TestConfigLexicon_E::APPID, 'key1'));
- $this->assertSame(true, $this->appConfig->isSensitive(TestConfigLexicon_E::APPID, 'key1'));
- $this->appConfig->deleteKey(TestConfigLexicon_E::APPID, 'key1');
+ $this->assertSame(true, $this->appConfig->setValueString(TestLexicon_E::APPID, 'key1', 'new_value'));
+ $this->assertSame(true, $this->appConfig->isLazy(TestLexicon_E::APPID, 'key1'));
+ $this->assertSame(true, $this->appConfig->isSensitive(TestLexicon_E::APPID, 'key1'));
+ $this->appConfig->deleteKey(TestLexicon_E::APPID, 'key1');
}
public function testAppLexiconGetCorrect() {
- $this->assertSame('abcde', $this->appConfig->getValueString(TestConfigLexicon_E::APPID, 'key1', 'default'));
+ $this->assertSame('abcde', $this->appConfig->getValueString(TestLexicon_E::APPID, 'key1', 'default'));
}
public function testAppLexiconSetIncorrectValueType() {
$this->expectException(AppConfigTypeConflictException::class);
- $this->appConfig->setValueInt(TestConfigLexicon_E::APPID, 'key1', -1);
+ $this->appConfig->setValueInt(TestLexicon_E::APPID, 'key1', -1);
}
public function testAppLexiconGetIncorrectValueType() {
$this->expectException(AppConfigTypeConflictException::class);
- $this->appConfig->getValueInt(TestConfigLexicon_E::APPID, 'key1');
+ $this->appConfig->getValueInt(TestLexicon_E::APPID, 'key1');
}
public function testAppLexiconIgnore() {
@@ -82,45 +91,45 @@ class LexiconTest extends TestCase {
}
public function testAppLexiconNotice() {
- $this->appConfig->setValueString(TestConfigLexicon_N::APPID, 'key_notice', 'new_value');
- $this->assertSame('new_value', $this->appConfig->getValueString(TestConfigLexicon_N::APPID, 'key_notice', ''));
+ $this->appConfig->setValueString(TestLexicon_N::APPID, 'key_notice', 'new_value');
+ $this->assertSame('new_value', $this->appConfig->getValueString(TestLexicon_N::APPID, 'key_notice', ''));
}
public function testAppLexiconWarning() {
- $this->appConfig->setValueString(TestConfigLexicon_W::APPID, 'key_warning', 'new_value');
- $this->assertSame('', $this->appConfig->getValueString(TestConfigLexicon_W::APPID, 'key_warning', ''));
+ $this->appConfig->setValueString(TestLexicon_W::APPID, 'key_warning', 'new_value');
+ $this->assertSame('', $this->appConfig->getValueString(TestLexicon_W::APPID, 'key_warning', ''));
}
public function testAppLexiconSetException() {
$this->expectException(AppConfigUnknownKeyException::class);
- $this->appConfig->setValueString(TestConfigLexicon_E::APPID, 'key_exception', 'new_value');
- $this->assertSame('', $this->appConfig->getValueString(TestConfigLexicon_E::APPID, 'key3', ''));
+ $this->appConfig->setValueString(TestLexicon_E::APPID, 'key_exception', 'new_value');
+ $this->assertSame('', $this->appConfig->getValueString(TestLexicon_E::APPID, 'key3', ''));
}
public function testAppLexiconGetException() {
$this->expectException(AppConfigUnknownKeyException::class);
- $this->appConfig->getValueString(TestConfigLexicon_E::APPID, 'key_exception');
+ $this->appConfig->getValueString(TestLexicon_E::APPID, 'key_exception');
}
public function testUserLexiconSetCorrect() {
- $this->assertSame(true, $this->userConfig->setValueString('user1', TestConfigLexicon_E::APPID, 'key1', 'new_value'));
- $this->assertSame(true, $this->userConfig->isLazy('user1', TestConfigLexicon_E::APPID, 'key1'));
- $this->assertSame(true, $this->userConfig->isSensitive('user1', TestConfigLexicon_E::APPID, 'key1'));
- $this->userConfig->deleteKey(TestConfigLexicon_E::APPID, 'key1');
+ $this->assertSame(true, $this->userConfig->setValueString('user1', TestLexicon_E::APPID, 'key1', 'new_value'));
+ $this->assertSame(true, $this->userConfig->isLazy('user1', TestLexicon_E::APPID, 'key1'));
+ $this->assertSame(true, $this->userConfig->isSensitive('user1', TestLexicon_E::APPID, 'key1'));
+ $this->userConfig->deleteKey(TestLexicon_E::APPID, 'key1');
}
public function testUserLexiconGetCorrect() {
- $this->assertSame('abcde', $this->userConfig->getValueString('user1', TestConfigLexicon_E::APPID, 'key1', 'default'));
+ $this->assertSame('abcde', $this->userConfig->getValueString('user1', TestLexicon_E::APPID, 'key1', 'default'));
}
public function testUserLexiconSetIncorrectValueType() {
$this->expectException(TypeConflictException::class);
- $this->userConfig->setValueInt('user1', TestConfigLexicon_E::APPID, 'key1', -1);
+ $this->userConfig->setValueInt('user1', TestLexicon_E::APPID, 'key1', -1);
}
public function testUserLexiconGetIncorrectValueType() {
$this->expectException(TypeConflictException::class);
- $this->userConfig->getValueInt('user1', TestConfigLexicon_E::APPID, 'key1');
+ $this->userConfig->getValueInt('user1', TestLexicon_E::APPID, 'key1');
}
public function testUserLexiconIgnore() {
@@ -129,23 +138,97 @@ class LexiconTest extends TestCase {
}
public function testUserLexiconNotice() {
- $this->userConfig->setValueString('user1', TestConfigLexicon_N::APPID, 'key_notice', 'new_value');
- $this->assertSame('new_value', $this->userConfig->getValueString('user1', TestConfigLexicon_N::APPID, 'key_notice', ''));
+ $this->userConfig->setValueString('user1', TestLexicon_N::APPID, 'key_notice', 'new_value');
+ $this->assertSame('new_value', $this->userConfig->getValueString('user1', TestLexicon_N::APPID, 'key_notice', ''));
}
public function testUserLexiconWarning() {
- $this->userConfig->setValueString('user1', TestConfigLexicon_W::APPID, 'key_warning', 'new_value');
- $this->assertSame('', $this->userConfig->getValueString('user1', TestConfigLexicon_W::APPID, 'key_warning', ''));
+ $this->userConfig->setValueString('user1', TestLexicon_W::APPID, 'key_warning', 'new_value');
+ $this->assertSame('', $this->userConfig->getValueString('user1', TestLexicon_W::APPID, 'key_warning', ''));
}
public function testUserLexiconSetException() {
$this->expectException(UnknownKeyException::class);
- $this->userConfig->setValueString('user1', TestConfigLexicon_E::APPID, 'key_exception', 'new_value');
- $this->assertSame('', $this->userConfig->getValueString('user1', TestConfigLexicon_E::APPID, 'key3', ''));
+ $this->userConfig->setValueString('user1', TestLexicon_E::APPID, 'key_exception', 'new_value');
+ $this->assertSame('', $this->userConfig->getValueString('user1', TestLexicon_E::APPID, 'key5', ''));
}
public function testUserLexiconGetException() {
$this->expectException(UnknownKeyException::class);
- $this->userConfig->getValueString('user1', TestConfigLexicon_E::APPID, 'key_exception');
+ $this->userConfig->getValueString('user1', TestLexicon_E::APPID, 'key_exception');
+ }
+
+ public function testAppConfigLexiconRenameSetNewValue() {
+ $this->assertSame(12345, $this->appConfig->getValueInt(TestConfigLexicon_I::APPID, 'key3', 123));
+ $this->appConfig->setValueInt(TestConfigLexicon_I::APPID, 'old_key3', 994);
+ $this->assertSame(994, $this->appConfig->getValueInt(TestConfigLexicon_I::APPID, 'key3', 123));
+ }
+
+ public function testAppConfigLexiconRenameSetOldValuePreMigration() {
+ $this->appConfig->ignoreLexiconAliases(true);
+ $this->appConfig->setValueInt(TestConfigLexicon_I::APPID, 'old_key3', 993);
+ $this->appConfig->ignoreLexiconAliases(false);
+ $this->assertSame(12345, $this->appConfig->getValueInt(TestConfigLexicon_I::APPID, 'key3', 123));
+ }
+
+ public function testAppConfigLexiconRenameSetOldValuePostMigration() {
+ $this->appConfig->ignoreLexiconAliases(true);
+ $this->appConfig->setValueInt(TestConfigLexicon_I::APPID, 'old_key3', 994);
+ $this->appConfig->ignoreLexiconAliases(false);
+ $this->configManager->migrateConfigLexiconKeys(TestConfigLexicon_I::APPID);
+ $this->assertSame(994, $this->appConfig->getValueInt(TestConfigLexicon_I::APPID, 'key3', 123));
+ }
+
+ public function testAppConfigLexiconRenameGetNewValue() {
+ $this->appConfig->setValueInt(TestConfigLexicon_I::APPID, 'key3', 981);
+ $this->assertSame(981, $this->appConfig->getValueInt(TestConfigLexicon_I::APPID, 'old_key3', 123));
+ }
+
+ public function testAppConfigLexiconRenameGetOldValuePreMigration() {
+ $this->appConfig->ignoreLexiconAliases(true);
+ $this->appConfig->setValueInt(TestConfigLexicon_I::APPID, 'key3', 984);
+ $this->assertSame(123, $this->appConfig->getValueInt(TestConfigLexicon_I::APPID, 'old_key3', 123));
+ $this->appConfig->ignoreLexiconAliases(false);
+ }
+
+ public function testAppConfigLexiconRenameGetOldValuePostMigration() {
+ $this->appConfig->ignoreLexiconAliases(true);
+ $this->appConfig->setValueInt(TestConfigLexicon_I::APPID, 'key3', 987);
+ $this->appConfig->ignoreLexiconAliases(false);
+ $this->configManager->migrateConfigLexiconKeys(TestConfigLexicon_I::APPID);
+ $this->assertSame(987, $this->appConfig->getValueInt(TestConfigLexicon_I::APPID, 'old_key3', 123));
+ }
+
+ public function testAppConfigLexiconRenameInvertBoolean() {
+ $this->appConfig->ignoreLexiconAliases(true);
+ $this->appConfig->setValueBool(TestConfigLexicon_I::APPID, 'old_key4', true);
+ $this->appConfig->ignoreLexiconAliases(false);
+ $this->assertSame(true, $this->appConfig->getValueBool(TestConfigLexicon_I::APPID, 'key4'));
+ $this->configManager->migrateConfigLexiconKeys(TestConfigLexicon_I::APPID);
+ $this->assertSame(false, $this->appConfig->getValueBool(TestConfigLexicon_I::APPID, 'key4'));
+ }
+
+ public function testAppConfigLexiconPreset() {
+ $this->presetManager->setLexiconPreset(Preset::FAMILY);
+ $this->assertSame('family', $this->appConfig->getValueString(TestLexicon_E::APPID, 'key3'));
+ }
+
+ public function testAppConfigLexiconPresets() {
+ $this->presetManager->setLexiconPreset(Preset::MEDIUM);
+ $this->assertSame('club+medium', $this->appConfig->getValueString(TestLexicon_E::APPID, 'key3'));
+ $this->presetManager->setLexiconPreset(Preset::FAMILY);
+ $this->assertSame('family', $this->appConfig->getValueString(TestLexicon_E::APPID, 'key3'));
+ }
+
+ public function testUserConfigLexiconPreset() {
+ $this->presetManager->setLexiconPreset(Preset::FAMILY);
+ $this->assertSame('family', $this->userConfig->getValueString('user1', TestLexicon_E::APPID, 'key3'));
+ }
+
+ public function testUserConfigLexiconPresets() {
+ $this->presetManager->setLexiconPreset(Preset::MEDIUM);
+ $this->assertSame('club+medium', $this->userConfig->getValueString('user1', TestLexicon_E::APPID, 'key3'));
+ $this->presetManager->setLexiconPreset(Preset::FAMILY);
+ $this->assertSame('family', $this->userConfig->getValueString('user1', TestLexicon_E::APPID, 'key3'));
}
}