mirror of
https://github.com/minetest/contentdb.git
synced 2025-01-03 19:57:29 +01:00
Add tests for git utils
This commit is contained in:
parent
4bb35953b1
commit
94bf83c611
@ -1 +0,0 @@
|
||||
# This makes app/tests a package
|
0
app/tests/integ/__init__.py
Normal file
0
app/tests/integ/__init__.py
Normal file
0
app/tests/unit/__init__.py
Normal file
0
app/tests/unit/__init__.py
Normal file
53
app/tests/unit/test_git.py
Normal file
53
app/tests/unit/test_git.py
Normal file
@ -0,0 +1,53 @@
|
||||
import os
|
||||
|
||||
from app.utils.git import get_latest_tag, get_latest_commit, clone_repo
|
||||
|
||||
|
||||
test_repo = "https://gitlab.com/rubenwardy/testmod"
|
||||
master_head = "3df40453cd6bb14a069f109b0cc7bbbc275c445c"
|
||||
test_branch_head = "51b54f00c3b3d712417a1cc4bfaa6cbdc7aac3fc"
|
||||
v4_commit = "c07d27c3a466d2102d1ba5473d172c74e6b3e0d7"
|
||||
random_commit = "84a2e53ff046eacbdbb80f3a00c58510885fefca"
|
||||
|
||||
|
||||
def test_get_latest_tag():
|
||||
tag, commit = get_latest_tag(test_repo)
|
||||
assert tag == "v4"
|
||||
assert commit == v4_commit
|
||||
|
||||
|
||||
def test_get_latest_commit():
|
||||
assert get_latest_commit(test_repo) == master_head
|
||||
assert get_latest_commit(test_repo, "test-branch") == test_branch_head
|
||||
|
||||
|
||||
def test_git_clone_head():
|
||||
with clone_repo(test_repo, recursive=True) as repo:
|
||||
assert repo.head.commit.hexsha == master_head
|
||||
assert os.path.isfile(os.path.join(repo.working_tree_dir, "init.lua"))
|
||||
assert os.path.isfile(os.path.join(repo.working_tree_dir, "chatcmdbuilder", "init.lua"))
|
||||
assert not os.path.isfile(os.path.join(repo.working_tree_dir, "test-branch.txt"))
|
||||
|
||||
|
||||
def test_git_clone_branch():
|
||||
with clone_repo(test_repo, "test-branch", recursive=True) as repo:
|
||||
assert repo.head.commit.hexsha == test_branch_head
|
||||
assert os.path.isfile(os.path.join(repo.working_tree_dir, "init.lua"))
|
||||
assert os.path.isfile(os.path.join(repo.working_tree_dir, "chatcmdbuilder", "init.lua"))
|
||||
assert os.path.isfile(os.path.join(repo.working_tree_dir, "test-branch.txt"))
|
||||
|
||||
|
||||
def test_git_clone_tag():
|
||||
with clone_repo(test_repo, "v4", recursive=True) as repo:
|
||||
assert repo.head.commit.hexsha == v4_commit
|
||||
assert os.path.isfile(os.path.join(repo.working_tree_dir, "init.lua"))
|
||||
assert not os.path.isfile(os.path.join(repo.working_tree_dir, "chatcmdbuilder", "init.lua"))
|
||||
assert not os.path.isfile(os.path.join(repo.working_tree_dir, "test-branch.txt"))
|
||||
|
||||
|
||||
def test_git_clone_commit():
|
||||
with clone_repo(test_repo, random_commit, recursive=True) as repo:
|
||||
assert repo.head.commit.hexsha == random_commit
|
||||
assert os.path.isfile(os.path.join(repo.working_tree_dir, "init.lua"))
|
||||
assert not os.path.isfile(os.path.join(repo.working_tree_dir, "chatcmdbuilder", "init.lua"))
|
||||
assert not os.path.isfile(os.path.join(repo.working_tree_dir, "test-branch.txt"))
|
@ -60,8 +60,9 @@ def clone_repo(urlstr, ref=None, recursive=False):
|
||||
origin.fetch()
|
||||
repo.git.checkout(ref)
|
||||
|
||||
for submodule in repo.submodules:
|
||||
submodule.update(init=True)
|
||||
if recursive:
|
||||
for submodule in repo.submodules:
|
||||
submodule.update(init=True)
|
||||
|
||||
yield repo
|
||||
shutil.rmtree(gitDir)
|
||||
|
Loading…
Reference in New Issue
Block a user