Beispiel #1
0
 def test_eid_role(self):
     with self.admin_access.web_request() as req:
         context = self.context(req)
         self.assertEqual(
             rest_publish(context, ':eid:`%s`' % context.eid),
             '<p><a class="reference"'
             ' href="http://testing.fr/cubicweb/cwuser/admin">'
             '#%s</a></p>\n' % context.eid)
         self.assertEqual(
             rest_publish(context, ':eid:`%s:some text`' % context.eid),
             '<p><a class="reference"'
             ' href="http://testing.fr/cubicweb/cwuser/admin">'
             'some text</a></p>\n')
Beispiel #2
0
 def test_rql_role_with_unknown_vid(self):
     with self.admin_access.web_request() as req:
         context = self.context(req)
         out = rest_publish(context, ':rql:`Any X WHERE X is CWUser:toto`')
         self.assertTrue(
             out.startswith("<p>an error occurred while interpreting this "
                            "rql directive: ObjectNotFound('toto'"), out)
Beispiel #3
0
 def test_rqltable_nocontent(self):
     with self.admin_access.web_request() as req:
         context = self.context(req)
         out = rest_publish(context, """.. rql-table::""")
         self.assertIn("System Message: ERROR", out)
         self.assertIn(
             "Content block expected for the &quot;rql-table&quot; "
             "directive; none found", out)
Beispiel #4
0
    def test_disable_field_name_colspan(self):
        with self.admin_access.web_request() as req:
            context = self.context(req)
            value = rest_publish(
                context, '''my field list:

:a long dumb param name: value
''')
            self.assertNotIn('colspan', value)
Beispiel #5
0
 def test_rql_role_with_vid_empty_rset(self):
     with self.admin_access.web_request() as req:
         context = self.context(req)
         out = rest_publish(
             context,
             ':rql:`Any X WHERE X is CWUser, X login "nono":table`')
         self.assertTrue(
             out.endswith(
                 '<p><div class="searchMessage"><strong>'
                 'No result matching query</strong></div>\n</p>\n'))
Beispiel #6
0
 def test_rql_role_with_vid(self):
     with self.admin_access.web_request() as req:
         context = self.context(req)
         out = rest_publish(
             context,
             ':rql:`Any X ORDERBY XL WHERE X is CWUser, X login XL:table`')
         self.assertTrue(
             out.endswith(
                 '<a href="http://testing.fr/cubicweb/cwuser/anon" '
                 'title="">anon</a></td></tr>\n</tbody></table>'
                 '</div></p>\n'))
Beispiel #7
0
    def test_rqltable_norset(self):
        with self.admin_access.web_request() as req:
            context = self.context(req)
            rql = "Any X WHERE X is CWUser, X firstname 'franky'"
            out = rest_publish(
                context, """\
.. rql-table::

                %(rql)s""" % {'rql': rql})
            self.assertIn("System Message: WARNING", out)
            self.assertIn("empty result set", out)
Beispiel #8
0
 def test_rql_role_without_vid(self):
     with self.admin_access.web_request() as req:
         context = self.context(req)
         out = rest_publish(
             context,
             ':rql:`Any X,XL ORDERBY XL WHERE X is CWUser, X login XL`')
         self.assertEqual(
             out, u'<p><h1>CWUser_plural</h1><div class="section">'
             '<a href="http://testing.fr/cubicweb/cwuser/admin" title="">admin</a>'
             '</div><div class="section">'
             '<a href="http://testing.fr/cubicweb/cwuser/anon" title="">anon</a>'
             '</div></p>\n')
Beispiel #9
0
    def test_rqltable_nooptions(self):
        with self.admin_access.web_request() as req:
            rql = "Any S,F,L WHERE X is CWUser, X surname S, X firstname F, X login L"
            out = rest_publish(
                self.context(req), """\
.. rql-table::

   %(rql)s
                """ % {'rql': rql})
            view = self.vreg['views'].select('table',
                                             req,
                                             rset=req.execute(rql))
            self.assertEqual(view.render(w=None)[49:], out[49:])
