diff --git a/plone/dexterity/tests/test_fti.py b/plone/dexterity/tests/test_fti.py
index 615c5ed..556abb2 100644
--- a/plone/dexterity/tests/test_fti.py
+++ b/plone/dexterity/tests/test_fti.py
@@ -31,6 +31,8 @@ from plone.dexterity.fti import ftiAdded, ftiRemoved, ftiRenamed, ftiModified
from plone.dexterity.factory import DexterityFactory
+from plone.dexterity.schema import DexteritySchemaPolicy
+
from plone.dexterity import utils
from plone.dexterity.tests.schemata import ITestSchema
@@ -46,6 +48,9 @@ class TestClass(object):
class TestClass2(object):
meta_type = "Test Class 2"
+class ITestInterface(Interface):
+ pass
+
class TestFTI(MockTestCase):
@@ -336,6 +341,36 @@ class TestFTI(MockTestCase):
self.assertEquals(u't\xe9st', msgid)
self.assertEquals('test', msgid.domain)
+ def test_lookupModel_without_schema_policy(self):
+ gsm = getGlobalSiteManager()
+ gsm.registerUtility(DexteritySchemaPolicy(), plone.supermodel.interfaces.ISchemaPolicy, name=u"dexterity")
+
+ fti = DexterityFTI(u"testtype")
+ fti.schema = None
+ fti.model_source = ''
+ fti.model_file = None
+
+ model = fti.lookupModel()
+ self.assertEquals(False, ITestInterface in model.schemata[''].__bases__)
+
+ def test_lookupModel_with_schema_policy(self):
+ class TestSchemaPolicy(DexteritySchemaPolicy):
+ def bases(self, schemaName, tree):
+ return (ITestInterface,)
+
+ gsm = getGlobalSiteManager()
+ policy = TestSchemaPolicy()
+ gsm.registerUtility(policy, plone.supermodel.interfaces.ISchemaPolicy, name=u"test")
+
+ fti = DexterityFTI(u"testtype")
+ fti.schema = None
+ fti.model_source = ''
+ fti.model_file = None
+ fti.schema_policy = u"test"
+
+ model = fti.lookupModel()
+ self.assertEquals(True, ITestInterface in model.schemata[''].__bases__)
+
class TestFTIEvents(MockTestCase):