1
0
Fork 0

Merging upstream version 4.7.0.

Signed-off-by: Daniel Baumann <daniel@debian.org>
This commit is contained in:
Daniel Baumann 2025-05-12 06:45:34 +02:00
parent 9ae5a60605
commit 49468bc6b3
Signed by: daniel
GPG key ID: FBB4F0E80A80222F
7 changed files with 115 additions and 9 deletions

View file

@ -15,7 +15,7 @@ name = "whatever"
version = "0.1.0"
"""
CARGO_EXPECTED = """\
CARGO_TOML_EXPECTED = """\
[package]
name = "whatever"
version = "42.1"
@ -27,18 +27,44 @@ name = "whatever"
version = "0.1.0"
"""
CARGO_WORKSPACE_EXPECTED = """\
CARGO_WORKSPACE_TOML_EXPECTED = """\
[workspace.package]
name = "whatever"
version = "42.1"
"""
CARGO_LOCK = """\
[[package]]
name = "whatever"
version = "0.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "123abc"
dependencies = [
"packageA",
"packageB",
"packageC",
]
"""
CARGO_LOCK_EXPECTED = """\
[[package]]
name = "whatever"
version = "42.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "123abc"
dependencies = [
"packageA",
"packageB",
"packageC",
]
"""
@pytest.mark.parametrize(
"content, expected",
(
(CARGO_TOML, CARGO_EXPECTED),
(CARGO_WORKSPACE_TOML, CARGO_WORKSPACE_EXPECTED),
(CARGO_TOML, CARGO_TOML_EXPECTED),
(CARGO_WORKSPACE_TOML, CARGO_WORKSPACE_TOML_EXPECTED),
),
)
def test_cargo_provider(
@ -58,3 +84,46 @@ def test_cargo_provider(
provider.set_version("42.1")
assert file.read_text() == dedent(expected)
@pytest.mark.parametrize(
"toml_content, lock_content, toml_expected, lock_expected",
(
(
CARGO_TOML,
CARGO_LOCK,
CARGO_TOML_EXPECTED,
CARGO_LOCK_EXPECTED,
),
(
CARGO_WORKSPACE_TOML,
CARGO_LOCK,
CARGO_WORKSPACE_TOML_EXPECTED,
CARGO_LOCK_EXPECTED,
),
),
)
def test_cargo_provider_with_lock(
config: BaseConfig,
chdir: Path,
toml_content: str,
lock_content: str,
toml_expected: str,
lock_expected: str,
):
filename = CargoProvider.filename
file = chdir / filename
file.write_text(dedent(toml_content))
lock_filename = CargoProvider.lock_filename
lock_file = chdir / lock_filename
lock_file.write_text(dedent(lock_content))
config.settings["version_provider"] = "cargo"
provider = get_provider(config)
assert isinstance(provider, CargoProvider)
assert provider.get_version() == "0.1.0"
provider.set_version("42.1")
assert file.read_text() == dedent(toml_expected)
assert lock_file.read_text() == dedent(lock_expected)