mirror of
https://github.com/pre-commit/pre-commit.git
synced 2026-04-15 01:51:46 +04:00
[skip-ci] WIP
This commit is contained in:
parent
67537e5660
commit
5c70bd4d45
2 changed files with 31 additions and 30 deletions
|
|
@ -88,8 +88,9 @@ def install_environment(
|
||||||
cmd_output_b(*cmd)
|
cmd_output_b(*cmd)
|
||||||
|
|
||||||
with in_env(prefix, version):
|
with in_env(prefix, version):
|
||||||
|
breakpoint()
|
||||||
install = (
|
install = (
|
||||||
'bun', 'install', '--no-progress', '--silent', '--no-save',
|
'bun', 'install', '--no-progress', '--silent', *additional_dependencies
|
||||||
)
|
)
|
||||||
lang_base.setup_cmd(prefix, install)
|
lang_base.setup_cmd(prefix, install)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -11,7 +11,7 @@ import pytest
|
||||||
import pre_commit.constants as C
|
import pre_commit.constants as C
|
||||||
from pre_commit import envcontext
|
from pre_commit import envcontext
|
||||||
from pre_commit import parse_shebang
|
from pre_commit import parse_shebang
|
||||||
from pre_commit.languages import node
|
from pre_commit.languages import bun
|
||||||
from pre_commit.prefix import Prefix
|
from pre_commit.prefix import Prefix
|
||||||
from pre_commit.store import _make_local_repo
|
from pre_commit.store import _make_local_repo
|
||||||
from pre_commit.util import cmd_output
|
from pre_commit.util import cmd_output
|
||||||
|
|
@ -19,7 +19,7 @@ from testing.language_helpers import run_language
|
||||||
from testing.util import xfailif_windows
|
from testing.util import xfailif_windows
|
||||||
|
|
||||||
|
|
||||||
ACTUAL_GET_DEFAULT_VERSION = node.get_default_version.__wrapped__
|
ACTUAL_GET_DEFAULT_VERSION = bun.get_default_version.__wrapped__
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
|
|
@ -41,13 +41,13 @@ def find_exe_mck():
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.usefixtures('is_linux')
|
@pytest.mark.usefixtures('is_linux')
|
||||||
def test_sets_system_when_node_and_npm_are_available(find_exe_mck):
|
def test_sets_system_when_bun_and_npm_are_available(find_exe_mck):
|
||||||
find_exe_mck.return_value = '/path/to/exe'
|
find_exe_mck.return_value = '/path/to/exe'
|
||||||
assert ACTUAL_GET_DEFAULT_VERSION() == 'system'
|
assert ACTUAL_GET_DEFAULT_VERSION() == 'system'
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.usefixtures('is_linux')
|
@pytest.mark.usefixtures('is_linux')
|
||||||
def test_uses_default_when_node_and_npm_are_not_available(find_exe_mck):
|
def test_uses_default_when_bun_and_npm_are_not_available(find_exe_mck):
|
||||||
find_exe_mck.return_value = None
|
find_exe_mck.return_value = None
|
||||||
assert ACTUAL_GET_DEFAULT_VERSION() == C.DEFAULT
|
assert ACTUAL_GET_DEFAULT_VERSION() == C.DEFAULT
|
||||||
|
|
||||||
|
|
@ -59,19 +59,19 @@ def test_sets_default_on_windows(find_exe_mck):
|
||||||
|
|
||||||
|
|
||||||
@xfailif_windows # pragma: win32 no cover
|
@xfailif_windows # pragma: win32 no cover
|
||||||
def test_healthy_system_node(tmpdir):
|
def test_healthy_system_bun(tmpdir):
|
||||||
tmpdir.join('package.json').write('{"name": "t", "version": "1.0.0"}')
|
tmpdir.join('package.json').write('{"name": "t", "version": "1.0.0"}')
|
||||||
|
|
||||||
prefix = Prefix(str(tmpdir))
|
prefix = Prefix(str(tmpdir))
|
||||||
node.install_environment(prefix, 'system', ())
|
bun.install_environment(prefix, 'system', ())
|
||||||
assert node.health_check(prefix, 'system') is None
|
assert bun.health_check(prefix, 'system') is None
|
||||||
|
|
||||||
|
|
||||||
@xfailif_windows # pragma: win32 no cover
|
@xfailif_windows # pragma: win32 no cover
|
||||||
def test_unhealthy_if_system_node_goes_missing(tmpdir):
|
def test_unhealthy_if_system_bun_goes_missing(tmpdir):
|
||||||
bin_dir = tmpdir.join('bin').ensure_dir()
|
bin_dir = tmpdir.join('bin').ensure_dir()
|
||||||
node_bin = bin_dir.join('node')
|
bun_bin = bin_dir.join('bun')
|
||||||
node_bin.mksymlinkto(shutil.which('node'))
|
bun_bin.mksymlinkto(shutil.which('bun'))
|
||||||
|
|
||||||
prefix_dir = tmpdir.join('prefix').ensure_dir()
|
prefix_dir = tmpdir.join('prefix').ensure_dir()
|
||||||
prefix_dir.join('package.json').write('{"name": "t", "version": "1.0.0"}')
|
prefix_dir.join('package.json').write('{"name": "t", "version": "1.0.0"}')
|
||||||
|
|
@ -79,18 +79,18 @@ def test_unhealthy_if_system_node_goes_missing(tmpdir):
|
||||||
path = ('PATH', (str(bin_dir), os.pathsep, envcontext.Var('PATH')))
|
path = ('PATH', (str(bin_dir), os.pathsep, envcontext.Var('PATH')))
|
||||||
with envcontext.envcontext((path,)):
|
with envcontext.envcontext((path,)):
|
||||||
prefix = Prefix(str(prefix_dir))
|
prefix = Prefix(str(prefix_dir))
|
||||||
node.install_environment(prefix, 'system', ())
|
bun.install_environment(prefix, 'system', ())
|
||||||
assert node.health_check(prefix, 'system') is None
|
assert bun.health_check(prefix, 'system') is None
|
||||||
|
|
||||||
node_bin.remove()
|
bun_bin.remove()
|
||||||
ret = node.health_check(prefix, 'system')
|
ret = bun.health_check(prefix, 'system')
|
||||||
assert ret == '`node --version` returned 127'
|
assert ret == '`bun --version` returned 127'
|
||||||
|
|
||||||
|
|
||||||
@xfailif_windows # pragma: win32 no cover
|
@xfailif_windows # pragma: win32 no cover
|
||||||
def test_installs_without_links_outside_env(tmpdir):
|
def test_installs_without_links_outside_env(tmpdir):
|
||||||
tmpdir.join('bin/main.js').ensure().write(
|
tmpdir.join('bin/main.js').ensure().write(
|
||||||
'#!/usr/bin/env node\n'
|
'#!/usr/bin/env bun\n'
|
||||||
'_ = require("lodash"); console.log("success!")\n',
|
'_ = require("lodash"); console.log("success!")\n',
|
||||||
)
|
)
|
||||||
tmpdir.join('package.json').write(
|
tmpdir.join('package.json').write(
|
||||||
|
|
@ -103,50 +103,50 @@ def test_installs_without_links_outside_env(tmpdir):
|
||||||
)
|
)
|
||||||
|
|
||||||
prefix = Prefix(str(tmpdir))
|
prefix = Prefix(str(tmpdir))
|
||||||
node.install_environment(prefix, 'system', ())
|
bun.install_environment(prefix, 'system', ())
|
||||||
assert node.health_check(prefix, 'system') is None
|
assert bun.health_check(prefix, 'system') is None
|
||||||
|
|
||||||
# this directory shouldn't exist, make sure we succeed without it existing
|
# this directory shouldn't exist, make sure we succeed without it existing
|
||||||
cmd_output('rm', '-rf', str(tmpdir.join('node_modules')))
|
cmd_output('rm', '-rf', str(tmpdir.join('node_modules')))
|
||||||
|
|
||||||
with node.in_env(prefix, 'system'):
|
with bun.in_env(prefix, 'system'):
|
||||||
assert cmd_output('foo')[1] == 'success!\n'
|
assert cmd_output('foo')[1] == 'success!\n'
|
||||||
|
|
||||||
|
|
||||||
def _make_hello_world(tmp_path):
|
def _make_hello_world(tmp_path):
|
||||||
package_json = '''\
|
package_json = '''\
|
||||||
{"name": "t", "version": "0.0.1", "bin": {"node-hello": "./bin/main.js"}}
|
{"name": "t", "version": "0.0.1", "bin": {"bun-hello": "./bin/main.js"}}
|
||||||
'''
|
'''
|
||||||
tmp_path.joinpath('package.json').write_text(package_json)
|
tmp_path.joinpath('package.json').write_text(package_json)
|
||||||
bin_dir = tmp_path.joinpath('bin')
|
bin_dir = tmp_path.joinpath('bin')
|
||||||
bin_dir.mkdir()
|
bin_dir.mkdir()
|
||||||
bin_dir.joinpath('main.js').write_text(
|
bin_dir.joinpath('main.js').write_text(
|
||||||
'#!/usr/bin/env node\n'
|
'#!/usr/bin/env bun\n'
|
||||||
'console.log("Hello World");\n',
|
'console.log("Hello World");\n',
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def test_node_hook_system(tmp_path):
|
def test_bun_hook_system(tmp_path):
|
||||||
_make_hello_world(tmp_path)
|
_make_hello_world(tmp_path)
|
||||||
ret = run_language(tmp_path, node, 'node-hello')
|
ret = run_language(tmp_path, bun, 'bun-hello')
|
||||||
assert ret == (0, b'Hello World\n')
|
assert ret == (0, b'Hello World\n')
|
||||||
|
|
||||||
|
|
||||||
def test_node_with_user_config_set(tmp_path):
|
def test_bun_with_user_config_set(tmp_path):
|
||||||
cfg = tmp_path.joinpath('cfg')
|
cfg = tmp_path.joinpath('cfg')
|
||||||
cfg.write_text('cache=/dne\n')
|
cfg.write_text('cache=/dne\n')
|
||||||
with envcontext.envcontext((('NPM_CONFIG_USERCONFIG', str(cfg)),)):
|
with envcontext.envcontext((('NPM_CONFIG_USERCONFIG', str(cfg)),)):
|
||||||
test_node_hook_system(tmp_path)
|
test_bun_hook_system(tmp_path)
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('version', (C.DEFAULT, '18.14.0'))
|
@pytest.mark.parametrize('version', (C.DEFAULT, '18.14.0'))
|
||||||
def test_node_hook_versions(tmp_path, version):
|
def test_bun_hook_versions(tmp_path, version):
|
||||||
_make_hello_world(tmp_path)
|
_make_hello_world(tmp_path)
|
||||||
ret = run_language(tmp_path, node, 'node-hello', version=version)
|
ret = run_language(tmp_path, bun, 'bun-hello', version=version)
|
||||||
assert ret == (0, b'Hello World\n')
|
assert ret == (0, b'Hello World\n')
|
||||||
|
|
||||||
|
|
||||||
def test_node_additional_deps(tmp_path):
|
def test_bun_additional_deps(tmp_path):
|
||||||
_make_local_repo(str(tmp_path))
|
_make_local_repo(str(tmp_path))
|
||||||
ret, out = run_language(tmp_path, node, 'npm ls -g', deps=('lodash',))
|
ret, out = run_language(tmp_path, bun, 'bun pm ls', deps=('lodash',))
|
||||||
assert b' lodash@' in out
|
assert b' lodash@' in out
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue