sapling/eden/scm/tests/test-hggit-url-parsing.py
Adam Simpkins ab3a7cb21f Move fb-mercurial sources into an eden/scm subdirectory.
Summary:
In preparation for merging fb-mercurial sources to the Eden repository,
move everything from the top-level directory into an `eden/scm`
subdirectory.
2019-11-13 16:04:48 -08:00

111 lines
4.1 KiB
Python

from __future__ import absolute_import
import shutil
import sys
import tempfile
from edenscm.mercurial import commands, hg, ui
try:
from edenscm.hgext.hggit.git_handler import GitHandler
except ImportError:
print("skipped: missing feature: dulwich")
sys.exit(80)
class TestUrlParsing(object):
def setUp(self):
# create a test repo location.
self.tmpdir = tempfile.mkdtemp("hg-git_url-test")
commands.init(ui.ui(), self.tmpdir)
repo = hg.repository(ui.ui(), self.tmpdir)
self.handler = GitHandler(repo, ui.ui())
def tearDown(self):
# remove the temp repo
shutil.rmtree(self.tmpdir)
def assertEquals(self, l, r):
print("%% expect %r" % (r,))
print(l)
assert l == r
def test_ssh_github_style_slash(self):
url = "git+ssh://git@github.com/webjam/webjam.git"
client, path = self.handler.get_transport_and_path(url)
self.assertEquals(path, "/webjam/webjam.git")
self.assertEquals(client.host, "git@github.com")
def test_ssh_github_style_colon_number_starting_username(self):
url = "git+ssh://git@github.com:42qu/vps.git"
client, path = self.handler.get_transport_and_path(url)
self.assertEquals(path, "42qu/vps.git")
self.assertEquals(client.host, "git@github.com")
def test_ssh_github_style_colon(self):
url = "git+ssh://git@github.com:webjam/webjam.git"
client, path = self.handler.get_transport_and_path(url)
self.assertEquals(path, "webjam/webjam.git")
self.assertEquals(client.host, "git@github.com")
def test_ssh_heroku_style(self):
url = "git+ssh://git@heroku.com:webjam.git"
client, path = self.handler.get_transport_and_path(url)
self.assertEquals(path, "webjam.git")
self.assertEquals(client.host, "git@heroku.com")
# also test that it works even if heroku isn't in the name
url = "git+ssh://git@compatible.com:webjam.git"
client, path = self.handler.get_transport_and_path(url)
self.assertEquals(path, "webjam.git")
self.assertEquals(client.host, "git@compatible.com")
def test_ssh_heroku_style_with_trailing_slash(self):
# some versions of mercurial add a trailing slash even if
# the user didn't supply one.
url = "git+ssh://git@heroku.com:webjam.git/"
client, path = self.handler.get_transport_and_path(url)
self.assertEquals(path, "webjam.git")
self.assertEquals(client.host, "git@heroku.com")
def test_heroku_style_with_port(self):
url = "git+ssh://git@heroku.com:999:webjam.git"
client, path = self.handler.get_transport_and_path(url)
self.assertEquals(path, "webjam.git")
self.assertEquals(client.host, "git@heroku.com")
self.assertEquals(client.port, "999")
def test_gitdaemon_style(self):
url = "git://github.com/webjam/webjam.git"
client, path = self.handler.get_transport_and_path(url)
self.assertEquals(path, "/webjam/webjam.git")
try:
self.assertEquals(client._host, "github.com")
except AttributeError:
self.assertEquals(client.host, "github.com")
def test_ssh_github_style_slash_with_port(self):
url = "git+ssh://git@github.com:10022/webjam/webjam.git"
client, path = self.handler.get_transport_and_path(url)
self.assertEquals(path, "/webjam/webjam.git")
self.assertEquals(client.host, "git@github.com")
self.assertEquals(client.port, "10022")
def test_gitdaemon_style_with_port(self):
url = "git://github.com:19418/webjam/webjam.git"
client, path = self.handler.get_transport_and_path(url)
self.assertEquals(path, "/webjam/webjam.git")
try:
self.assertEquals(client._host, "github.com")
except AttributeError:
self.assertEquals(client.host, "github.com")
self.assertEquals(client._port, "19418")
if __name__ == "__main__":
tc = TestUrlParsing()
for test in sorted([t for t in dir(tc) if t.startswith("test_")]):
tc.setUp()
getattr(tc, test)()
tc.tearDown()