Mercurial > p > roundup > code
view test/test_xmlrpc.py @ 3909:e89bcb28f683
indexargs_url force ids to int
ids appear as hyperdb.String instances, which confused indexargs_url when they
appear in the filterspec. They need to be treated as treated as integers when
generating URLs.
It feels sort of hacky to check for 'id' like this but I'm at a loss for what
else to do in this case. Suggestions are welcome :)
Maybe we should look into using some other hyperdb class to represent ids?
this fixes [SF#783492]
Some trailing whitespace also got trimmed.
| author | Justus Pendleton <jpend@users.sourceforge.net> |
|---|---|
| date | Tue, 18 Sep 2007 16:59:42 +0000 |
| parents | cf6c45201980 |
| children | 3c3077582c16 |
line wrap: on
line source
# # Copyright (C) 2007 Stefan Seefeld # All rights reserved. # For license terms see the file COPYING.txt. # import unittest, os, shutil, errno, sys, difflib, cgi, re from roundup.cgi.exceptions import * from roundup import init, instance, password, hyperdb, date from roundup.xmlrpc import RoundupServer import db_test_base NEEDS_INSTANCE = 1 class TestCaseBase(unittest.TestCase): def setUp(self): self.dirname = '_test_xmlrpc' # set up and open a tracker self.instance = db_test_base.setupTracker(self.dirname) # open the database self.db = self.instance.open('admin') self.db.user.create(username='joe', password=password.Password('random'), address='random@home.org', realname='Joe Random', roles='User') self.db.commit() self.db.close() self.server = RoundupServer(self.dirname) def tearDown(self): try: shutil.rmtree(self.dirname) except OSError, error: if error.errno not in (errno.ENOENT, errno.ESRCH): raise class AccessTestCase(TestCaseBase): def test(self): # Retrieve all three users. results = self.server.list('joe', 'random', 'user', 'id') self.assertEqual(len(results), 3) # Obtain data for 'joe'. userid = 'user' + results[-1] results = self.server.display('joe', 'random', userid) self.assertEqual(results['username'], 'joe') self.assertEqual(results['realname'], 'Joe Random') # Reset joe's 'realname'. results = self.server.set('joe', 'random', userid, 'realname=Joe Doe') results = self.server.display('joe', 'random', userid, 'realname') self.assertEqual(results['realname'], 'Joe Doe') # Create test results = self.server.create('joe', 'random', 'issue', 'title=foo') issueid = 'issue' + results results = self.server.display('joe', 'random', issueid, 'title') self.assertEqual(results['title'], 'foo') class AuthenticationTestCase(TestCaseBase): def test(self): # Unknown user (caught in XMLRPC frontend). self.assertRaises(Unauthorised, self.server.list, 'nobody', 'nobody', 'user', 'id') # Wrong permissions (caught by roundup security module). results = self.server.list('joe', 'random', 'user', 'id') userid = 'user' + results[0] # admin self.assertRaises(Unauthorised, self.server.set, 'joe', 'random', userid, 'realname=someone') def test_suite(): suite = unittest.TestSuite() suite.addTest(unittest.makeSuite(AccessTestCase)) suite.addTest(unittest.makeSuite(AuthenticationTestCase)) return suite if __name__ == '__main__': runner = unittest.TextTestRunner() unittest.main(testRunner=runner)
