]> BookStack Code Mirror - bookstack/blobdiff - tests/LanguageTest.php
Tests: Updated comment test to account for new editor usage
[bookstack] / tests / LanguageTest.php
index bf0ebbeaea37f06a1700eca7f58d00b0674d4b4c..28491c3af9d3b112e359dddc4ce4d0f809e3bdd2 100644 (file)
@@ -1,25 +1,46 @@
-<?php namespace Tests;
+<?php
+
+namespace Tests;
+
+use BookStack\Activity\ActivityType;
+use BookStack\Translation\LocaleManager;
 
 class LanguageTest extends TestCase
 {
-
-    protected $langs;
+    protected array $langs;
 
     /**
      * LanguageTest constructor.
      */
-    public function setUp()
+    protected function setUp(): void
     {
         parent::setUp();
-        $this->langs = array_diff(scandir(resource_path('lang')), ['..', '.', 'check.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 test_locales_all_have_language_dropdown_entry()
     {
-        $configLocales = config('app.locales');
-        sort($configLocales);
+        $this->markTestSkipped('Only used when checking language inclusion');
+
+        $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 +62,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,4 +79,29 @@ class LanguageTest extends TestCase
         }
     }
 
-}
\ No newline at end of file
+    public function test_views_use_rtl_if_rtl_language_is_set()
+    {
+        $this->asEditor()->withHtml($this->get('/'))->assertElementExists('html[dir="ltr"]');
+
+        setting()->putUser($this->users->editor(), 'language', 'ar');
+
+        $this->withHtml($this->get('/'))->assertElementExists('html[dir="rtl"]');
+    }
+
+    public function test_unknown_lang_does_not_break_app()
+    {
+        config()->set('app.locale', 'zz');
+
+        $loginReq = $this->get('/login', ['Accept-Language' => 'zz']);
+        $loginReq->assertOk();
+        $loginReq->assertSee('Log In');
+    }
+
+    public function test_all_activity_types_have_activity_text()
+    {
+        foreach (ActivityType::all() as $activityType) {
+            $langKey = 'activities.' . $activityType;
+            $this->assertNotEquals($langKey, trans($langKey, [], 'en'));
+        }
+    }
+}