X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/651ae2f3be949b43c02d09789f540f5a19a09f53..refs/pull/5280/head:/tests/LanguageTest.php diff --git a/tests/LanguageTest.php b/tests/LanguageTest.php index 91abadc91..abe06407e 100644 --- a/tests/LanguageTest.php +++ b/tests/LanguageTest.php @@ -1,25 +1,44 @@ -langs = array_diff(scandir(resource_path('lang')), ['..', '.', 'check.php', 'format.php']); + $this->langs = array_diff(scandir(lang_path('')), ['..', '.']); + } + + public function test_locales_list_set_properly() + { + $appLocales = $this->app->make(LocaleManager::class)->getAllAppLocales(); + sort($appLocales); + sort($this->langs); + $this->assertEquals(implode(':', $this->langs), implode(':', $appLocales), 'app.locales configuration variable does not match those found in lang files'); } - public function test_locales_config_key_set_properly() + // Not part of standard phpunit test runs since we sometimes expect non-added langs. + public function do_test_locales_all_have_language_dropdown_entry() { - $configLocales = config('app.locales'); - sort($configLocales); + $dropdownLocales = array_keys(trans('settings.language_select', [], 'en')); + sort($dropdownLocales); sort($this->langs); - $this->assertTrue(implode(':', $this->langs) === implode(':', $configLocales), 'app.locales configuration variable matches found lang files'); + $diffs = array_diff($this->langs, $dropdownLocales); + if (count($diffs) > 0) { + $diffText = implode(',', $diffs); + $warning = "Languages: {$diffText} found in files but not in language select dropdown."; + $this->fail($warning); + } + $this->assertTrue(true); } public function test_correct_language_if_not_logged_in() @@ -41,27 +60,13 @@ class LanguageTest extends TestCase $loginPageFrenchReq->assertDontSee('Se Connecter'); } - public function test_js_endpoint_for_each_language() - { - - $visibleKeys = ['common', 'components', 'entities', 'errors']; - - $this->asEditor(); - foreach ($this->langs as $lang) { - setting()->putUser($this->getEditor(), 'language', $lang); - $transResp = $this->get('/translations'); - foreach ($visibleKeys as $key) { - $transResp->assertSee($key); - } - } - } - public function test_all_lang_files_loadable() { - $files = array_diff(scandir(resource_path('lang/en')), ['..', '.']); + $files = array_diff(scandir(lang_path('en')), ['..', '.']); foreach ($this->langs as $lang) { foreach ($files as $file) { $loadError = false; + try { $translations = trans(str_replace('.php', '', $file), [], $lang); } catch (\Exception $e) { @@ -72,39 +77,29 @@ class LanguageTest extends TestCase } } - public function test_rtl_config_set_if_lang_is_rtl() + public function test_views_use_rtl_if_rtl_language_is_set() { - $this->asEditor(); - $this->assertFalse(config('app.rtl'), "App RTL config should be false by default"); - setting()->putUser($this->getEditor(), 'language', 'ar'); - $this->get('/'); - $this->assertTrue(config('app.rtl'), "App RTL config should have been set to true by middleware"); - } + $this->asEditor()->withHtml($this->get('/'))->assertElementExists('html[dir="ltr"]'); - public function test_de_informal_falls_base_to_de() - { - // Base de back value - $deBack = trans()->get('common.cancel', [], 'de', false); - $this->assertEquals('Abbrechen', $deBack); - // Ensure de_informal has no value set - $this->assertEquals('common.cancel', trans()->get('common.cancel', [], 'de_informal', false)); - // Ensure standard trans falls back to de - $this->assertEquals($deBack, trans('common.cancel', [], 'de_informal')); - // Ensure de_informal gets its own values where set - $deEmailActionHelp = trans()->get('common.email_action_help', [], 'de', false); - $enEmailActionHelp = trans()->get('common.email_action_help', [], 'en', false); - $deInformalEmailActionHelp = trans()->get('common.email_action_help', [], 'de_informal', false); - $this->assertNotEquals($deEmailActionHelp, $deInformalEmailActionHelp); - $this->assertNotEquals($enEmailActionHelp, $deInformalEmailActionHelp); + setting()->putUser($this->users->editor(), 'language', 'ar'); + + $this->withHtml($this->get('/'))->assertElementExists('html[dir="rtl"]'); } - public function test_de_informal_falls_base_to_de_in_js_endpoint() + public function test_unknown_lang_does_not_break_app() { - $this->asEditor(); - setting()->putUser($this->getEditor(), 'language', 'de_informal'); + config()->set('app.locale', 'zz'); - $transResp = $this->get('/translations'); - $transResp->assertSee('"cancel":"Abbrechen"'); + $loginReq = $this->get('/login', ['Accept-Language' => 'zz']); + $loginReq->assertOk(); + $loginReq->assertSee('Log In'); } -} \ No newline at end of file + public function test_all_activity_types_have_activity_text() + { + foreach (ActivityType::all() as $activityType) { + $langKey = 'activities.' . $activityType; + $this->assertNotEquals($langKey, trans($langKey, [], 'en')); + } + } +}