mirror of
https://github.com/pre-commit/pre-commit.git
synced 2026-02-17 08:14:42 +04:00
commit
50cf02764c
12 changed files with 96 additions and 143 deletions
1
testing/resources/ruby_hooks_repo/.gitignore
vendored
1
testing/resources/ruby_hooks_repo/.gitignore
vendored
|
|
@ -1 +0,0 @@
|
||||||
*.gem
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
- id: ruby_hook
|
|
||||||
name: Ruby Hook
|
|
||||||
entry: ruby_hook
|
|
||||||
language: ruby
|
|
||||||
files: \.rb$
|
|
||||||
|
|
@ -1,3 +0,0 @@
|
||||||
#!/usr/bin/env ruby
|
|
||||||
|
|
||||||
puts 'Hello world from a ruby hook'
|
|
||||||
|
|
@ -1,9 +0,0 @@
|
||||||
Gem::Specification.new do |s|
|
|
||||||
s.name = 'ruby_hook'
|
|
||||||
s.version = '0.1.0'
|
|
||||||
s.authors = ['Anthony Sottile']
|
|
||||||
s.summary = 'A ruby hook!'
|
|
||||||
s.description = 'A ruby hook!'
|
|
||||||
s.files = ['bin/ruby_hook']
|
|
||||||
s.executables = ['ruby_hook']
|
|
||||||
end
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
*.gem
|
|
||||||
|
|
@ -1,6 +0,0 @@
|
||||||
- id: ruby_hook
|
|
||||||
name: Ruby Hook
|
|
||||||
entry: ruby_hook
|
|
||||||
language: ruby
|
|
||||||
language_version: 3.2.0
|
|
||||||
files: \.rb$
|
|
||||||
|
|
@ -1,4 +0,0 @@
|
||||||
#!/usr/bin/env ruby
|
|
||||||
|
|
||||||
puts RUBY_VERSION
|
|
||||||
puts 'Hello world from a ruby hook'
|
|
||||||
|
|
@ -1,9 +0,0 @@
|
||||||
Gem::Specification.new do |s|
|
|
||||||
s.name = 'ruby_hook'
|
|
||||||
s.version = '0.1.0'
|
|
||||||
s.authors = ['Anthony Sottile']
|
|
||||||
s.summary = 'A ruby hook!'
|
|
||||||
s.description = 'A ruby hook!'
|
|
||||||
s.files = ['bin/ruby_hook']
|
|
||||||
s.executables = ['ruby_hook']
|
|
||||||
end
|
|
||||||
|
|
@ -1,6 +1,5 @@
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
import os.path
|
|
||||||
import tarfile
|
import tarfile
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
|
|
||||||
|
|
@ -8,10 +7,12 @@ import pytest
|
||||||
|
|
||||||
import pre_commit.constants as C
|
import pre_commit.constants as C
|
||||||
from pre_commit import parse_shebang
|
from pre_commit import parse_shebang
|
||||||
|
from pre_commit.envcontext import envcontext
|
||||||
from pre_commit.languages import ruby
|
from pre_commit.languages import ruby
|
||||||
from pre_commit.prefix import Prefix
|
from pre_commit.store import _make_local_repo
|
||||||
from pre_commit.util import cmd_output
|
|
||||||
from pre_commit.util import resource_bytesio
|
from pre_commit.util import resource_bytesio
|
||||||
|
from testing.language_helpers import run_language
|
||||||
|
from testing.util import cwd
|
||||||
from testing.util import xfailif_windows
|
from testing.util import xfailif_windows
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -34,50 +35,6 @@ def test_uses_system_if_both_gem_and_ruby_are_available(find_exe_mck):
|
||||||
assert ACTUAL_GET_DEFAULT_VERSION() == 'system'
|
assert ACTUAL_GET_DEFAULT_VERSION() == 'system'
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
|
||||||
def fake_gem_prefix(tmpdir):
|
|
||||||
gemspec = '''\
|
|
||||||
Gem::Specification.new do |s|
|
|
||||||
s.name = 'pre_commit_placeholder_package'
|
|
||||||
s.version = '0.0.0'
|
|
||||||
s.summary = 'placeholder gem for pre-commit hooks'
|
|
||||||
s.authors = ['Anthony Sottile']
|
|
||||||
end
|
|
||||||
'''
|
|
||||||
tmpdir.join('placeholder_gem.gemspec').write(gemspec)
|
|
||||||
yield Prefix(tmpdir)
|
|
||||||
|
|
||||||
|
|
||||||
@xfailif_windows # pragma: win32 no cover
|
|
||||||
def test_install_ruby_system(fake_gem_prefix):
|
|
||||||
ruby.install_environment(fake_gem_prefix, 'system', ())
|
|
||||||
|
|
||||||
# Should be able to activate and use rbenv install
|
|
||||||
with ruby.in_env(fake_gem_prefix, 'system'):
|
|
||||||
_, out, _ = cmd_output('gem', 'list')
|
|
||||||
assert 'pre_commit_placeholder_package' in out
|
|
||||||
|
|
||||||
|
|
||||||
@xfailif_windows # pragma: win32 no cover
|
|
||||||
def test_install_ruby_default(fake_gem_prefix):
|
|
||||||
ruby.install_environment(fake_gem_prefix, C.DEFAULT, ())
|
|
||||||
# Should have created rbenv directory
|
|
||||||
assert os.path.exists(fake_gem_prefix.path('rbenv-default'))
|
|
||||||
|
|
||||||
# Should be able to activate using our script and access rbenv
|
|
||||||
with ruby.in_env(fake_gem_prefix, 'default'):
|
|
||||||
cmd_output('rbenv', '--help')
|
|
||||||
|
|
||||||
|
|
||||||
@xfailif_windows # pragma: win32 no cover
|
|
||||||
def test_install_ruby_with_version(fake_gem_prefix):
|
|
||||||
ruby.install_environment(fake_gem_prefix, '3.2.0', ())
|
|
||||||
|
|
||||||
# Should be able to activate and use rbenv install
|
|
||||||
with ruby.in_env(fake_gem_prefix, '3.2.0'):
|
|
||||||
cmd_output('rbenv', 'install', '--help')
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
'filename',
|
'filename',
|
||||||
('rbenv.tar.gz', 'ruby-build.tar.gz', 'ruby-download.tar.gz'),
|
('rbenv.tar.gz', 'ruby-build.tar.gz', 'ruby-download.tar.gz'),
|
||||||
|
|
@ -87,3 +44,95 @@ def test_archive_root_stat(filename):
|
||||||
with tarfile.open(fileobj=f) as tarf:
|
with tarfile.open(fileobj=f) as tarf:
|
||||||
root, _, _ = filename.partition('.')
|
root, _, _ = filename.partition('.')
|
||||||
assert oct(tarf.getmember(root).mode) == '0o755'
|
assert oct(tarf.getmember(root).mode) == '0o755'
|
||||||
|
|
||||||
|
|
||||||
|
def _setup_hello_world(tmp_path):
|
||||||
|
bin_dir = tmp_path.joinpath('bin')
|
||||||
|
bin_dir.mkdir()
|
||||||
|
bin_dir.joinpath('ruby_hook').write_text(
|
||||||
|
'#!/usr/bin/env ruby\n'
|
||||||
|
"puts 'Hello world from a ruby hook'\n",
|
||||||
|
)
|
||||||
|
gemspec = '''\
|
||||||
|
Gem::Specification.new do |s|
|
||||||
|
s.name = 'ruby_hook'
|
||||||
|
s.version = '0.1.0'
|
||||||
|
s.authors = ['Anthony Sottile']
|
||||||
|
s.summary = 'A ruby hook!'
|
||||||
|
s.description = 'A ruby hook!'
|
||||||
|
s.files = ['bin/ruby_hook']
|
||||||
|
s.executables = ['ruby_hook']
|
||||||
|
end
|
||||||
|
'''
|
||||||
|
tmp_path.joinpath('ruby_hook.gemspec').write_text(gemspec)
|
||||||
|
|
||||||
|
|
||||||
|
def test_ruby_hook_system(tmp_path):
|
||||||
|
assert ruby.get_default_version() == 'system'
|
||||||
|
|
||||||
|
_setup_hello_world(tmp_path)
|
||||||
|
|
||||||
|
ret = run_language(tmp_path, ruby, 'ruby_hook')
|
||||||
|
assert ret == (0, b'Hello world from a ruby hook\n')
|
||||||
|
|
||||||
|
|
||||||
|
def test_ruby_with_user_install_set(tmp_path):
|
||||||
|
gemrc = tmp_path.joinpath('gemrc')
|
||||||
|
gemrc.write_text('gem: --user-install\n')
|
||||||
|
|
||||||
|
with envcontext((('GEMRC', str(gemrc)),)):
|
||||||
|
test_ruby_hook_system(tmp_path)
|
||||||
|
|
||||||
|
|
||||||
|
def test_ruby_additional_deps(tmp_path):
|
||||||
|
_make_local_repo(tmp_path)
|
||||||
|
|
||||||
|
ret = run_language(
|
||||||
|
tmp_path,
|
||||||
|
ruby,
|
||||||
|
'ruby -e',
|
||||||
|
args=('require "tins"',),
|
||||||
|
deps=('tins',),
|
||||||
|
)
|
||||||
|
assert ret == (0, b'')
|
||||||
|
|
||||||
|
|
||||||
|
@xfailif_windows # pragma: win32 no cover
|
||||||
|
def test_ruby_hook_default(tmp_path):
|
||||||
|
_setup_hello_world(tmp_path)
|
||||||
|
|
||||||
|
out, ret = run_language(tmp_path, ruby, 'rbenv --help', version='default')
|
||||||
|
assert out == 0
|
||||||
|
assert ret.startswith(b'Usage: rbenv ')
|
||||||
|
|
||||||
|
|
||||||
|
@xfailif_windows # pragma: win32 no cover
|
||||||
|
def test_ruby_hook_language_version(tmp_path):
|
||||||
|
_setup_hello_world(tmp_path)
|
||||||
|
tmp_path.joinpath('bin', 'ruby_hook').write_text(
|
||||||
|
'#!/usr/bin/env ruby\n'
|
||||||
|
'puts RUBY_VERSION\n'
|
||||||
|
"puts 'Hello world from a ruby hook'\n",
|
||||||
|
)
|
||||||
|
|
||||||
|
ret = run_language(tmp_path, ruby, 'ruby_hook', version='3.2.0')
|
||||||
|
assert ret == (0, b'3.2.0\nHello world from a ruby hook\n')
|
||||||
|
|
||||||
|
|
||||||
|
@xfailif_windows # pragma: win32 no cover
|
||||||
|
def test_ruby_with_bundle_disable_shared_gems(tmp_path):
|
||||||
|
workdir = tmp_path.joinpath('workdir')
|
||||||
|
workdir.mkdir()
|
||||||
|
# this Gemfile is missing `source`
|
||||||
|
workdir.joinpath('Gemfile').write_text('gem "lol_hai"\n')
|
||||||
|
# this bundle config causes things to be written elsewhere
|
||||||
|
bundle = workdir.joinpath('.bundle')
|
||||||
|
bundle.mkdir()
|
||||||
|
bundle.joinpath('config').write_text(
|
||||||
|
'BUNDLE_DISABLE_SHARED_GEMS: true\n'
|
||||||
|
'BUNDLE_PATH: vendor/gem\n',
|
||||||
|
)
|
||||||
|
|
||||||
|
with cwd(workdir):
|
||||||
|
# `3.2.0` has new enough `gem` requiring `source` and reading `.bundle`
|
||||||
|
test_ruby_hook_language_version(tmp_path)
|
||||||
|
|
|
||||||
|
|
@ -19,7 +19,6 @@ from pre_commit.languages import golang
|
||||||
from pre_commit.languages import helpers
|
from pre_commit.languages import helpers
|
||||||
from pre_commit.languages import node
|
from pre_commit.languages import node
|
||||||
from pre_commit.languages import python
|
from pre_commit.languages import python
|
||||||
from pre_commit.languages import ruby
|
|
||||||
from pre_commit.languages.all import languages
|
from pre_commit.languages.all import languages
|
||||||
from pre_commit.prefix import Prefix
|
from pre_commit.prefix import Prefix
|
||||||
from pre_commit.repository import _hook_installed
|
from pre_commit.repository import _hook_installed
|
||||||
|
|
@ -33,7 +32,6 @@ from testing.fixtures import modify_manifest
|
||||||
from testing.util import cwd
|
from testing.util import cwd
|
||||||
from testing.util import get_resource_path
|
from testing.util import get_resource_path
|
||||||
from testing.util import skipif_cant_run_docker
|
from testing.util import skipif_cant_run_docker
|
||||||
from testing.util import xfailif_windows
|
|
||||||
|
|
||||||
|
|
||||||
def _norm_out(b):
|
def _norm_out(b):
|
||||||
|
|
@ -227,52 +225,6 @@ def test_node_hook_with_npm_userconfig_set(tempdir_factory, store, tmpdir):
|
||||||
test_run_a_node_hook(tempdir_factory, store)
|
test_run_a_node_hook(tempdir_factory, store)
|
||||||
|
|
||||||
|
|
||||||
def test_run_a_ruby_hook(tempdir_factory, store):
|
|
||||||
_test_hook_repo(
|
|
||||||
tempdir_factory, store, 'ruby_hooks_repo',
|
|
||||||
'ruby_hook', [os.devnull], b'Hello world from a ruby hook\n',
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
def test_run_a_ruby_hook_with_user_install_set(tempdir_factory, store, tmpdir):
|
|
||||||
gemrc = tmpdir.join('gemrc')
|
|
||||||
gemrc.write('gem: --user-install\n')
|
|
||||||
with envcontext((('GEMRC', str(gemrc)),)):
|
|
||||||
test_run_a_ruby_hook(tempdir_factory, store)
|
|
||||||
|
|
||||||
|
|
||||||
@xfailif_windows # pragma: win32 no cover
|
|
||||||
def test_run_versioned_ruby_hook(tempdir_factory, store):
|
|
||||||
_test_hook_repo(
|
|
||||||
tempdir_factory, store, 'ruby_versioned_hooks_repo',
|
|
||||||
'ruby_hook',
|
|
||||||
[os.devnull],
|
|
||||||
b'3.2.0\nHello world from a ruby hook\n',
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
@xfailif_windows # pragma: win32 no cover
|
|
||||||
def test_run_ruby_hook_with_disable_shared_gems(
|
|
||||||
tempdir_factory,
|
|
||||||
store,
|
|
||||||
tmpdir,
|
|
||||||
):
|
|
||||||
"""Make sure a Gemfile in the project doesn't interfere."""
|
|
||||||
tmpdir.join('Gemfile').write('gem "lol_hai"')
|
|
||||||
tmpdir.join('.bundle').mkdir()
|
|
||||||
tmpdir.join('.bundle', 'config').write(
|
|
||||||
'BUNDLE_DISABLE_SHARED_GEMS: true\n'
|
|
||||||
'BUNDLE_PATH: vendor/gem\n',
|
|
||||||
)
|
|
||||||
with cwd(tmpdir.strpath):
|
|
||||||
_test_hook_repo(
|
|
||||||
tempdir_factory, store, 'ruby_versioned_hooks_repo',
|
|
||||||
'ruby_hook',
|
|
||||||
[os.devnull],
|
|
||||||
b'3.2.0\nHello world from a ruby hook\n',
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
def test_system_hook_with_spaces(tempdir_factory, store):
|
def test_system_hook_with_spaces(tempdir_factory, store):
|
||||||
_test_hook_repo(
|
_test_hook_repo(
|
||||||
tempdir_factory, store, 'system_hook_with_spaces_repo',
|
tempdir_factory, store, 'system_hook_with_spaces_repo',
|
||||||
|
|
@ -530,16 +482,6 @@ def test_repository_state_compatibility(tempdir_factory, store, v):
|
||||||
assert _hook_installed(hook) is True
|
assert _hook_installed(hook) is True
|
||||||
|
|
||||||
|
|
||||||
def test_additional_ruby_dependencies_installed(tempdir_factory, store):
|
|
||||||
path = make_repo(tempdir_factory, 'ruby_hooks_repo')
|
|
||||||
config = make_config_from_repo(path)
|
|
||||||
config['hooks'][0]['additional_dependencies'] = ['tins']
|
|
||||||
hook = _get_hook(config, store, 'ruby_hook')
|
|
||||||
with ruby.in_env(hook.prefix, hook.language_version):
|
|
||||||
output = cmd_output('gem', 'list', '--local')[1]
|
|
||||||
assert 'tins' in output
|
|
||||||
|
|
||||||
|
|
||||||
def test_additional_node_dependencies_installed(tempdir_factory, store):
|
def test_additional_node_dependencies_installed(tempdir_factory, store):
|
||||||
path = make_repo(tempdir_factory, 'node_hooks_repo')
|
path = make_repo(tempdir_factory, 'node_hooks_repo')
|
||||||
config = make_config_from_repo(path)
|
config = make_config_from_repo(path)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue