mirror of
https://github.com/pre-commit/pre-commit.git
synced 2026-02-17 08:14:42 +04:00
Support hooks with custom node version.
This commit is contained in:
parent
4b98b39cea
commit
511de4fe32
8 changed files with 61 additions and 31 deletions
|
|
@ -2,9 +2,9 @@
|
||||||
sha: ca93f6834f2afc8a8f7de46c0e02076419077c7a
|
sha: ca93f6834f2afc8a8f7de46c0e02076419077c7a
|
||||||
hooks:
|
hooks:
|
||||||
- id: trailing-whitespace
|
- id: trailing-whitespace
|
||||||
files: \.(py|sh|yaml)$
|
files: \.(js|py|sh|yaml)$
|
||||||
- id: end-of-file-fixer
|
- id: end-of-file-fixer
|
||||||
files: \.(py|sh|yaml)$
|
files: \.(js|py|sh|yaml)$
|
||||||
- id: check-yaml
|
- id: check-yaml
|
||||||
files: \.(yaml|yml)$
|
files: \.(yaml|yml)$
|
||||||
- id: debug-statements
|
- id: debug-statements
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,6 @@
|
||||||
import contextlib
|
import contextlib
|
||||||
|
|
||||||
from pre_commit.languages import helpers
|
from pre_commit.languages import helpers
|
||||||
from pre_commit.languages import python
|
|
||||||
from pre_commit.prefixed_command_runner import CalledProcessError
|
from pre_commit.prefixed_command_runner import CalledProcessError
|
||||||
from pre_commit.util import clean_path_on_failure
|
from pre_commit.util import clean_path_on_failure
|
||||||
|
|
||||||
|
|
@ -9,14 +8,10 @@ from pre_commit.util import clean_path_on_failure
|
||||||
ENVIRONMENT_DIR = 'node_env'
|
ENVIRONMENT_DIR = 'node_env'
|
||||||
|
|
||||||
|
|
||||||
class NodeEnv(python.PythonEnv):
|
class NodeEnv(helpers.Environment):
|
||||||
@property
|
@property
|
||||||
def env_prefix(self):
|
def env_prefix(self):
|
||||||
base = super(NodeEnv, self).env_prefix
|
return '. {{prefix}}{0}/bin/activate &&'.format(ENVIRONMENT_DIR)
|
||||||
return ' '.join([
|
|
||||||
base,
|
|
||||||
'. {{prefix}}{0}/bin/activate &&'.format(ENVIRONMENT_DIR)]
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
@contextlib.contextmanager
|
@contextlib.contextmanager
|
||||||
|
|
@ -27,29 +22,31 @@ def in_env(repo_cmd_runner):
|
||||||
def install_environment(repo_cmd_runner, version='default'):
|
def install_environment(repo_cmd_runner, version='default'):
|
||||||
assert repo_cmd_runner.exists('package.json')
|
assert repo_cmd_runner.exists('package.json')
|
||||||
|
|
||||||
with clean_path_on_failure(repo_cmd_runner.path(python.ENVIRONMENT_DIR)):
|
env_dir = repo_cmd_runner.path(ENVIRONMENT_DIR)
|
||||||
repo_cmd_runner.run(
|
with clean_path_on_failure(env_dir):
|
||||||
['virtualenv', '{{prefix}}{0}'.format(python.ENVIRONMENT_DIR)],
|
if version == 'default':
|
||||||
)
|
# In the default case we attempt to install system node and if that
|
||||||
|
# doesn't work we use --prebuilt
|
||||||
|
try:
|
||||||
|
with clean_path_on_failure(env_dir):
|
||||||
|
repo_cmd_runner.run([
|
||||||
|
'nodeenv', '-n', 'system',
|
||||||
|
'{{prefix}}{0}'.format(ENVIRONMENT_DIR),
|
||||||
|
])
|
||||||
|
except CalledProcessError:
|
||||||
|
# TODO: log failure here
|
||||||
|
repo_cmd_runner.run([
|
||||||
|
'nodeenv', '--prebuilt',
|
||||||
|
'{{prefix}}{0}'.format(ENVIRONMENT_DIR)
|
||||||
|
])
|
||||||
|
else:
|
||||||
|
repo_cmd_runner.run([
|
||||||
|
'nodeenv', '--prebuilt', '-n', version,
|
||||||
|
'{{prefix}}{0}'.format(ENVIRONMENT_DIR)
|
||||||
|
])
|
||||||
|
|
||||||
with python.in_env(repo_cmd_runner) as python_env:
|
with in_env(repo_cmd_runner) as node_env:
|
||||||
python_env.run('pip install nodeenv')
|
node_env.run('cd {prefix} && npm install -g')
|
||||||
|
|
||||||
with clean_path_on_failure(repo_cmd_runner.path(ENVIRONMENT_DIR)):
|
|
||||||
# Try and use the system level node executable first
|
|
||||||
try:
|
|
||||||
with clean_path_on_failure(repo_cmd_runner.path(ENVIRONMENT_DIR)):
|
|
||||||
python_env.run(
|
|
||||||
'nodeenv -n system {{prefix}}{0}'.format(ENVIRONMENT_DIR),
|
|
||||||
)
|
|
||||||
except CalledProcessError:
|
|
||||||
# TODO: log failure here
|
|
||||||
python_env.run(
|
|
||||||
'nodeenv --jobs 4 {{prefix}}{0}'.format(ENVIRONMENT_DIR),
|
|
||||||
)
|
|
||||||
|
|
||||||
with in_env(repo_cmd_runner) as node_env:
|
|
||||||
node_env.run('cd {prefix} && npm install -g')
|
|
||||||
|
|
||||||
|
|
||||||
def run_hook(repo_cmd_runner, hook, file_args):
|
def run_hook(repo_cmd_runner, hook, file_args):
|
||||||
|
|
|
||||||
1
setup.py
1
setup.py
|
|
@ -33,6 +33,7 @@ setup(
|
||||||
'asottile.ordereddict',
|
'asottile.ordereddict',
|
||||||
'asottile.yaml',
|
'asottile.yaml',
|
||||||
'jsonschema',
|
'jsonschema',
|
||||||
|
'nodeenv>=0.9.4',
|
||||||
'plumbum',
|
'plumbum',
|
||||||
'pyyaml',
|
'pyyaml',
|
||||||
'simplejson',
|
'simplejson',
|
||||||
|
|
|
||||||
4
testing/resources/node_0_11_8_hooks_repo/bin/main.js
Normal file
4
testing/resources/node_0_11_8_hooks_repo/bin/main.js
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
#!/usr/bin/env node
|
||||||
|
|
||||||
|
console.log(process.version);
|
||||||
|
console.log('Hello World');
|
||||||
5
testing/resources/node_0_11_8_hooks_repo/hooks.yaml
Normal file
5
testing/resources/node_0_11_8_hooks_repo/hooks.yaml
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
- id: node-11-8-hook
|
||||||
|
name: Node 0.11.8 hook
|
||||||
|
entry: node-11-8-hook
|
||||||
|
language: node
|
||||||
|
language_version: 0.11.8
|
||||||
5
testing/resources/node_0_11_8_hooks_repo/package.json
Normal file
5
testing/resources/node_0_11_8_hooks_repo/package.json
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"name": "node-11-8-hook",
|
||||||
|
"version": "0.0.1",
|
||||||
|
"bin": {"node-11-8-hook": "./bin/main.js"}
|
||||||
|
}
|
||||||
|
|
@ -82,6 +82,11 @@ def node_hooks_repo(dummy_git_repo):
|
||||||
yield _make_repo(dummy_git_repo, 'node_hooks_repo')
|
yield _make_repo(dummy_git_repo, 'node_hooks_repo')
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.yield_fixture
|
||||||
|
def node_0_11_8_hooks_repo(dummy_git_repo):
|
||||||
|
yield _make_repo(dummy_git_repo, 'node_0_11_8_hooks_repo')
|
||||||
|
|
||||||
|
|
||||||
@pytest.yield_fixture
|
@pytest.yield_fixture
|
||||||
def ruby_hooks_repo(dummy_git_repo):
|
def ruby_hooks_repo(dummy_git_repo):
|
||||||
yield _make_repo(dummy_git_repo, 'ruby_hooks_repo')
|
yield _make_repo(dummy_git_repo, 'ruby_hooks_repo')
|
||||||
|
|
@ -128,6 +133,11 @@ def config_for_node_hooks_repo(node_hooks_repo):
|
||||||
yield _make_config(node_hooks_repo, 'foo', '\\.js$')
|
yield _make_config(node_hooks_repo, 'foo', '\\.js$')
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.yield_fixture
|
||||||
|
def config_for_node_0_11_8_hooks_repo(node_0_11_8_hooks_repo):
|
||||||
|
yield _make_config(node_0_11_8_hooks_repo, 'node-11-8-hook', '\\.js$')
|
||||||
|
|
||||||
|
|
||||||
@pytest.yield_fixture
|
@pytest.yield_fixture
|
||||||
def config_for_ruby_hooks_repo(ruby_hooks_repo):
|
def config_for_ruby_hooks_repo(ruby_hooks_repo):
|
||||||
yield _make_config(ruby_hooks_repo, 'ruby_hook', '\\.rb$')
|
yield _make_config(ruby_hooks_repo, 'ruby_hook', '\\.rb$')
|
||||||
|
|
|
||||||
|
|
@ -32,6 +32,14 @@ def test_run_versioned_hook(config_for_python3_hooks_repo, store):
|
||||||
assert ret[1] == "3.3\n['/dev/null']\nHello World\n"
|
assert ret[1] == "3.3\n['/dev/null']\nHello World\n"
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.integration
|
||||||
|
def test_run_versioned_node_hook(config_for_node_0_11_8_hooks_repo, store):
|
||||||
|
repo = Repository.create(config_for_node_0_11_8_hooks_repo, store)
|
||||||
|
ret = repo.run_hook('node-11-8-hook', ['/dev/null'])
|
||||||
|
assert ret[0] == 0
|
||||||
|
assert ret[1] == 'v0.11.8\nHello World\n'
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.integration
|
@pytest.mark.integration
|
||||||
def test_lots_of_files(config_for_python_hooks_repo, store):
|
def test_lots_of_files(config_for_python_hooks_repo, store):
|
||||||
repo = Repository.create(config_for_python_hooks_repo, store)
|
repo = Repository.create(config_for_python_hooks_repo, store)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue