diff -r 000000000000 -r b97547f5f1fa web/test/unittest_views_baseviews.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/web/test/unittest_views_baseviews.py Wed Nov 05 15:52:50 2008 +0100 @@ -0,0 +1,108 @@ +from simplejson import loads + +from logilab.common.testlib import unittest_main +from logilab.mtconverter import html_unescape + +from cubicweb.devtools.apptest import EnvBasedTC + +from cubicweb.web.htmlwidgets import TableWidget +from cubicweb.web.views.baseviews import vid_from_rset + +def loadjson(value): + return loads(html_unescape(value)) + +class VidFromRsetTC(EnvBasedTC): + + def test_no_rset(self): + req = self.request() + self.assertEquals(vid_from_rset(req, None, self.schema), 'index') + + def test_no_entity(self): + req = self.request() + rset = self.execute('Any X WHERE X login "blabla"') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'noresult') + + def test_one_entity(self): + req = self.request() + rset = self.execute('Any X WHERE X login "admin"') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'primary') + rset = self.execute('Any X, L WHERE X login "admin", X login L') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'primary') + req.search_state = ('pasnormal',) + rset = self.execute('Any X WHERE X login "admin"') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'outofcontext-search') + + def test_one_entity_eid(self): + req = self.request() + rset = self.execute('Any X WHERE X eid 1') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'primary') + + def test_more_than_one_entity(self): + req = self.request() + rset = self.execute('Any X WHERE X is EUser') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'list') + rset = self.execute('Any X, L WHERE X login L') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'list') + + def test_more_than_one_entity_by_row(self): + req = self.request() + rset = self.execute('Any X, G WHERE X in_group G') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'table') + + def test_more_than_one_entity_by_row_2(self): + req = self.request() + rset = self.execute('Any X, GN WHERE X in_group G, G name GN') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'table') + + def test_aggregat(self): + req = self.request() + rset = self.execute('Any X, COUNT(T) GROUPBY X WHERE X is T') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'table') + rset = self.execute('Any MAX(X) WHERE X is EUser') + self.assertEquals(vid_from_rset(req, rset, self.schema), 'table') + + def test_subquery(self): + rset = self.execute( +'DISTINCT Any X,N ORDERBY N ' +'WITH X,N BEING (' +' (DISTINCT Any P,N WHERE P is EUser, P login N)' +' UNION' +' (DISTINCT Any W,N WHERE W is EGroup, W name N))') + req = self.request() + self.assertEquals(vid_from_rset(req, rset, self.schema), 'table') + + +class TableViewTC(EnvBasedTC): + + def _prepare_entity(self): + e = self.add_entity("State", name=u'', description=u'loo"ong blabla') + rset = self.execute('Any X, D, CD, NOW - CD WHERE X is State, X description D, X creation_date CD, X eid %(x)s', + {'x': e.eid}, 'x') + req = self.request() + view = self.vreg.select_view('table', req, rset) + return e, rset, view + + def test_headers(self): + self.skip('implement me') + + def test_sortvalue(self): + e, _, view = self._prepare_entity() + expected = ['', 'loo"ong blabla'[:10], e.creation_date.strftime('%Y-%m-%d %H:%M')] + got = [loadjson(view.sortvalue(0, i)) for i in xrange(3)] + self.assertListEqual(got, expected) + # XXX sqlite does not handle Interval correctly + # value = loadjson(view.sortvalue(0, 3)) + # self.assertAlmostEquals(value, rset.rows[0][3].seconds) + + def test_sortvalue_with_display_col(self): + e, rset, view = self._prepare_entity() + rqlstdescr = rset.syntax_tree().get_description()[0] # XXX missing Union support + table = TableWidget(view) + table.columns = view.get_columns(rqlstdescr, [1, 2], None, None, None, None, 0) + expected = ['loo"ong blabla'[:10], e.creation_date.strftime('%Y-%m-%d %H:%M')] + got = [loadjson(value) for _, value in table.itercols(0)] + self.assertListEqual(got, expected) + + +if __name__ == '__main__': + unittest_main()