pypa-hatch/tests/cli/version/test_version.py

173 lines
4.3 KiB
Python

import pytest
from hatch.project.core import Project
from hatchling.utils.constants import DEFAULT_BUILD_SCRIPT
@pytest.fixture
def local_builder(mock_backend_process, mocker):
if mock_backend_process:
mocker.patch('hatch.env.virtual.VirtualEnvironment.build_environment')
yield
def test_incompatible_environment(hatch, temp_dir, helpers):
project_name = 'My.App'
with temp_dir.as_cwd():
result = hatch('new', project_name)
assert result.exit_code == 0, result.output
path = temp_dir / 'my-app'
project = Project(path)
config = dict(project.raw_config)
config['build-system']['requires'].append('foo')
config['tool']['hatch']['metadata'] = {'hooks': {'custom': {}}}
project.save_config(config)
helpers.update_project_environment(
project, 'default', {'skip-install': True, 'python': '9000', **project.config.envs['default']}
)
with path.as_cwd():
result = hatch('version')
assert result.exit_code == 1, result.output
assert result.output == helpers.dedent(
"""
Environment `default` is incompatible: cannot locate Python: 9000
"""
)
def test_show_dynamic(hatch, temp_dir):
project_name = 'My.App'
with temp_dir.as_cwd():
hatch('new', project_name)
path = temp_dir / 'my-app'
with path.as_cwd():
result = hatch('version')
assert result.exit_code == 0, result.output
assert result.output == '0.0.1\n'
@pytest.mark.usefixtures('local_builder')
def test_show_dynamic_missing_build_dependencies(hatch, helpers, temp_dir):
project_name = 'My.App'
with temp_dir.as_cwd():
hatch('new', project_name)
path = temp_dir / 'my-app'
project = Project(path)
config = dict(project.raw_config)
config['build-system']['requires'].append('foo')
project.save_config(config)
with path.as_cwd():
result = hatch('version')
assert result.exit_code == 0, result.output
assert result.output == helpers.dedent(
"""
Setting up build environment for missing dependencies
0.0.1
"""
)
def test_set_dynamic(hatch, helpers, temp_dir):
project_name = 'My.App'
with temp_dir.as_cwd():
hatch('new', project_name)
path = temp_dir / 'my-app'
project = Project(path)
config = dict(project.raw_config)
config['tool']['hatch']['metadata'] = {'hooks': {'custom': {}}}
project.save_config(config)
build_script = path / DEFAULT_BUILD_SCRIPT
build_script.write_text(
helpers.dedent(
"""
from hatchling.metadata.plugin.interface import MetadataHookInterface
class CustomMetadataHook(MetadataHookInterface):
def update(self, metadata):
pass
"""
)
)
with path.as_cwd():
result = hatch('version', 'minor,rc')
assert result.exit_code == 0, result.output
assert result.output == helpers.dedent(
"""
Old: 0.0.1
New: 0.1.0rc0
"""
)
with path.as_cwd():
result = hatch('version')
assert result.exit_code == 0, result.output
assert result.output == '0.1.0rc0\n'
def test_show_static(hatch, temp_dir):
project_name = 'My.App'
with temp_dir.as_cwd():
hatch('new', project_name)
path = temp_dir / 'my-app'
project = Project(path)
config = dict(project.raw_config)
config['project']['version'] = '1.2.3'
config['project']['dynamic'].remove('version')
project.save_config(config)
with path.as_cwd():
result = hatch('version')
assert result.exit_code == 0, result.output
assert result.output == '1.2.3\n'
def test_set_static(hatch, helpers, temp_dir):
project_name = 'My.App'
with temp_dir.as_cwd():
hatch('new', project_name)
path = temp_dir / 'my-app'
project = Project(path)
config = dict(project.raw_config)
config['project']['version'] = '1.2.3'
config['project']['dynamic'].remove('version')
project.save_config(config)
with path.as_cwd():
result = hatch('version', 'minor,rc')
assert result.exit_code == 1, result.output
assert result.output == helpers.dedent(
"""
Cannot set version when it is statically defined by the `project.version` field
"""
)