summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorSebastian Thiel <sebastian.thiel@icloud.com>2021-05-26 07:37:20 +0800
committerGitHub <noreply@github.com>2021-05-26 07:37:20 +0800
commit17643e0bd1b65155412ba5dba8f995a4f0080188 (patch)
tree81677cb062f30badff8ae37fbe05234d4d6908a7 /test
parenteae0e37c88a71a3b8ca816b820eed71fd1590f11 (diff)
parent1a04c15b1f77f908b1dd3983a27ee49c41b3a3e5 (diff)
downloadgitpython-17643e0bd1b65155412ba5dba8f995a4f0080188.tar.gz
Merge pull request #1254 from tmzullinger/index-mode-fix
improve index mode for executable files
Diffstat (limited to 'test')
-rw-r--r--test/test_fun.py15
1 files changed, 13 insertions, 2 deletions
diff --git a/test/test_fun.py b/test/test_fun.py
index a7fb8f8b..e3d07194 100644
--- a/test/test_fun.py
+++ b/test/test_fun.py
@@ -1,5 +1,5 @@
from io import BytesIO
-from stat import S_IFDIR, S_IFREG, S_IFLNK
+from stat import S_IFDIR, S_IFREG, S_IFLNK, S_IXUSR
from os import stat
import os.path as osp
from unittest import SkipTest
@@ -7,7 +7,8 @@ from unittest import SkipTest
from git import Git
from git.index import IndexFile
from git.index.fun import (
- aggressive_tree_merge
+ aggressive_tree_merge,
+ stat_mode_to_index_mode,
)
from git.objects.fun import (
traverse_tree_recursive,
@@ -206,6 +207,16 @@ class TestFun(TestBase):
assert_entries(aggressive_tree_merge(odb, trees), 2, True)
# END handle ours, theirs
+ def test_stat_mode_to_index_mode(self):
+ modes = (
+ 0o600, 0o611, 0o640, 0o641, 0o644, 0o650, 0o651,
+ 0o700, 0o711, 0o740, 0o744, 0o750, 0o751, 0o755,
+ )
+ for mode in modes:
+ expected_mode = S_IFREG | (mode & S_IXUSR and 0o755 or 0o644)
+ assert stat_mode_to_index_mode(mode) == expected_mode
+ # END for each mode
+
def _assert_tree_entries(self, entries, num_trees):
for entry in entries:
assert len(entry) == num_trees