[sql generation] fix bug with inlined relation and referenced by other neged relation
we should check in that the column is not null in such cases
# 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/>.
"""
"""
from cubicweb.goa.testlib import *
import time
from mx.DateTime import DateTimeType
from datetime import datetime
from cubicweb.goa import db
from google.appengine.api import datastore
class Article(db.Model):
content = db.TextProperty()
synopsis = db.StringProperty(default='hello')
class Blog(db.Model):
diem = db.DateProperty(required=True, auto_now_add=True)
title = db.StringProperty(required=True)
content = db.TextProperty()
talks_about = db.ReferenceProperty(Article)
cites = db.SelfReferenceProperty()
class MetaDataTC(GAEBasedTC):
MODEL_CLASSES = (Article, Blog)
def setUp(self):
GAEBasedTC.setUp(self)
self.req = self.request()
self.a = self.add_entity('Article')
self.p = self.add_entity('CWProperty', pkey=u'ui.language', value=u'en')
self.session.commit()
def _test_timestamp(self, entity, attr, sleep=0.1):
timestamp = getattr(entity, attr)
self.failUnless(timestamp)
self.assertIsInstance(timestamp, DateTimeType)
self.assertIsInstance(entity.to_gae_model()['s_'+attr], datetime)
time.sleep(sleep)
if entity.id == 'Article':
entity.set_attributes(content=u'zou')
else:
entity.set_attributes(value=u'en')
self.session.commit()
return timestamp
def test_creation_date_dbmodel(self):
cdate = self._test_timestamp(self.a, 'creation_date')
self.assertEquals(cdate, self.a.creation_date)
def test_creation_date_yams(self):
cdate = self._test_timestamp(self.p, 'creation_date')
self.assertEquals(cdate, self.p.creation_date)
def test_modification_date_dbmodel(self):
mdate = self._test_timestamp(self.a, 'modification_date', sleep=1)
a = self.execute('Any X WHERE X eid %(x)s', {'x': self.a.eid}, 'x').get_entity(0, 0)
self.failUnless(mdate < a.modification_date, (mdate, a.modification_date))
def test_modification_date_yams(self):
mdate = self._test_timestamp(self.p, 'modification_date', sleep=1)
p = self.execute('Any X WHERE X eid %(x)s', {'x': self.p.eid}, 'x').get_entity(0, 0)
self.failUnless(mdate < p.modification_date, (mdate, p.modification_date))
def _test_owned_by(self, entity):
self.assertEquals(len(entity.owned_by), 1)
owner = entity.owned_by[0]
self.assertIsInstance(owner, db.Model)
dbmodel = entity.to_gae_model()
self.assertEquals(len(dbmodel['s_owned_by']), 1)
self.assertIsInstance(dbmodel['s_owned_by'][0], datastore.Key)
def test_owned_by_dbmodel(self):
self._test_owned_by(self.a)
def test_owned_by_yams(self):
self._test_owned_by(self.p)
def _test_created_by(self, entity):
self.assertEquals(len(entity.created_by), 1)
creator = entity.created_by[0]
self.assertIsInstance(creator, db.Model)
self.assertIsInstance(entity.to_gae_model()['s_created_by'], datastore.Key)
def test_created_by_dbmodel(self):
self._test_created_by(self.a)
def test_created_by_dbmodel(self):
self._test_created_by(self.p)
def test_user_owns_dbmodel(self):
self.failUnless(self.req.user.owns(self.a.eid))
def test_user_owns_yams(self):
self.failUnless(self.req.user.owns(self.p.eid))
def test_is_relation(self):
en = self.execute('Any EN WHERE E name EN, X is E, X eid %(x)s', {'x': self.a.eid}, 'x')[0][0]
self.assertEquals(en, 'Article')
en = self.execute('Any EN WHERE E name EN, X is E, X eid %(x)s', {'x': self.p.eid}, 'x')[0][0]
self.assertEquals(en, 'CWProperty')
en = self.execute('Any EN WHERE E name EN, X is E, X eid %(x)s', {'x': self.req.user.eid}, 'x')[0][0]
self.assertEquals(en, 'CWUser')
if __name__ == '__main__':
from logilab.common.testlib import unittest_main
unittest_main()