sapling/tests/test-hggit-url-parsing.py
Jun Wu a487dacc4b codemod: reformat rest of the code
Summary:
Previous code format attempt (D8173629) didn't cover all files due to `**/*.py`
was not expanded recursively by bash. That makes certain changes larger than
they should be (ex. D8675439). Now use zsh's `**/*.py` to format them.

Also fix Python syntax so black can run on more files, and all lint issues.

Reviewed By: phillco

Differential Revision: D8696912

fbshipit-source-id: 95f07aa0c5eb1b63947b0f77f534957f4ab65364
2018-07-05 17:52:43 -07:00

112 lines
4.1 KiB
Python

import shutil
import sys
import tempfile
from hgext.hggit.git_handler import GitHandler
from mercurial import commands, hg, ui
try:
import dulwich
type(dulwich) # avoid pyflakes unused import error
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()