[dataimport] backout 6947201033be (related to #2788402)
(and add a try: except to cache the intended error)
The problem actually comes from the ``MassiveObjectStore``
in the ``dataio`` cube, so it should be corrected there.
Here, we only protect it with a ``RuntimeWarning`` so that
the user can see the problem.
``value`` is set to ``None`` (whence to ``NULL`` from
a database standpoint), so that the data can be nevertheless
inserted in the database. However, only the keys present in
``row`` are actually non-'``NULL``'.
The real solution is to work out the issue in ``MassiveObjectStore``
directly.
The current try/except should only be a temporary hack.
# copyright 2003-2010 LOGILAB S.A. (Paris, FRANCE), all rights reserved.# contact http://www.logilab.fr/ -- mailto:contact@logilab.fr## This file is part of CubicWeb.## CubicWeb is free software: you can redistribute it and/or modify it under the# terms of the GNU Lesser General Public License as published by the Free# Software Foundation, either version 2.1 of the License, or (at your option)# any later version.## CubicWeb is distributed in the hope that it will be useful, but WITHOUT# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more# details.## You should have received a copy of the GNU Lesser General Public License along# with CubicWeb. If not, see <http://www.gnu.org/licenses/>."""some basic stuff to build dot generated graph images"""__docformat__="restructuredtext en"_=unicodeimporttempfileimportosfromlogilab.mtconverterimportxml_escapefromlogilab.common.graphimportGraphGenerator,DotBackendfromcubicweb.viewimportEntityViewfromcubicweb.utilsimportmake_uidclassDotGraphView(EntityView):__abstract__=Truebackend_class=DotBackendbackend_kwargs={'ratio':'compress','size':'30,10'}defcell_call(self,row,col):entity=self.cw_rset.get_entity(row,col)visitor=self.build_visitor(entity)prophdlr=self.build_dotpropshandler()graphname='dotgraph%s'%str(entity.eid)generator=GraphGenerator(self.backend_class(graphname,None,**self.backend_kwargs))# map filepmap,mapfile=tempfile.mkstemp(".map",graphname)os.close(pmap)# image filefd,tmpfile=tempfile.mkstemp('.png')os.close(fd)generator.generate(visitor,prophdlr,tmpfile,mapfile)filekeyid=make_uid()self._cw.session.data[filekeyid]=tmpfileself.w(u'<img src="%s" alt="%s" usemap="#%s" />'%(xml_escape(entity.absolute_url(vid='tmppng',tmpfile=filekeyid)),xml_escape(self._cw._('Data connection graph for %s')%entity.dc_title()),graphname))stream=open(mapfile,'r').read()stream=stream.decode(self._cw.encoding)self.w(stream)os.unlink(mapfile)defbuild_visitor(self,entity):raiseNotImplementedErrordefbuild_dotpropshandler(self):returnDotPropsHandler(self._cw)classDotPropsHandler(object):def__init__(self,req):self._=req._defnode_properties(self,entity):"""return default DOT drawing options for a state or transition"""return{'label':entity.dc_long_title(),'href':entity.absolute_url(),'fontname':'Courier','fontsize':10,'shape':'box',}defedge_properties(self,transition,fromstate,tostate):return{'label':'','dir':'forward','color':'black','style':'filled'}