2022-01-16 08:24:05 +08:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2021-07-08 02:06:01 +08:00
|
|
|
import shutil
|
2015-12-26 01:25:14 +08:00
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
2015-01-01 04:21:21 +08:00
|
|
|
from pre_commit_hooks.check_added_large_files import find_large_added_files
|
|
|
|
from pre_commit_hooks.check_added_large_files import main
|
2015-03-21 04:52:21 +08:00
|
|
|
from pre_commit_hooks.util import cmd_output
|
2021-06-23 08:10:13 +08:00
|
|
|
from testing.util import git_commit
|
2015-01-01 04:21:21 +08:00
|
|
|
|
|
|
|
|
|
|
|
def test_nothing_added(temp_git_dir):
|
2016-05-28 05:09:50 +08:00
|
|
|
with temp_git_dir.as_cwd():
|
2015-01-01 04:21:21 +08:00
|
|
|
assert find_large_added_files(['f.py'], 0) == 0
|
|
|
|
|
|
|
|
|
|
|
|
def test_adding_something(temp_git_dir):
|
2016-05-28 05:09:50 +08:00
|
|
|
with temp_git_dir.as_cwd():
|
|
|
|
temp_git_dir.join('f.py').write("print('hello world')")
|
2015-03-21 04:52:21 +08:00
|
|
|
cmd_output('git', 'add', 'f.py')
|
2015-01-01 04:21:21 +08:00
|
|
|
|
|
|
|
# Should fail with max size of 0
|
|
|
|
assert find_large_added_files(['f.py'], 0) == 1
|
|
|
|
|
|
|
|
|
|
|
|
def test_add_something_giant(temp_git_dir):
|
2016-05-28 05:09:50 +08:00
|
|
|
with temp_git_dir.as_cwd():
|
|
|
|
temp_git_dir.join('f.py').write('a' * 10000)
|
2015-01-01 04:21:21 +08:00
|
|
|
|
|
|
|
# Should not fail when not added
|
|
|
|
assert find_large_added_files(['f.py'], 0) == 0
|
|
|
|
|
2015-03-21 04:52:21 +08:00
|
|
|
cmd_output('git', 'add', 'f.py')
|
2015-01-01 04:21:21 +08:00
|
|
|
|
|
|
|
# Should fail with strict bound
|
|
|
|
assert find_large_added_files(['f.py'], 0) == 1
|
|
|
|
|
|
|
|
# Should also fail with actual bound
|
|
|
|
assert find_large_added_files(['f.py'], 9) == 1
|
|
|
|
|
|
|
|
# Should pass with higher bound
|
|
|
|
assert find_large_added_files(['f.py'], 10) == 0
|
|
|
|
|
|
|
|
|
2020-09-16 13:26:11 +08:00
|
|
|
def test_enforce_all(temp_git_dir):
|
|
|
|
with temp_git_dir.as_cwd():
|
|
|
|
temp_git_dir.join('f.py').write('a' * 10000)
|
|
|
|
|
|
|
|
# Should fail, when not staged with enforce_all
|
|
|
|
assert find_large_added_files(['f.py'], 0, enforce_all=True) == 1
|
|
|
|
|
|
|
|
# Should pass, when not staged without enforce_all
|
|
|
|
assert find_large_added_files(['f.py'], 0, enforce_all=False) == 0
|
|
|
|
|
|
|
|
|
2015-01-01 04:21:21 +08:00
|
|
|
def test_added_file_not_in_pre_commits_list(temp_git_dir):
|
2016-05-28 05:09:50 +08:00
|
|
|
with temp_git_dir.as_cwd():
|
|
|
|
temp_git_dir.join('f.py').write("print('hello world')")
|
2015-03-21 04:52:21 +08:00
|
|
|
cmd_output('git', 'add', 'f.py')
|
2015-01-01 04:21:21 +08:00
|
|
|
|
|
|
|
# Should pass even with a size of 0
|
|
|
|
assert find_large_added_files(['g.py'], 0) == 0
|
|
|
|
|
|
|
|
|
|
|
|
def test_integration(temp_git_dir):
|
2016-05-28 05:09:50 +08:00
|
|
|
with temp_git_dir.as_cwd():
|
2015-01-01 04:21:21 +08:00
|
|
|
assert main(argv=[]) == 0
|
|
|
|
|
2016-05-28 05:09:50 +08:00
|
|
|
temp_git_dir.join('f.py').write('a' * 10000)
|
2015-03-21 04:52:21 +08:00
|
|
|
cmd_output('git', 'add', 'f.py')
|
2015-01-01 04:21:21 +08:00
|
|
|
|
|
|
|
# Should not fail with default
|
|
|
|
assert main(argv=['f.py']) == 0
|
|
|
|
|
|
|
|
# Should fail with --maxkb
|
|
|
|
assert main(argv=['--maxkb', '9', 'f.py']) == 1
|
2015-12-26 01:25:14 +08:00
|
|
|
|
|
|
|
|
|
|
|
def has_gitlfs():
|
2021-07-08 02:06:01 +08:00
|
|
|
return shutil.which('git-lfs') is not None
|
2015-12-26 01:25:14 +08:00
|
|
|
|
|
|
|
|
|
|
|
xfailif_no_gitlfs = pytest.mark.xfail(
|
|
|
|
not has_gitlfs(), reason='This test requires git-lfs',
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@xfailif_no_gitlfs
|
2021-12-21 12:09:53 +08:00
|
|
|
def test_allows_gitlfs(temp_git_dir): # pragma: no cover
|
2016-05-28 05:09:50 +08:00
|
|
|
with temp_git_dir.as_cwd():
|
2021-12-21 12:09:53 +08:00
|
|
|
cmd_output('git', 'lfs', 'install', '--local')
|
2016-05-28 05:09:50 +08:00
|
|
|
temp_git_dir.join('f.py').write('a' * 10000)
|
2015-12-26 01:25:14 +08:00
|
|
|
cmd_output('git', 'lfs', 'track', 'f.py')
|
2016-06-13 00:49:44 +08:00
|
|
|
cmd_output('git', 'add', '--', '.')
|
2015-12-26 01:25:14 +08:00
|
|
|
# Should succeed
|
|
|
|
assert main(('--maxkb', '9', 'f.py')) == 0
|
|
|
|
|
|
|
|
|
|
|
|
@xfailif_no_gitlfs
|
2021-12-21 12:09:53 +08:00
|
|
|
def test_moves_with_gitlfs(temp_git_dir): # pragma: no cover
|
2016-05-28 05:09:50 +08:00
|
|
|
with temp_git_dir.as_cwd():
|
2021-12-21 12:09:53 +08:00
|
|
|
cmd_output('git', 'lfs', 'install', '--local')
|
2015-12-26 01:25:14 +08:00
|
|
|
cmd_output('git', 'lfs', 'track', 'a.bin', 'b.bin')
|
|
|
|
# First add the file we're going to move
|
2016-05-28 05:09:50 +08:00
|
|
|
temp_git_dir.join('a.bin').write('a' * 10000)
|
2016-06-13 00:49:44 +08:00
|
|
|
cmd_output('git', 'add', '--', '.')
|
2021-06-23 08:10:13 +08:00
|
|
|
git_commit('-am', 'foo')
|
2015-12-26 01:25:14 +08:00
|
|
|
# Now move it and make sure the hook still succeeds
|
|
|
|
cmd_output('git', 'mv', 'a.bin', 'b.bin')
|
|
|
|
assert main(('--maxkb', '9', 'b.bin')) == 0
|
2020-09-16 13:26:11 +08:00
|
|
|
|
|
|
|
|
|
|
|
@xfailif_no_gitlfs
|
2021-12-21 12:09:53 +08:00
|
|
|
def test_enforce_allows_gitlfs(temp_git_dir): # pragma: no cover
|
2020-09-16 13:26:11 +08:00
|
|
|
with temp_git_dir.as_cwd():
|
2021-12-21 12:09:53 +08:00
|
|
|
cmd_output('git', 'lfs', 'install', '--local')
|
2020-09-16 13:26:11 +08:00
|
|
|
temp_git_dir.join('f.py').write('a' * 10000)
|
|
|
|
cmd_output('git', 'lfs', 'track', 'f.py')
|
|
|
|
cmd_output('git', 'add', '--', '.')
|
|
|
|
# With --enforce-all large files on git lfs should succeed
|
|
|
|
assert main(('--enforce-all', '--maxkb', '9', 'f.py')) == 0
|
2021-10-22 06:29:54 +08:00
|
|
|
|
|
|
|
|
2021-12-21 12:09:53 +08:00
|
|
|
@xfailif_no_gitlfs
|
|
|
|
def test_enforce_allows_gitlfs_after_commit(temp_git_dir): # pragma: no cover
|
2021-10-22 06:29:54 +08:00
|
|
|
with temp_git_dir.as_cwd():
|
2021-12-21 12:09:53 +08:00
|
|
|
cmd_output('git', 'lfs', 'install', '--local')
|
2021-10-22 06:29:54 +08:00
|
|
|
temp_git_dir.join('f.py').write('a' * 10000)
|
|
|
|
cmd_output('git', 'lfs', 'track', 'f.py')
|
|
|
|
cmd_output('git', 'add', '--', '.')
|
|
|
|
git_commit('-am', 'foo')
|
|
|
|
# With --enforce-all large files on git lfs should succeed
|
|
|
|
assert main(('--enforce-all', '--maxkb', '9', 'f.py')) == 0
|