* Remove six for PY2 compatability since our dependencies are not, PY2 is legacy. * Removed usages of utils from future/past libraries since they are deprecated. This includes 'from __future__ ...' and 'from past...' statements. * Removed compatibility imports for PY2, switched from six imports to standard library imports. * Removed utils code blocks that handle operations depending on PY2/3 versions. * Removed 'from __future__ ...' lines from templates/code generators * Used PY3 syntaxes in place of PY2 compatible blocks. eg: metaclass
36 lines
1.1 KiB
Python
36 lines
1.1 KiB
Python
# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
|
# MIT License. See license.txt
|
|
|
|
import unittest
|
|
import frappe
|
|
from frappe.desk.doctype.todo.todo import ToDo
|
|
from frappe.cache_manager import clear_controller_cache
|
|
|
|
class TestHooks(unittest.TestCase):
|
|
def test_hooks(self):
|
|
hooks = frappe.get_hooks()
|
|
self.assertTrue(isinstance(hooks.get("app_name"), list))
|
|
self.assertTrue(isinstance(hooks.get("doc_events"), dict))
|
|
self.assertTrue(isinstance(hooks.get("doc_events").get("*"), dict))
|
|
self.assertTrue(isinstance(hooks.get("doc_events").get("*"), dict))
|
|
self.assertTrue("frappe.desk.notifications.clear_doctype_notifications" in
|
|
hooks.get("doc_events").get("*").get("on_update"))
|
|
|
|
def test_override_doctype_class(self):
|
|
from frappe import hooks
|
|
|
|
# Set hook
|
|
hooks.override_doctype_class = {
|
|
'ToDo': ['frappe.tests.test_hooks.CustomToDo']
|
|
}
|
|
|
|
# Clear cache
|
|
frappe.cache().delete_value('app_hooks')
|
|
clear_controller_cache('ToDo')
|
|
|
|
todo = frappe.get_doc(doctype='ToDo', description='asdf')
|
|
self.assertTrue(isinstance(todo, CustomToDo))
|
|
|
|
|
|
class CustomToDo(ToDo):
|
|
pass
|