1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- """Compatibility tests between Dulwich and the cgit server.
- Warning: these tests should be fairly stable, but when writing/debugging new
- tests, deadlocks may freeze the test process such that it cannot be
- Ctrl-C'ed. On POSIX systems, you can kill the tests with Ctrl-Z, "kill %".
- """
- import os
- import sys
- import threading
- from dulwich.server import DictBackend, TCPGitServer
- from .. import skipIf
- from .server_utils import NoSideBand64kReceivePackHandler, ServerTests
- from .utils import CompatTestCase, require_git_version
- @skipIf(sys.platform == "win32", "Broken on windows, with very long fail time.")
- class GitServerTestCase(ServerTests, CompatTestCase):
- """Tests for client/server compatibility.
- This server test case does not use side-band-64k in git-receive-pack.
- """
- protocol = "git"
- def _handlers(self):
- return {b"git-receive-pack": NoSideBand64kReceivePackHandler}
- def _check_server(self, dul_server):
- receive_pack_handler_cls = dul_server.handlers[b"git-receive-pack"]
- caps = receive_pack_handler_cls.capabilities()
- self.assertNotIn(b"side-band-64k", caps)
- def _start_server(self, repo):
- backend = DictBackend({b"/": repo})
- dul_server = TCPGitServer(backend, b"localhost", 0, handlers=self._handlers())
- self._check_server(dul_server)
- self.addCleanup(dul_server.shutdown)
- self.addCleanup(dul_server.server_close)
- threading.Thread(target=dul_server.serve).start()
- self._server = dul_server
- _, port = self._server.socket.getsockname()
- return port
- @skipIf(sys.platform == "win32", "Broken on windows, with very long fail time.")
- class GitServerSideBand64kTestCase(GitServerTestCase):
- """Tests for client/server compatibility with side-band-64k support."""
-
- min_git_version = (1, 7, 0, 2)
- def setUp(self):
- super().setUp()
-
-
-
- if os.name == "nt":
- require_git_version((1, 9, 3))
- def _handlers(self):
- return None
- def _check_server(self, server):
- receive_pack_handler_cls = server.handlers[b"git-receive-pack"]
- caps = receive_pack_handler_cls.capabilities()
- self.assertIn(b"side-band-64k", caps)
|