Files
@ b36285f90f89
Branch filter:
Location: kallithea/rhodecode/tests/vcs/test_getslice.py - annotation
b36285f90f89
1.9 KiB
text/x-python
compare: rename optional compare_url parameter repo to other_repo
At the same time it is placed before other_ref_type and other_ref. Just to keep
a logical flow and (a new) consistency that will help the next refactoring.
At the same time it is placed before other_ref_type and other_ref. Just to keep
a logical flow and (a new) consistency that will help the next refactoring.
402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 402a96fcfa22 | 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()
|