##// END OF EJS Templates
fixed issues some people had with whoosh indexers and unicode decode...
fixed issues some people had with whoosh indexers and unicode decode errors when building os paths

File last commit:

r2451:402a96fc beta
r3016:b3c8a3a5 beta
Show More
test_getslice.py
56 lines | 1.9 KiB | text/x-python | PythonLexer
Added vcs testsuite for better integration tests + added fetching...
r2451 from __future__ import with_statement
import datetime
from base import BackendTestMixin
from conf import SCM_TESTS
from rhodecode.lib.vcs.nodes import FileNode
from rhodecode.lib.vcs.utils.compat import unittest
class GetsliceTestCaseMixin(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__getslice__last_item_is_tip(self):
self.assertEqual(list(self.repo[-1:])[0], self.repo.get_changeset())
def test__getslice__respects_start_index(self):
self.assertEqual(list(self.repo[2:]),
[self.repo.get_changeset(rev) for rev in self.repo.revisions[2:]])
def test__getslice__respects_negative_start_index(self):
self.assertEqual(list(self.repo[-2:]),
[self.repo.get_changeset(rev) for rev in self.repo.revisions[-2:]])
def test__getslice__respects_end_index(self):
self.assertEqual(list(self.repo[:2]),
[self.repo.get_changeset(rev) for rev in self.repo.revisions[:2]])
def test__getslice__respects_negative_end_index(self):
self.assertEqual(list(self.repo[:-2]),
[self.repo.get_changeset(rev) for rev in self.repo.revisions[:-2]])
# For each backend create test case class
for alias in SCM_TESTS:
attrs = {
'backend_alias': alias,
}
cls_name = ''.join(('%s getslice test' % alias).title().split())
bases = (GetsliceTestCaseMixin, unittest.TestCase)
globals()[cls_name] = type(cls_name, bases, attrs)
if __name__ == '__main__':
unittest.main()