dataimport/test/unittest_importer.py
changeset 10514 b29d9904482e
parent 10460 d260722f2453
child 10807 bb0c7dbd1fe7
--- a/dataimport/test/unittest_importer.py	Fri Jun 26 11:15:25 2015 +0200
+++ b/dataimport/test/unittest_importer.py	Fri Jun 26 15:00:07 2015 +0200
@@ -18,12 +18,13 @@
 
 from collections import defaultdict
 
-from logilab.common.testlib import unittest_main
+from logilab.common.testlib import TestCase, unittest_main
 
 from cubicweb import ValidationError
 from cubicweb.devtools.testlib import CubicWebTC
 from cubicweb.dataimport import RQLObjectStore, ucsvreader
-from cubicweb.dataimport.importer import ExtEntity, ExtEntitiesImporter, SimpleImportLog, RelationMapping
+from cubicweb.dataimport.importer import (ExtEntity, ExtEntitiesImporter, SimpleImportLog,
+                                          RelationMapping, use_extid_as_cwuri)
 
 
 class RelationMappingTC(CubicWebTC):
@@ -148,6 +149,22 @@
             self.assertEqual(entity.nom, u'Richelieu Cardinal')
 
 
+class UseExtidAsCwuriTC(TestCase):
+
+    def test(self):
+        personne = ExtEntity('Personne', 1, {'nom': set([u'de la lune']),
+                                             'prenom': set([u'Jean'])})
+        mapping = {}
+        set_cwuri = use_extid_as_cwuri(mapping)
+        list(set_cwuri((personne,)))
+        self.assertIn('cwuri', personne.values)
+        self.assertEqual(personne.values['cwuri'], set(['1']))
+        mapping[1] = 'whatever'
+        personne.values.pop('cwuri')
+        list(set_cwuri((personne,)))
+        self.assertNotIn('cwuri', personne.values)
+
+
 def extentities_from_csv(fpath):
     """Yield ExtEntity read from `fpath` CSV file."""
     with open(fpath) as f: