##// END OF EJS Templates
API cli should prefer to display errors instead of responses
API cli should prefer to display errors instead of responses

File last commit:

r3797:d7488551 beta
r3896:8dae2a28 beta
Show More
test_getitem.py
44 lines | 1.4 KiB | text/x-python | PythonLexer
Added vcs testsuite for better integration tests + added fetching...
r2451 from __future__ import with_statement
import datetime
synced vcs with upstream...
r3797 from rhodecode.tests.vcs.base import BackendTestMixin
from rhodecode.tests.vcs.conf import SCM_TESTS
Added vcs testsuite for better integration tests + added fetching...
r2451 from rhodecode.lib.vcs.nodes import FileNode
from rhodecode.lib.vcs.utils.compat import unittest
class GetitemTestCaseMixin(BackendTestMixin):
@classmethod
def _get_commits(cls):
start_date = datetime.datetime(2010, 1, 1, 20)
for x in xrange(5):
yield {
'message': 'Commit %d' % x,
'author': 'Joe Doe <joe.doe@example.com>',
'date': start_date + datetime.timedelta(hours=12 * x),
'added': [
FileNode('file_%d.txt' % x, content='Foobar %d' % x),
],
}
def test__getitem__last_item_is_tip(self):
self.assertEqual(self.repo[-1], self.repo.get_changeset())
def test__getitem__returns_correct_items(self):
changesets = [self.repo[x] for x in xrange(len(self.repo.revisions))]
self.assertEqual(changesets, list(self.repo.get_changesets()))
# For each backend create test case class
for alias in SCM_TESTS:
attrs = {
'backend_alias': alias,
}
cls_name = ''.join(('%s getitem test' % alias).title().split())
bases = (GetitemTestCaseMixin, unittest.TestCase)
globals()[cls_name] = type(cls_name, bases, attrs)
if __name__ == '__main__':
unittest.main()