mirror of
https://github.com/pre-commit/pre-commit.git
synced 2026-02-06 00:09:15 -06:00
Fixes lots of files problem. Closes #34
This commit is contained in:
@@ -1,16 +1,11 @@
|
||||
|
||||
from plumbum import local
|
||||
import subprocess
|
||||
|
||||
|
||||
def run_hook(env, hook, file_args):
|
||||
return env.run(
|
||||
' '.join([hook['entry']] + hook.get('args', []) + list(file_args)),
|
||||
retcode=None,
|
||||
)
|
||||
return env.run(
|
||||
' '.join(['xargs |', hook['entry']] + hook.get('args', [])),
|
||||
retcode=None,
|
||||
stdin='\n'.join(file_args) + '\n',
|
||||
' '.join(['xargs', hook['entry']] + hook.get('args', [])),
|
||||
stdin='\n'.join(list(file_args) + ['']),
|
||||
)
|
||||
|
||||
|
||||
@@ -29,9 +24,14 @@ class Environment(object):
|
||||
"""
|
||||
raise NotImplementedError
|
||||
|
||||
def run(self, cmd, **kwargs):
|
||||
def run(self, cmd, stdin=None, **kwargs):
|
||||
"""Returns (returncode, stdout, stderr)."""
|
||||
return local['bash'][
|
||||
'-c',
|
||||
' '.join([self.env_prefix, cmd])
|
||||
].run(**kwargs)
|
||||
proc = subprocess.Popen(
|
||||
['bash', '-c', ' '.join([self.env_prefix, cmd])],
|
||||
stdin=subprocess.PIPE,
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=subprocess.PIPE,
|
||||
)
|
||||
stdout, stderr = proc.communicate(stdin)
|
||||
|
||||
return proc.returncode, stdout, stderr
|
||||
|
||||
@@ -52,7 +52,6 @@ def test_run_a_python_hook(config_for_python_pre_commit_git_repo):
|
||||
assert ret[1] == "['/dev/null']\nHello World\n"
|
||||
|
||||
|
||||
@pytest.mark.xfail
|
||||
@pytest.mark.integration
|
||||
def test_run_a_hook_lots_of_files(config_for_python_pre_commit_git_repo):
|
||||
repo = Repository(config_for_python_pre_commit_git_repo)
|
||||
@@ -60,7 +59,6 @@ def test_run_a_hook_lots_of_files(config_for_python_pre_commit_git_repo):
|
||||
ret = repo.run_hook('foo', ['/dev/null'] * 15000)
|
||||
|
||||
assert ret[0] == 0
|
||||
assert ret[1] == 'Hello World\n'
|
||||
|
||||
|
||||
@pytest.mark.skipif(
|
||||
|
||||
Reference in New Issue
Block a user