server/test/unittest_schemaserial.py
branchtls-sprint
changeset 1787 71c143c0ada3
parent 1398 5fe84a5f7035
child 1977 606923dff11b
equal deleted inserted replaced
1786:eccd1885d42e 1787:71c143c0ada3
    14 config.bootstrap_cubes()
    14 config.bootstrap_cubes()
    15 loader.lib_directory = config.schemas_lib_dir()
    15 loader.lib_directory = config.schemas_lib_dir()
    16 schema = loader.load(config)
    16 schema = loader.load(config)
    17 
    17 
    18 from cubicweb.server.schemaserial import *
    18 from cubicweb.server.schemaserial import *
    19     
    19 
    20 class Schema2RQLTC(TestCase):
    20 class Schema2RQLTC(TestCase):
    21         
    21 
    22     def test_eschema2rql1(self):
    22     def test_eschema2rql1(self):
    23         self.assertListEquals(list(eschema2rql(schema.eschema('CWAttribute'))),
    23         self.assertListEquals(list(eschema2rql(schema.eschema('CWAttribute'))),
    24                               [
    24                               [
    25             ('INSERT CWEType X: X description %(description)s,X final %(final)s,X meta %(meta)s,X name %(name)s',
    25             ('INSERT CWEType X: X description %(description)s,X final %(final)s,X meta %(meta)s,X name %(name)s',
    26              {'description': u'define a final relation: link a final relation type from a non final entity to a final entity type. used to build the application schema',
    26              {'description': u'define a final relation: link a final relation type from a non final entity to a final entity type. used to build the application schema',
    27               'meta': True, 'name': u'CWAttribute', 'final': False})
    27               'meta': True, 'name': u'CWAttribute', 'final': False})
    28             ])
    28             ])
    29         
    29 
    30     def test_eschema2rql2(self):
    30     def test_eschema2rql2(self):
    31         self.assertListEquals(list(eschema2rql(schema.eschema('String'))), [
    31         self.assertListEquals(list(eschema2rql(schema.eschema('String'))), [
    32                 ('INSERT CWEType X: X description %(description)s,X final %(final)s,X meta %(meta)s,X name %(name)s',
    32                 ('INSERT CWEType X: X description %(description)s,X final %(final)s,X meta %(meta)s,X name %(name)s',
    33                  {'description': u'', 'final': True, 'meta': True, 'name': u'String'})])
    33                  {'description': u'', 'final': True, 'meta': True, 'name': u'String'})])
    34     
    34 
    35     def test_eschema2rql_specialization(self):
    35     def test_eschema2rql_specialization(self):
    36         self.assertListEquals(list(specialize2rql(schema)),
    36         self.assertListEquals(list(specialize2rql(schema)),
    37                               [
    37                               [
    38                 ('SET X specializes ET WHERE X name %(x)s, ET name %(et)s',
    38                 ('SET X specializes ET WHERE X name %(x)s, ET name %(et)s',
    39                  {'x': 'Division', 'et': 'Societe'}),
    39                  {'x': 'Division', 'et': 'Societe'}),
    40                 ('SET X specializes ET WHERE X name %(x)s, ET name %(et)s',
    40                 ('SET X specializes ET WHERE X name %(x)s, ET name %(et)s',
    41                  {'x': 'SubDivision', 'et': 'Division'})])
    41                  {'x': 'SubDivision', 'et': 'Division'})])
    42         
    42 
    43     def test_rschema2rql1(self):
    43     def test_rschema2rql1(self):
    44         self.assertListEquals(list(rschema2rql(schema.rschema('relation_type'))),
    44         self.assertListEquals(list(rschema2rql(schema.rschema('relation_type'))),
    45                              [
    45                              [
    46             ('INSERT CWRType X: X description %(description)s,X final %(final)s,X fulltext_container %(fulltext_container)s,X inlined %(inlined)s,X meta %(meta)s,X name %(name)s,X symetric %(symetric)s',
    46             ('INSERT CWRType X: X description %(description)s,X final %(final)s,X fulltext_container %(fulltext_container)s,X inlined %(inlined)s,X meta %(meta)s,X name %(name)s,X symetric %(symetric)s',
    47              {'description': u'link a relation definition to its relation type', 'meta': True, 'symetric': False, 'name': u'relation_type', 'final' : False, 'fulltext_container': None, 'inlined': True}),
    47              {'description': u'link a relation definition to its relation type', 'meta': True, 'symetric': False, 'name': u'relation_type', 'final' : False, 'fulltext_container': None, 'inlined': True}),
       
    48 
       
    49             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
       
    50              {'rt': 'relation_type', 'description': u'', 'composite': u'object', 'oe': 'CWRType',
       
    51               'ordernum': 1, 'cardinality': u'1*', 'se': 'CWRelation'}),
       
    52             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWRelation',
       
    53              {'rt': 'relation_type', 'oe': 'CWRType', 'ctname': u'RQLConstraint', 'se': 'CWRelation', 'value': u'O final FALSE'}),
       
    54 
    48             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    55             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    49              {'rt': 'relation_type', 'description': u'', 'composite': u'object', 'oe': 'CWRType',
    56              {'rt': 'relation_type', 'description': u'', 'composite': u'object', 'oe': 'CWRType',
    50               'ordernum': 1, 'cardinality': u'1*', 'se': 'CWAttribute'}),
    57               'ordernum': 1, 'cardinality': u'1*', 'se': 'CWAttribute'}),
    51             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWRelation',
    58             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWRelation',
    52              {'rt': 'relation_type', 'oe': 'CWRType', 'ctname': u'RQLConstraint', 'se': 'CWAttribute', 'value': u'O final TRUE'}),
    59              {'rt': 'relation_type', 'oe': 'CWRType', 'ctname': u'RQLConstraint', 'se': 'CWAttribute', 'value': u'O final TRUE'}),
       
    60             ])
       
    61 
       
    62     def test_rschema2rql2(self):
       
    63         self.assertListEquals(list(rschema2rql(schema.rschema('add_permission'))),
       
    64                               [
       
    65             ('INSERT CWRType X: X description %(description)s,X final %(final)s,X fulltext_container %(fulltext_container)s,X inlined %(inlined)s,X meta %(meta)s,X name %(name)s,X symetric %(symetric)s', {'description': u'core relation giving to a group the permission to add an entity or relation type', 'meta': True, 'symetric': False, 'name': u'add_permission', 'final': False, 'fulltext_container': None, 'inlined': False}),
       
    66 
    53             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    67             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    54              {'rt': 'relation_type', 'description': u'', 'composite': u'object', 'oe': 'CWRType',
    68              {'rt': 'add_permission', 'description': u'groups allowed to add entities/relations of this type', 'composite': None, 'oe': 'CWGroup', 'ordernum': 3, 'cardinality': u'**', 'se': 'CWEType'}),
    55               'ordernum': 1, 'cardinality': u'1*', 'se': 'CWRelation'}),
    69             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    56             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWRelation',
    70              {'rt': 'add_permission', 'description': u'groups allowed to add entities/relations of this type', 'composite': None, 'oe': 'CWGroup', 'ordernum': 3, 'cardinality': u'**', 'se': 'CWRType'}),
    57              {'rt': 'relation_type', 'oe': 'CWRType', 'ctname': u'RQLConstraint', 'se': 'CWRelation', 'value': u'O final FALSE'}),
    71 
    58             ])
       
    59         
       
    60     def test_rschema2rql2(self):
       
    61         expected = [
       
    62             ('INSERT CWRType X: X description %(description)s,X final %(final)s,X fulltext_container %(fulltext_container)s,X inlined %(inlined)s,X meta %(meta)s,X name %(name)s,X symetric %(symetric)s', {'description': u'core relation giving to a group the permission to add an entity or relation type', 'meta': True, 'symetric': False, 'name': u'add_permission', 'final': False, 'fulltext_container': None, 'inlined': False}),
       
    63             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    72             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    64              {'rt': 'add_permission', 'description': u'rql expression allowing to add entities/relations of this type', 'composite': 'subject', 'oe': 'RQLExpression', 'ordernum': 5, 'cardinality': u'*?', 'se': 'CWEType'}),
    73              {'rt': 'add_permission', 'description': u'rql expression allowing to add entities/relations of this type', 'composite': 'subject', 'oe': 'RQLExpression', 'ordernum': 5, 'cardinality': u'*?', 'se': 'CWEType'}),
    65             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    74             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    66              {'rt': 'add_permission', 'description': u'rql expression allowing to add entities/relations of this type', 'composite': 'subject', 'oe': 'RQLExpression', 'ordernum': 5, 'cardinality': u'*?', 'se': 'CWRType'}),
    75              {'rt': 'add_permission', 'description': u'rql expression allowing to add entities/relations of this type', 'composite': 'subject', 'oe': 'RQLExpression', 'ordernum': 5, 'cardinality': u'*?', 'se': 'CWRType'}),
    67             
    76             ])
    68             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    77 
    69              {'rt': 'add_permission', 'description': u'groups allowed to add entities/relations of this type', 'composite': None, 'oe': 'CWGroup', 'ordernum': 3, 'cardinality': u'**', 'se': 'CWEType'}),
       
    70             ('INSERT CWRelation X: X cardinality %(cardinality)s,X composite %(composite)s,X description %(description)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
       
    71              {'rt': 'add_permission', 'description': u'groups allowed to add entities/relations of this type', 'composite': None, 'oe': 'CWGroup', 'ordernum': 3, 'cardinality': u'**', 'se': 'CWRType'}),
       
    72             ]
       
    73         for i, (rql, args) in enumerate(rschema2rql(schema.rschema('add_permission'))):
       
    74             yield self.assertEquals, (rql, args), expected[i]
       
    75         
       
    76     def test_rschema2rql3(self):
    78     def test_rschema2rql3(self):
    77         self.assertListEquals(list(rschema2rql(schema.rschema('cardinality'))), 
    79         self.assertListEquals(list(rschema2rql(schema.rschema('cardinality'))),
    78                              [
    80                              [
    79             ('INSERT CWRType X: X description %(description)s,X final %(final)s,X fulltext_container %(fulltext_container)s,X inlined %(inlined)s,X meta %(meta)s,X name %(name)s,X symetric %(symetric)s',
    81             ('INSERT CWRType X: X description %(description)s,X final %(final)s,X fulltext_container %(fulltext_container)s,X inlined %(inlined)s,X meta %(meta)s,X name %(name)s,X symetric %(symetric)s',
    80              {'description': u'', 'meta': False, 'symetric': False, 'name': u'cardinality', 'final': True, 'fulltext_container': None, 'inlined': False}),
    82              {'description': u'', 'meta': False, 'symetric': False, 'name': u'cardinality', 'final': True, 'fulltext_container': None, 'inlined': False}),
       
    83 
       
    84             ('INSERT CWAttribute X: X cardinality %(cardinality)s,X defaultval %(defaultval)s,X description %(description)s,X fulltextindexed %(fulltextindexed)s,X indexed %(indexed)s,X internationalizable %(internationalizable)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
       
    85              {'rt': 'cardinality', 'description': u'subject/object cardinality', 'internationalizable': True, 'fulltextindexed': False, 'ordernum': 5, 'defaultval': None, 'indexed': False, 'cardinality': u'?1', 'oe': 'String', 'se': 'CWRelation'}),
       
    86             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWAttribute',
       
    87              {'rt': 'cardinality', 'oe': 'String', 'ctname': u'SizeConstraint', 'se': 'CWRelation', 'value': u'max=2'}),
       
    88             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWAttribute',
       
    89              {'rt': 'cardinality', 'oe': 'String', 'ctname': u'StaticVocabularyConstraint', 'se': 'CWRelation', 'value': u"u'?*', u'1*', u'+*', u'**', u'?+', u'1+', u'++', u'*+', u'?1', u'11', u'+1', u'*1', u'??', u'1?', u'+?', u'*?'"}),
    81 
    90 
    82             ('INSERT CWAttribute X: X cardinality %(cardinality)s,X defaultval %(defaultval)s,X description %(description)s,X fulltextindexed %(fulltextindexed)s,X indexed %(indexed)s,X internationalizable %(internationalizable)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    91             ('INSERT CWAttribute X: X cardinality %(cardinality)s,X defaultval %(defaultval)s,X description %(description)s,X fulltextindexed %(fulltextindexed)s,X indexed %(indexed)s,X internationalizable %(internationalizable)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
    83              {'rt': 'cardinality', 'description': u'subject/object cardinality', 'internationalizable': True, 'fulltextindexed': False, 'ordernum': 5, 'defaultval': None, 'indexed': False, 'cardinality': u'?1', 'oe': 'String', 'se': 'CWAttribute'}),
    92              {'rt': 'cardinality', 'description': u'subject/object cardinality', 'internationalizable': True, 'fulltextindexed': False, 'ordernum': 5, 'defaultval': None, 'indexed': False, 'cardinality': u'?1', 'oe': 'String', 'se': 'CWAttribute'}),
    84             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWAttribute',
    93             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWAttribute',
    85              {'rt': 'cardinality', 'oe': 'String', 'ctname': u'SizeConstraint', 'se': 'CWAttribute', 'value': u'max=2'}),
    94              {'rt': 'cardinality', 'oe': 'String', 'ctname': u'SizeConstraint', 'se': 'CWAttribute', 'value': u'max=2'}),
    86             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWAttribute',
    95             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWAttribute',
    87              {'rt': 'cardinality', 'oe': 'String', 'ctname': u'StaticVocabularyConstraint', 'se': 'CWAttribute', 'value': u"u'?1', u'11', u'??', u'1?'"}),
    96              {'rt': 'cardinality', 'oe': 'String', 'ctname': u'StaticVocabularyConstraint', 'se': 'CWAttribute', 'value': u"u'?1', u'11', u'??', u'1?'"}),
       
    97             ])
    88 
    98 
    89             ('INSERT CWAttribute X: X cardinality %(cardinality)s,X defaultval %(defaultval)s,X description %(description)s,X fulltextindexed %(fulltextindexed)s,X indexed %(indexed)s,X internationalizable %(internationalizable)s,X ordernum %(ordernum)s,X relation_type ER,X from_entity SE,X to_entity OE WHERE SE name %(se)s,ER name %(rt)s,OE name %(oe)s',
       
    90              {'rt': 'cardinality', 'description': u'subject/object cardinality', 'internationalizable': True, 'fulltextindexed': False, 'ordernum': 5, 'defaultval': None, 'indexed': False, 'cardinality': u'?1', 'oe': 'String', 'se': 'CWRelation'}),
       
    91             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWAttribute',
       
    92              {'rt': 'cardinality', 'oe': 'String', 'ctname': u'SizeConstraint', 'se': 'CWRelation', 'value': u'max=2'}),
       
    93             ('INSERT CWConstraint X: X value %(value)s, X cstrtype CT, EDEF constrained_by X WHERE CT name %(ctname)s, EDEF relation_type ER, EDEF from_entity SE, EDEF to_entity OE, ER name %(rt)s, SE name %(se)s, OE name %(oe)s, EDEF is CWAttribute',
       
    94              {'rt': 'cardinality', 'oe': 'String', 'ctname': u'StaticVocabularyConstraint', 'se': 'CWRelation', 'value': u"u'?*', u'1*', u'+*', u'**', u'?+', u'1+', u'++', u'*+', u'?1', u'11', u'+1', u'*1', u'??', u'1?', u'+?', u'*?'"}),
       
    95             ])
       
    96         
       
    97 
    99 
    98     def test_updateeschema2rql1(self):
   100     def test_updateeschema2rql1(self):
    99         self.assertListEquals(list(updateeschema2rql(schema.eschema('CWAttribute'))),
   101         self.assertListEquals(list(updateeschema2rql(schema.eschema('CWAttribute'))),
   100                               [('SET X description %(description)s,X final %(final)s,X meta %(meta)s,X name %(name)s WHERE X is CWEType, X name %(et)s',
   102                               [('SET X description %(description)s,X final %(final)s,X meta %(meta)s,X name %(name)s WHERE X is CWEType, X name %(et)s',
   101                                 {'description': u'define a final relation: link a final relation type from a non final entity to a final entity type. used to build the application schema', 'meta': True, 'et': 'CWAttribute', 'final': False, 'name': u'CWAttribute'}),
   103                                 {'description': u'define a final relation: link a final relation type from a non final entity to a final entity type. used to build the application schema', 'meta': True, 'et': 'CWAttribute', 'final': False, 'name': u'CWAttribute'}),
   102                                ])
   104                                ])
   103         
   105 
   104     def test_updateeschema2rql2(self):
   106     def test_updateeschema2rql2(self):
   105         self.assertListEquals(list(updateeschema2rql(schema.eschema('String'))),
   107         self.assertListEquals(list(updateeschema2rql(schema.eschema('String'))),
   106                               [('SET X description %(description)s,X final %(final)s,X meta %(meta)s,X name %(name)s WHERE X is CWEType, X name %(et)s',
   108                               [('SET X description %(description)s,X final %(final)s,X meta %(meta)s,X name %(name)s WHERE X is CWEType, X name %(et)s',
   107                                 {'description': u'', 'meta': True, 'et': 'String', 'final': True, 'name': u'String'})
   109                                 {'description': u'', 'meta': True, 'et': 'String', 'final': True, 'name': u'String'})
   108                                ])
   110                                ])
   109         
   111 
   110     def test_updaterschema2rql1(self):
   112     def test_updaterschema2rql1(self):
   111         self.assertListEquals(list(updaterschema2rql(schema.rschema('relation_type'))),
   113         self.assertListEquals(list(updaterschema2rql(schema.rschema('relation_type'))),
   112                              [
   114                              [
   113             ('SET X description %(description)s,X final %(final)s,X fulltext_container %(fulltext_container)s,X inlined %(inlined)s,X meta %(meta)s,X name %(name)s,X symetric %(symetric)s WHERE X is CWRType, X name %(rt)s',
   115             ('SET X description %(description)s,X final %(final)s,X fulltext_container %(fulltext_container)s,X inlined %(inlined)s,X meta %(meta)s,X name %(name)s,X symetric %(symetric)s WHERE X is CWRType, X name %(rt)s',
   114              {'rt': 'relation_type', 'symetric': False,
   116              {'rt': 'relation_type', 'symetric': False,
   115               'description': u'link a relation definition to its relation type',
   117               'description': u'link a relation definition to its relation type',
   116               'meta': True, 'final': False, 'fulltext_container': None, 'inlined': True, 'name': u'relation_type'})
   118               'meta': True, 'final': False, 'fulltext_container': None, 'inlined': True, 'name': u'relation_type'})
   117             ])
   119             ])
   118         
   120 
   119     def test_updaterschema2rql2(self):
   121     def test_updaterschema2rql2(self):
   120         expected = [
   122         expected = [
   121             ('SET X description %(description)s,X final %(final)s,X fulltext_container %(fulltext_container)s,X inlined %(inlined)s,X meta %(meta)s,X name %(name)s,X symetric %(symetric)s WHERE X is CWRType, X name %(rt)s',
   123             ('SET X description %(description)s,X final %(final)s,X fulltext_container %(fulltext_container)s,X inlined %(inlined)s,X meta %(meta)s,X name %(name)s,X symetric %(symetric)s WHERE X is CWRType, X name %(rt)s',
   122              {'rt': 'add_permission', 'symetric': False,
   124              {'rt': 'add_permission', 'symetric': False,
   123               'description': u'core relation giving to a group the permission to add an entity or relation type',
   125               'description': u'core relation giving to a group the permission to add an entity or relation type',
   131         'managers': 0,
   133         'managers': 0,
   132         'users':  1,
   134         'users':  1,
   133         'guests': 2,
   135         'guests': 2,
   134         'owners': 3,
   136         'owners': 3,
   135         }
   137         }
   136     
   138 
   137     def test_eperms2rql1(self):
   139     def test_eperms2rql1(self):
   138         self.assertListEquals([rql for rql, kwargs in erperms2rql(schema.eschema('CWEType'), self.GROUP_MAPPING)],
   140         self.assertListEquals([rql for rql, kwargs in erperms2rql(schema.eschema('CWEType'), self.GROUP_MAPPING)],
   139                               ['SET X read_permission Y WHERE X is CWEType, X name "CWEType", Y eid 2',
   141                               ['SET X read_permission Y WHERE X is CWEType, X name "CWEType", Y eid 2',
   140                                'SET X read_permission Y WHERE X is CWEType, X name "CWEType", Y eid 0',
   142                                'SET X read_permission Y WHERE X is CWEType, X name "CWEType", Y eid 0',
   141                                'SET X read_permission Y WHERE X is CWEType, X name "CWEType", Y eid 1',
   143                                'SET X read_permission Y WHERE X is CWEType, X name "CWEType", Y eid 1',
   142                                'SET X add_permission Y WHERE X is CWEType, X name "CWEType", Y eid 0',
   144                                'SET X add_permission Y WHERE X is CWEType, X name "CWEType", Y eid 0',
   143                                'SET X update_permission Y WHERE X is CWEType, X name "CWEType", Y eid 0',
   145                                'SET X update_permission Y WHERE X is CWEType, X name "CWEType", Y eid 0',
   144                                'SET X update_permission Y WHERE X is CWEType, X name "CWEType", Y eid 3',
   146                                'SET X update_permission Y WHERE X is CWEType, X name "CWEType", Y eid 3',
   145                                'SET X delete_permission Y WHERE X is CWEType, X name "CWEType", Y eid 0',
   147                                'SET X delete_permission Y WHERE X is CWEType, X name "CWEType", Y eid 0',
   146                                ])
   148                                ])
   147         
   149 
   148     def test_rperms2rql2(self):
   150     def test_rperms2rql2(self):
   149         self.assertListEquals([rql for rql, kwargs in erperms2rql(schema.rschema('read_permission'), self.GROUP_MAPPING)],
   151         self.assertListEquals([rql for rql, kwargs in erperms2rql(schema.rschema('read_permission'), self.GROUP_MAPPING)],
   150                               ['SET X read_permission Y WHERE X is CWRType, X name "read_permission", Y eid 2',
   152                               ['SET X read_permission Y WHERE X is CWRType, X name "read_permission", Y eid 2',
   151                                'SET X read_permission Y WHERE X is CWRType, X name "read_permission", Y eid 0',
   153                                'SET X read_permission Y WHERE X is CWRType, X name "read_permission", Y eid 0',
   152                                'SET X read_permission Y WHERE X is CWRType, X name "read_permission", Y eid 1',
   154                                'SET X read_permission Y WHERE X is CWRType, X name "read_permission", Y eid 1',
   153                                'SET X add_permission Y WHERE X is CWRType, X name "read_permission", Y eid 0',
   155                                'SET X add_permission Y WHERE X is CWRType, X name "read_permission", Y eid 0',
   154                                'SET X delete_permission Y WHERE X is CWRType, X name "read_permission", Y eid 0',
   156                                'SET X delete_permission Y WHERE X is CWRType, X name "read_permission", Y eid 0',
   155                                ])
   157                                ])
   156         
   158 
   157     def test_rperms2rql3(self):
   159     def test_rperms2rql3(self):
   158         self.assertListEquals([rql for rql, kwargs in erperms2rql(schema.rschema('name'), self.GROUP_MAPPING)],
   160         self.assertListEquals([rql for rql, kwargs in erperms2rql(schema.rschema('name'), self.GROUP_MAPPING)],
   159                               ['SET X read_permission Y WHERE X is CWRType, X name "name", Y eid 2',
   161                               ['SET X read_permission Y WHERE X is CWRType, X name "name", Y eid 2',
   160                                'SET X read_permission Y WHERE X is CWRType, X name "name", Y eid 0',
   162                                'SET X read_permission Y WHERE X is CWRType, X name "name", Y eid 0',
   161                                'SET X read_permission Y WHERE X is CWRType, X name "name", Y eid 1',
   163                                'SET X read_permission Y WHERE X is CWRType, X name "name", Y eid 1',
   164                                'SET X add_permission Y WHERE X is CWRType, X name "name", Y eid 1',
   166                                'SET X add_permission Y WHERE X is CWRType, X name "name", Y eid 1',
   165                                'SET X delete_permission Y WHERE X is CWRType, X name "name", Y eid 2',
   167                                'SET X delete_permission Y WHERE X is CWRType, X name "name", Y eid 2',
   166                                'SET X delete_permission Y WHERE X is CWRType, X name "name", Y eid 0',
   168                                'SET X delete_permission Y WHERE X is CWRType, X name "name", Y eid 0',
   167                                'SET X delete_permission Y WHERE X is CWRType, X name "name", Y eid 1',
   169                                'SET X delete_permission Y WHERE X is CWRType, X name "name", Y eid 1',
   168                                ])
   170                                ])
   169         
   171 
   170     #def test_perms2rql(self):
   172     #def test_perms2rql(self):
   171     #    self.assertListEquals(perms2rql(schema, self.GROUP_MAPPING),
   173     #    self.assertListEquals(perms2rql(schema, self.GROUP_MAPPING),
   172     #                         ['INSERT CWEType X: X name 'Societe', X final FALSE'])
   174     #                         ['INSERT CWEType X: X name 'Societe', X final FALSE'])
   173         
   175 
   174 
   176 
   175 
   177 
   176 if __name__ == '__main__':
   178 if __name__ == '__main__':
   177     unittest_main()
   179     unittest_main()