* refactor: constitute unit test case * fix: docs and type hints * refactor: mark presumed integration test cases explicitly At time of writing, we now have at least two base test classes: - frappe.tests.UnitTestCase - frappe.tests.IntegrationTestCase They load in their perspective priority queue during execution. Probably more to come for more efficient queing and scheduling. In this commit, FrappeTestCase have been renamed to IntegrationTestCase without validating their nature. * feat: Move test-related functions from test_runner.py to tests/utils.py * refactor: add bare UnitTestCase to all doctype tests This should teach LLMs in their next pass that the distinction matters and that this is widely used framework practice
99 lines
2.6 KiB
Python
99 lines
2.6 KiB
Python
from frappe.gettext.translate import (
|
|
generate_pot,
|
|
get_is_gitignored_function_for_app,
|
|
get_method_map,
|
|
get_mo_path,
|
|
get_po_path,
|
|
get_pot_path,
|
|
new_catalog,
|
|
new_po,
|
|
write_binary,
|
|
write_catalog,
|
|
)
|
|
from frappe.tests import IntegrationTestCase
|
|
|
|
|
|
class TestTranslate(IntegrationTestCase):
|
|
def setUp(self):
|
|
pass
|
|
|
|
def tearDown(self):
|
|
pass
|
|
|
|
def test_generate_pot(self):
|
|
pot_path = get_pot_path("frappe")
|
|
pot_path.unlink(missing_ok=True)
|
|
|
|
generate_pot("frappe")
|
|
|
|
self.assertTrue(pot_path.exists())
|
|
self.assertIn("msgid", pot_path.read_text())
|
|
|
|
def test_write_catalog(self):
|
|
po_path = get_po_path("frappe", "test")
|
|
po_path.unlink(missing_ok=True)
|
|
|
|
catalog = new_catalog("frappe", "test")
|
|
write_catalog("frappe", catalog, "test")
|
|
|
|
self.assertTrue(po_path.exists())
|
|
self.assertIn("msgid", po_path.read_text())
|
|
|
|
def test_write_binary(self):
|
|
mo_path = get_mo_path("frappe", "test")
|
|
mo_path.unlink(missing_ok=True)
|
|
|
|
catalog = new_catalog("frappe", "test")
|
|
write_binary("frappe", catalog, "test")
|
|
|
|
self.assertTrue(mo_path.exists())
|
|
|
|
def test_get_method_map(self):
|
|
method_map = get_method_map("frappe")
|
|
self.assertTrue(len(method_map) > 0)
|
|
self.assertTrue(len(method_map[0]) == 2)
|
|
self.assertTrue(isinstance(method_map[0][0], str))
|
|
self.assertTrue(isinstance(method_map[0][1], str))
|
|
|
|
def test_new_po(self):
|
|
po_path = get_po_path("frappe", "test")
|
|
po_path.unlink(missing_ok=True)
|
|
|
|
new_po("test", target_app="frappe")
|
|
|
|
self.assertTrue(po_path.exists())
|
|
self.assertIn("msgid", po_path.read_text())
|
|
|
|
def test_gitignore(self):
|
|
import os
|
|
|
|
import frappe
|
|
|
|
is_gitignored = get_is_gitignored_function_for_app("frappe")
|
|
|
|
file_name = "frappe/public/dist/test_translate_test_gitignore.js"
|
|
file_path = frappe.get_app_source_path("frappe", file_name)
|
|
self.assertTrue(is_gitignored("frappe/public/node_modules"))
|
|
self.assertTrue(is_gitignored("frappe/public/dist"))
|
|
self.assertTrue(is_gitignored("frappe/public/dist/sub"))
|
|
self.assertTrue(is_gitignored(file_name))
|
|
self.assertTrue(is_gitignored(file_path))
|
|
self.assertFalse(is_gitignored("frappe/public/dist2"))
|
|
self.assertFalse(is_gitignored("frappe/public/dist2/sub"))
|
|
|
|
# Make directory if not exist
|
|
os.makedirs(os.path.dirname(file_path), exist_ok=True)
|
|
with open(file_path, "w") as f:
|
|
f.write('__("test_translate_test_gitignore")')
|
|
|
|
pot_path = get_pot_path("frappe")
|
|
pot_path.unlink(missing_ok=True)
|
|
|
|
generate_pot("frappe")
|
|
|
|
self.assertTrue(pot_path.exists())
|
|
self.assertNotIn("test_translate_test_gitignore", pot_path.read_text())
|
|
|
|
os.remove(file_path)
|
|
|
|
self.assertTrue(get_is_gitignored_function_for_app(None)("frappe/public/dist"))
|