Beispiel #10
0
    def test_bad_rest_no_crash(self):
        with self.admin_access.web_request() as req:
            rest_publish(
                self.context(req), '''
| card | implication     |
--------------------------
| 1-1  | N1 = N2         |
| 1-?  | N1 <= N2        |
| 1-+  | N1 >= N2        |
| 1-*  | N1>0 => N2>0    |
--------------------------
| ?-?  | N1 # N2         |
| ?-+  | N1 >= N2        |
| ?-*  | N1 #  N2        |
--------------------------
| +-+  | N1>0 => N2>0 et |
|      | N2>0 => N1>0    |
| +-*  | N1>+ => N2>0    |
--------------------------
| *-*  | N1#N2           |
--------------------------

''')
Beispiel #11
0
    def test_rqltable_badvid(self):
        with self.admin_access.web_request() as req:
            rql = "Any S,F,L WHERE X is CWUser, X surname S, X firstname F, X login L"
            vid = 'mytabel'
            out = rest_publish(
                self.context(req), """\
.. rql-table::
   :vid: %(vid)s

   %(rql)s
                """ % {
                    'rql': rql,
                    'vid': vid
                })
            self.assertIn("fail to select '%s' view" % vid, out)
Beispiel #12
0
 def test_bookmark_role(self):
     with self.admin_access.web_request() as req:
         context = self.context(req)
         rset = req.execute(
             'INSERT Bookmark X: X title "hello", X path '
             '"/view?rql=Any X,XL ORDERBY XL WHERE X is CWUser, X login XL"'
         )
         eid = rset[0][0]
         out = rest_publish(context, ':bookmark:`%s`' % eid)
         self.assertEqual(
             out, u'<p><h1>CWUser_plural</h1><div class="section">'
             '<a href="http://testing.fr/cubicweb/cwuser/admin" title="">admin'
             '</a></div><div class="section">'
             '<a href="http://testing.fr/cubicweb/cwuser/anon" title="">anon'
             '</a></div></p>\n')
Beispiel #13
0
    def test_rqltable_vid(self):
        with self.admin_access.web_request() as req:
            rql = "Any S,F,L WHERE X is CWUser, X surname S, X firstname F, X login L"
            vid = 'mytable'
            out = rest_publish(
                self.context(req), """\
.. rql-table::
   :vid: %(vid)s

   %(rql)s
                """ % {
                    'rql': rql,
                    'vid': vid
                })
            view = self.vreg['views'].select(vid, req, rset=req.execute(rql))
            self.assertEqual(view.render(w=None)[49:], out[49:])
            self.assertIn(vid, out[:49])
Beispiel #14
0
    def test_rqltable_headers_missing_edges(self):
        with self.admin_access.web_request() as req:
            rql = "Any S,F,L WHERE X is CWUser, X surname S, X firstname F, X login L"
            headers = [" ", "prenom", ""]
            out = rest_publish(
                self.context(req), """\
.. rql-table::
   :headers: %(headers)s

   %(rql)s
                """ % {
                    'rql': rql,
                    'headers': ', '.join(headers)
                })
            view = self.vreg['views'].select('table',
                                             req,
                                             rset=req.execute(rql))
            view.headers = [None, headers[1], None]
            self.assertEqual(view.render(w=None)[49:], out[49:])
Beispiel #15
0
    def test_rqltable_colvids(self):
        with self.admin_access.web_request() as req:
            rql = "Any X,S,F,L WHERE X is CWUser, X surname S, X firstname F, X login L"
            colvids = {0: "oneline"}
            out = rest_publish(
                self.context(req), """\
.. rql-table::
   :colvids: %(colvids)s

   %(rql)s
                """ % {
                    'rql':
                    rql,
                    'colvids':
                    ', '.join(["%d=%s" % (k, v) for k, v in colvids.items()])
                })
            view = self.vreg['views'].select('table',
                                             req,
                                             rset=req.execute(rql))
            view.cellvids = colvids
            self.assertEqual(view.render(w=None)[49:], out[49:])
Beispiel #16
0
 def test_card_role_link(self):
     self.request().create_entity('Card', wikiid=u'index', title=u'Site index page', synopsis=u'yo')
     self.assertEqual(rest_publish(self.context(), ':card:`index`'),
                       '<p><a class="reference" href="http://testing.fr/cubicweb/card/index">index</a></p>\n')
Beispiel #17
0
 def test_card_role_create_subpage(self):
     self.assertEqual(rest_publish(self.context(), ':card:`foo/bar`'),
                      '<p><a class="doesnotexist reference" href="http://testing.fr/cubicweb/card/foo/bar">foo/bar</a></p>\n')
Beispiel #18
0
 def test_card_role_create(self):
     self.assertEqual(rest_publish(self.context(), ':card:`index`'),
                       '<p><a class="doesnotexist reference" href="http://testing.fr/cubicweb/card/index">index</a></p>\n')