##// END OF EJS Templates
Don't cache dulwich Repos, in pararell multithreaded evniroment dulwich pack file openers...
Don't cache dulwich Repos, in pararell multithreaded evniroment dulwich pack file openers can break badly. We need to create Repo() objects always for each call, even when it's taken from cache. Fixed issue with dulwich filedescriptor leak ref #573

File last commit:

r2995:32471bd1 beta
r3043:b61824e6 beta
Show More
test_repository.py
216 lines | 6.1 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 conf import TEST_USER_CONFIG_FILE
from rhodecode.lib.vcs.nodes import FileNode
from rhodecode.lib.vcs.utils.compat import unittest
from rhodecode.lib.vcs.exceptions import ChangesetDoesNotExistError
class RepositoryBaseTest(BackendTestMixin):
recreate_repo_per_test = False
@classmethod
def _get_commits(cls):
return super(RepositoryBaseTest, cls)._get_commits()[:1]
def test_get_config_value(self):
self.assertEqual(self.repo.get_config_value('universal', 'foo',
TEST_USER_CONFIG_FILE), 'bar')
def test_get_config_value_defaults_to_None(self):
self.assertEqual(self.repo.get_config_value('universal', 'nonexist',
TEST_USER_CONFIG_FILE), None)
def test_get_user_name(self):
self.assertEqual(self.repo.get_user_name(TEST_USER_CONFIG_FILE),
'Foo Bar')
def test_get_user_email(self):
self.assertEqual(self.repo.get_user_email(TEST_USER_CONFIG_FILE),
'foo.bar@example.com')
class RepositoryGetDiffTest(BackendTestMixin):
@classmethod
def _get_commits(cls):
commits = [
{
'message': 'Initial commit',
'author': 'Joe Doe <joe.doe@example.com>',
'date': datetime.datetime(2010, 1, 1, 20),
'added': [
FileNode('foobar', content='foobar'),
FileNode('foobar2', content='foobar2'),
],
},
{
'message': 'Changed foobar, added foobar3',
'author': 'Jane Doe <jane.doe@example.com>',
'date': datetime.datetime(2010, 1, 1, 21),
'added': [
FileNode('foobar3', content='foobar3'),
],
'changed': [
FileNode('foobar', 'FOOBAR'),
],
},
{
'message': 'Removed foobar, changed foobar3',
'author': 'Jane Doe <jane.doe@example.com>',
'date': datetime.datetime(2010, 1, 1, 22),
'changed': [
FileNode('foobar3', content='FOOBAR\nFOOBAR\nFOOBAR\n'),
],
'removed': [FileNode('foobar')],
},
]
return commits
def test_raise_for_wrong(self):
with self.assertRaises(ChangesetDoesNotExistError):
self.repo.get_diff('a' * 40, 'b' * 40)
Implemented generation of changesets based...
r2995
Added vcs testsuite for better integration tests + added fetching...
r2451 class GitRepositoryGetDiffTest(RepositoryGetDiffTest, unittest.TestCase):
backend_alias = 'git'
def test_initial_commit_diff(self):
initial_rev = self.repo.revisions[0]
self.assertEqual(self.repo.get_diff(self.repo.EMPTY_CHANGESET, initial_rev), '''diff --git a/foobar b/foobar
new file mode 100644
Implemented generation of changesets based...
r2995 index 0000000000000000000000000000000000000000..f6ea0495187600e7b2288c8ac19c5886383a4632
Added vcs testsuite for better integration tests + added fetching...
r2451 --- /dev/null
+++ b/foobar
@@ -0,0 +1 @@
+foobar
\ No newline at end of file
diff --git a/foobar2 b/foobar2
new file mode 100644
Implemented generation of changesets based...
r2995 index 0000000000000000000000000000000000000000..e8c9d6b98e3dce993a464935e1a53f50b56a3783
Added vcs testsuite for better integration tests + added fetching...
r2451 --- /dev/null
+++ b/foobar2
@@ -0,0 +1 @@
+foobar2
\ No newline at end of file
''')
def test_second_changeset_diff(self):
revs = self.repo.revisions
self.assertEqual(self.repo.get_diff(revs[0], revs[1]), '''diff --git a/foobar b/foobar
Implemented generation of changesets based...
r2995 index f6ea0495187600e7b2288c8ac19c5886383a4632..389865bb681b358c9b102d79abd8d5f941e96551 100644
Added vcs testsuite for better integration tests + added fetching...
r2451 --- a/foobar
+++ b/foobar
@@ -1 +1 @@
-foobar
\ No newline at end of file
+FOOBAR
\ No newline at end of file
diff --git a/foobar3 b/foobar3
new file mode 100644
Implemented generation of changesets based...
r2995 index 0000000000000000000000000000000000000000..c11c37d41d33fb47741cff93fa5f9d798c1535b0
Added vcs testsuite for better integration tests + added fetching...
r2451 --- /dev/null
+++ b/foobar3
@@ -0,0 +1 @@
+foobar3
\ No newline at end of file
''')
def test_third_changeset_diff(self):
revs = self.repo.revisions
self.assertEqual(self.repo.get_diff(revs[1], revs[2]), '''diff --git a/foobar b/foobar
deleted file mode 100644
Implemented generation of changesets based...
r2995 index 389865bb681b358c9b102d79abd8d5f941e96551..0000000000000000000000000000000000000000
Added vcs testsuite for better integration tests + added fetching...
r2451 --- a/foobar
+++ /dev/null
@@ -1 +0,0 @@
-FOOBAR
\ No newline at end of file
diff --git a/foobar3 b/foobar3
Implemented generation of changesets based...
r2995 index c11c37d41d33fb47741cff93fa5f9d798c1535b0..f9324477362684ff692aaf5b9a81e01b9e9a671c 100644
Added vcs testsuite for better integration tests + added fetching...
r2451 --- a/foobar3
+++ b/foobar3
@@ -1 +1,3 @@
-foobar3
\ No newline at end of file
+FOOBAR
+FOOBAR
+FOOBAR
''')
class HgRepositoryGetDiffTest(RepositoryGetDiffTest, unittest.TestCase):
backend_alias = 'hg'
def test_initial_commit_diff(self):
initial_rev = self.repo.revisions[0]
self.assertEqual(self.repo.get_diff(self.repo.EMPTY_CHANGESET, initial_rev), '''diff --git a/foobar b/foobar
new file mode 100755
--- /dev/null
+++ b/foobar
@@ -0,0 +1,1 @@
+foobar
\ No newline at end of file
diff --git a/foobar2 b/foobar2
new file mode 100755
--- /dev/null
+++ b/foobar2
@@ -0,0 +1,1 @@
+foobar2
\ No newline at end of file
''')
def test_second_changeset_diff(self):
revs = self.repo.revisions
self.assertEqual(self.repo.get_diff(revs[0], revs[1]), '''diff --git a/foobar b/foobar
--- a/foobar
+++ b/foobar
@@ -1,1 +1,1 @@
-foobar
\ No newline at end of file
+FOOBAR
\ No newline at end of file
diff --git a/foobar3 b/foobar3
new file mode 100755
--- /dev/null
+++ b/foobar3
@@ -0,0 +1,1 @@
+foobar3
\ No newline at end of file
''')
def test_third_changeset_diff(self):
revs = self.repo.revisions
self.assertEqual(self.repo.get_diff(revs[1], revs[2]), '''diff --git a/foobar b/foobar
deleted file mode 100755
--- a/foobar
+++ /dev/null
@@ -1,1 +0,0 @@
-FOOBAR
\ No newline at end of file
diff --git a/foobar3 b/foobar3
--- a/foobar3
+++ b/foobar3
@@ -1,1 +1,3 @@
-foobar3
\ No newline at end of file
+FOOBAR
+FOOBAR
+FOOBAR
''')
# For each backend create test case class
for alias in SCM_TESTS:
attrs = {
'backend_alias': alias,
}
cls_name = alias.capitalize() + RepositoryBaseTest.__name__
bases = (RepositoryBaseTest, unittest.TestCase)
globals()[cls_name] = type(cls_name, bases, attrs)
if __name__ == '__main__':
unittest.main()