diff options
Diffstat (limited to 'tests/units/Model')
-rw-r--r-- | tests/units/Model/ConfigTest.php | 143 | ||||
-rw-r--r-- | tests/units/Model/CurrencyTest.php | 7 |
2 files changed, 119 insertions, 31 deletions
diff --git a/tests/units/Model/ConfigTest.php b/tests/units/Model/ConfigTest.php index 0c108fd1..447c9238 100644 --- a/tests/units/Model/ConfigTest.php +++ b/tests/units/Model/ConfigTest.php @@ -7,6 +7,74 @@ use Kanboard\Core\Session\SessionManager; class ConfigTest extends Base { + public function testGetTimezones() + { + $configModel = new Config($this->container); + $this->assertNotEmpty($configModel->getTimezones()); + $this->assertArrayHasKey('Europe/Paris', $configModel->getTimezones()); + $this->assertContains('Europe/Paris', $configModel->getTimezones()); + $this->assertArrayNotHasKey('', $configModel->getTimezones()); + + $this->assertArrayHasKey('', $configModel->getTimezones(true)); + $this->assertContains('Application default', $configModel->getTimezones(true)); + } + + public function testGetLanguages() + { + $configModel = new Config($this->container); + $this->assertNotEmpty($configModel->getLanguages()); + $this->assertArrayHasKey('fr_FR', $configModel->getLanguages()); + $this->assertContains('Français', $configModel->getLanguages()); + $this->assertArrayNotHasKey('', $configModel->getLanguages()); + + $this->assertArrayHasKey('', $configModel->getLanguages(true)); + $this->assertContains('Application default', $configModel->getLanguages(true)); + } + + public function testGetJsLanguage() + { + $configModel = new Config($this->container); + $this->assertEquals('en', $configModel->getJsLanguageCode()); + + $this->container['sessionStorage']->user = array('language' => 'fr_FR'); + $this->assertEquals('fr', $configModel->getJsLanguageCode()); + + $this->container['sessionStorage']->user = array('language' => 'xx_XX'); + $this->assertEquals('en', $configModel->getJsLanguageCode()); + } + + public function testGetCurrentLanguage() + { + $configModel = new Config($this->container); + $this->assertEquals('en_US', $configModel->getCurrentLanguage()); + + $this->container['sessionStorage']->user = array('language' => 'fr_FR'); + $this->assertEquals('fr_FR', $configModel->getCurrentLanguage()); + + $this->container['sessionStorage']->user = array('language' => 'xx_XX'); + $this->assertEquals('xx_XX', $configModel->getCurrentLanguage()); + } + + public function testGetCurrentTimezone() + { + $configModel = new Config($this->container); + $this->assertEquals('UTC', $configModel->getCurrentTimezone()); + + $this->container['sessionStorage']->user = array('timezone' => 'Europe/Paris'); + $this->assertEquals('Europe/Paris', $configModel->getCurrentTimezone()); + + $this->container['sessionStorage']->user = array('timezone' => 'Something'); + $this->assertEquals('Something', $configModel->getCurrentTimezone()); + } + + public function testRegenerateToken() + { + $configModel = new Config($this->container); + $token = $configModel->getOption('api_token'); + $this->assertTrue($configModel->regenerateToken('api_token')); + $this->assertNotEquals($token, $configModel->getOption('api_token')); + } + public function testCRUDOperations() { $c = new Config($this->container); @@ -37,60 +105,73 @@ class ConfigTest extends Base $c = new Config($this->container); $this->assertTrue($c->save(array('application_url' => 'http://localhost/'))); - $this->assertEquals('http://localhost/', $c->get('application_url')); + $this->assertEquals('http://localhost/', $c->getOption('application_url')); $this->assertTrue($c->save(array('application_url' => 'http://localhost'))); - $this->assertEquals('http://localhost/', $c->get('application_url')); + $this->assertEquals('http://localhost/', $c->getOption('application_url')); $this->assertTrue($c->save(array('application_url' => ''))); - $this->assertEquals('', $c->get('application_url')); + $this->assertEquals('', $c->getOption('application_url')); } public function testDefaultValues() { $c = new Config($this->container); - $this->assertEquals('en_US', $c->get('application_language')); - $this->assertEquals('UTC', $c->get('application_timezone')); - - $this->assertEmpty($c->get('webhook_url_task_modification')); - $this->assertEmpty($c->get('webhook_url_task_creation')); - $this->assertEmpty($c->get('board_columns')); - $this->assertEmpty($c->get('application_url')); - - $this->assertNotEmpty($c->get('webhook_token')); - $this->assertNotEmpty($c->get('api_token')); + $this->assertEquals(172800, $c->getOption('board_highlight_period')); + $this->assertEquals(60, $c->getOption('board_public_refresh_interval')); + $this->assertEquals(10, $c->getOption('board_private_refresh_interval')); + $this->assertEmpty($c->getOption('board_columns')); + + $this->assertEquals('yellow', $c->getOption('default_color')); + $this->assertEquals('en_US', $c->getOption('application_language')); + $this->assertEquals('UTC', $c->getOption('application_timezone')); + $this->assertEquals('m/d/Y', $c->getOption('application_date_format')); + $this->assertEmpty($c->getOption('application_url')); + $this->assertEmpty($c->getOption('application_stylesheet')); + $this->assertEquals('USD', $c->getOption('application_currency')); + + $this->assertEquals(0, $c->getOption('calendar_user_subtasks_time_tracking')); + $this->assertEquals('date_started', $c->getOption('calendar_user_tasks')); + $this->assertEquals('date_started', $c->getOption('calendar_user_tasks')); + + $this->assertEquals(0, $c->getOption('integration_gravatar')); + $this->assertEquals(1, $c->getOption('cfd_include_closed_tasks')); + $this->assertEquals(1, $c->getOption('password_reset')); + + $this->assertEquals(1, $c->getOption('subtask_time_tracking')); + $this->assertEquals(0, $c->getOption('subtask_restriction')); + $this->assertEmpty($c->getOption('project_categories')); + + $this->assertEmpty($c->getOption('webhook_url_task_modification')); + $this->assertEmpty($c->getOption('webhook_url_task_creation')); + $this->assertNotEmpty($c->getOption('webhook_token')); + $this->assertEmpty($c->getOption('webhook_url')); + + $this->assertNotEmpty($c->getOption('api_token')); } - public function testGet() + public function testGetOption() { $c = new Config($this->container); - $this->assertEquals('', $c->get('board_columns')); - $this->assertEquals('test', $c->get('board_columns', 'test')); - $this->assertEquals(0, $c->get('board_columns', 0)); + $this->assertEquals('', $c->getOption('board_columns')); + $this->assertEquals('test', $c->getOption('board_columns', 'test')); + $this->assertEquals(0, $c->getOption('board_columns', 0)); } - public function testGetWithSession() + public function testGetWithCaching() { $c = new Config($this->container); - session_id('test'); - $this->assertTrue(SessionManager::isOpen()); + $this->assertEquals('UTC', $c->get('application_timezone')); + $this->assertTrue($c->save(array('application_timezone' => 'Europe/Paris'))); + + $this->assertEquals('UTC', $c->get('application_timezone')); // cached value + $this->assertEquals('Europe/Paris', $c->getOption('application_timezone')); $this->assertEquals('', $c->get('board_columns')); $this->assertEquals('test', $c->get('board_columns', 'test')); - - $this->container['sessionStorage']->config = array( - 'board_columns' => 'foo', - 'empty_value' => 0 - ); - - $this->assertEquals('foo', $c->get('board_columns')); - $this->assertEquals('foo', $c->get('board_columns', 'test')); $this->assertEquals('test', $c->get('empty_value', 'test')); - - session_id(''); - $this->assertFalse(SessionManager::isOpen()); } } diff --git a/tests/units/Model/CurrencyTest.php b/tests/units/Model/CurrencyTest.php index ee11c0fb..0bc71da6 100644 --- a/tests/units/Model/CurrencyTest.php +++ b/tests/units/Model/CurrencyTest.php @@ -6,6 +6,13 @@ use Kanboard\Model\Currency; class CurrencyTest extends Base { + public function testGetCurrencies() + { + $currencyModel = new Currency($this->container); + $currencies = $currencyModel->getCurrencies(); + $this->assertArrayHasKey('EUR', $currencies); + } + public function testGetAll() { $currencyModel = new Currency($this->container); |