From 96586ba7095b3d955b093bc34d696654faa80252 Mon Sep 17 00:00:00 2001 From: Maxence Lange Date: Fri, 6 Dec 2024 09:35:00 -0100 Subject: feat(config): implementation of lexicon Signed-off-by: Maxence Lange --- tests/lib/AppConfigTest.php | 5 + tests/lib/Config/LexiconTest.php | 151 +++++++++++++++++++++++++++++++ tests/lib/Config/TestConfigLexicon_E.php | 38 ++++++++ tests/lib/Config/TestConfigLexicon_I.php | 40 ++++++++ tests/lib/Config/TestConfigLexicon_N.php | 39 ++++++++ tests/lib/Config/TestConfigLexicon_W.php | 39 ++++++++ tests/lib/Config/UserConfigTest.php | 4 +- 7 files changed, 314 insertions(+), 2 deletions(-) create mode 100644 tests/lib/Config/LexiconTest.php create mode 100644 tests/lib/Config/TestConfigLexicon_E.php create mode 100644 tests/lib/Config/TestConfigLexicon_I.php create mode 100644 tests/lib/Config/TestConfigLexicon_N.php create mode 100644 tests/lib/Config/TestConfigLexicon_W.php (limited to 'tests') diff --git a/tests/lib/AppConfigTest.php b/tests/lib/AppConfigTest.php index e8c10fe654b..775c9027dd6 100644 --- a/tests/lib/AppConfigTest.php +++ b/tests/lib/AppConfigTest.php @@ -9,6 +9,7 @@ namespace Test; use InvalidArgumentException; use OC\AppConfig; +use OC\AppFramework\Bootstrap\Coordinator; use OCP\Exceptions\AppConfigTypeConflictException; use OCP\Exceptions\AppConfigUnknownKeyException; use OCP\IAppConfig; @@ -28,6 +29,8 @@ class AppConfigTest extends TestCase { protected IDBConnection $connection; private LoggerInterface $logger; private ICrypto $crypto; + private Coordinator $coordinator; + private array $originalConfig; /** @@ -88,6 +91,7 @@ class AppConfigTest extends TestCase { $this->connection = \OCP\Server::get(IDBConnection::class); $this->logger = \OCP\Server::get(LoggerInterface::class); $this->crypto = \OCP\Server::get(ICrypto::class); + $this->coordinator = \OCP\Server::get(Coordinator::class); // storing current config and emptying the data table $sql = $this->connection->getQueryBuilder(); @@ -178,6 +182,7 @@ class AppConfigTest extends TestCase { $this->connection, $this->logger, $this->crypto, + $this->coordinator ); $msg = ' generateAppConfig() failed to confirm cache status'; diff --git a/tests/lib/Config/LexiconTest.php b/tests/lib/Config/LexiconTest.php new file mode 100644 index 00000000000..5bcd3509b22 --- /dev/null +++ b/tests/lib/Config/LexiconTest.php @@ -0,0 +1,151 @@ +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); + + $this->appConfig = Server::get(IAppConfig::class); + $this->userConfig = Server::get(IUserConfig::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->userConfig->deleteApp(TestConfigLexicon_I::APPID); + $this->userConfig->deleteApp(TestConfigLexicon_N::APPID); + $this->userConfig->deleteApp(TestConfigLexicon_W::APPID); + $this->userConfig->deleteApp(TestConfigLexicon_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'); + } + + public function testAppLexiconGetCorrect() { + $this->assertSame('abcde', $this->appConfig->getValueString(TestConfigLexicon_E::APPID, 'key1', 'default')); + } + + public function testAppLexiconSetIncorrectValueType() { + $this->expectException(AppConfigTypeConflictException::class); + $this->appConfig->setValueInt(TestConfigLexicon_E::APPID, 'key1', -1); + } + + public function testAppLexiconGetIncorrectValueType() { + $this->expectException(AppConfigTypeConflictException::class); + $this->appConfig->getValueInt(TestConfigLexicon_E::APPID, 'key1'); + } + + public function testAppLexiconIgnore() { + $this->appConfig->setValueString(TestConfigLexicon_I::APPID, 'key_ignore', 'new_value'); + $this->assertSame('new_value', $this->appConfig->getValueString(TestConfigLexicon_I::APPID, 'key_ignore', '')); + } + + 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', '')); + } + + public function testAppLexiconWarning() { + $this->appConfig->setValueString(TestConfigLexicon_W::APPID, 'key_warning', 'new_value'); + $this->assertSame('', $this->appConfig->getValueString(TestConfigLexicon_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', '')); + } + + public function testAppLexiconGetException() { + $this->expectException(AppConfigUnknownKeyException::class); + $this->appConfig->getValueString(TestConfigLexicon_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'); + } + + public function testUserLexiconGetCorrect() { + $this->assertSame('abcde', $this->userConfig->getValueString('user1', TestConfigLexicon_E::APPID, 'key1', 'default')); + } + + public function testUserLexiconSetIncorrectValueType() { + $this->expectException(TypeConflictException::class); + $this->userConfig->setValueInt('user1', TestConfigLexicon_E::APPID, 'key1', -1); + } + + public function testUserLexiconGetIncorrectValueType() { + $this->expectException(TypeConflictException::class); + $this->userConfig->getValueInt('user1', TestConfigLexicon_E::APPID, 'key1'); + } + + public function testUserLexiconIgnore() { + $this->userConfig->setValueString('user1', TestConfigLexicon_I::APPID, 'key_ignore', 'new_value'); + $this->assertSame('new_value', $this->userConfig->getValueString('user1', TestConfigLexicon_I::APPID, 'key_ignore', '')); + } + + 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', '')); + } + + 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', '')); + } + + 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', '')); + } + + public function testUserLexiconGetException() { + $this->expectException(UnknownKeyException::class); + $this->userConfig->getValueString('user1', TestConfigLexicon_E::APPID, 'key_exception'); + } +} diff --git a/tests/lib/Config/TestConfigLexicon_E.php b/tests/lib/Config/TestConfigLexicon_E.php new file mode 100644 index 00000000000..e0890cbd76e --- /dev/null +++ b/tests/lib/Config/TestConfigLexicon_E.php @@ -0,0 +1,38 @@ +generateUserConfig(); $this->assertEqualsCanonicalizing( -- cgit v1.2.3