summaryrefslogtreecommitdiff
path: root/addons/website/tests/test_lang_url.py
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/website/tests/test_lang_url.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/website/tests/test_lang_url.py')
-rw-r--r--addons/website/tests/test_lang_url.py62
1 files changed, 62 insertions, 0 deletions
diff --git a/addons/website/tests/test_lang_url.py b/addons/website/tests/test_lang_url.py
new file mode 100644
index 00000000..51153ade
--- /dev/null
+++ b/addons/website/tests/test_lang_url.py
@@ -0,0 +1,62 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo.addons.http_routing.models.ir_http import url_lang
+from odoo.addons.website.tools import MockRequest
+from odoo.tests import HttpCase, tagged
+
+
+@tagged('-at_install', 'post_install')
+class TestLangUrl(HttpCase):
+ def setUp(self):
+ super(TestLangUrl, self).setUp()
+
+ # Simulate multi lang without loading translations
+ self.website = self.env.ref('website.default_website')
+ self.lang_fr = self.env['res.lang']._activate_lang('fr_FR')
+ self.lang_fr.write({'url_code': 'fr'})
+ self.website.language_ids = self.env.ref('base.lang_en') + self.lang_fr
+ self.website.default_lang_id = self.env.ref('base.lang_en')
+
+ def test_01_url_lang(self):
+ with MockRequest(self.env, website=self.website):
+ self.assertEqual(url_lang('', '[lang]'), '/[lang]/hello/', "`[lang]` is used to be replaced in the url_return after installing a language, it should not be replaced or removed.")
+
+ def test_02_url_redirect(self):
+ url = '/fr_WHATEVER/contactus'
+ r = self.url_open(url)
+ self.assertEqual(r.status_code, 200)
+ self.assertTrue(r.url.endswith('/fr/contactus'), "fr_WHATEVER should be forwarded to 'fr_FR' lang as closest match")
+
+ url = '/fr_FR/contactus'
+ r = self.url_open(url)
+ self.assertEqual(r.status_code, 200)
+ self.assertTrue(r.url.endswith('/fr/contactus'), "lang in url should use url_code ('fr' in this case)")
+
+ def test_03_url_cook_lang_not_available(self):
+ """ An activated res.lang should not be displayed in the frontend if not a website lang. """
+ self.website.language_ids = self.env.ref('base.lang_en')
+ r = self.url_open('/fr/contactus')
+ self.assertTrue('lang="en-US"' in r.text, "french should not be displayed as not a frontend lang")
+
+ def test_04_url_cook_lang_not_available(self):
+ """ `nearest_lang` should filter out lang not available in frontend.
+ Eg: 1. go in backend in english -> request.context['lang'] = `en_US`
+ 2. go in frontend, the request.context['lang'] is passed through
+ `nearest_lang` which should not return english. More then a
+ misbehavior it will crash in website language selector template.
+ """
+ # 1. Load backend
+ self.authenticate('admin', 'admin')
+ r = self.url_open('/web')
+ self.assertTrue('"lang": "en_US"' in r.text, "ensure english was loaded")
+
+ # 2. Remove en_US from frontend
+ self.website.language_ids = self.lang_fr
+ self.website.default_lang_id = self.lang_fr
+
+ # 3. Ensure visiting /contactus do not crash
+ url = '/contactus'
+ r = self.url_open(url)
+ self.assertEqual(r.status_code, 200)
+ self.assertTrue('lang="fr-FR"' in r.text, "Ensure contactus did not soft crash + loaded in correct lang")