Release version 0.5.1
This commit is contained in:
@@ -1,3 +1,8 @@
|
|||||||
|
## [0.5.1] - 2025-12-09
|
||||||
|
|
||||||
|
* Refine pkgmgr release CLI close wiring and integration tests for --close flag (ChatGPT: https://chatgpt.com/share/69376b4e-8440-800f-9d06-535ec1d7a40e)
|
||||||
|
|
||||||
|
|
||||||
## [0.5.0] - 2025-12-09
|
## [0.5.0] - 2025-12-09
|
||||||
|
|
||||||
* Add pkgmgr branch close subcommand, extend CLI parser wiring, and add unit tests for branch handling and version version-selection logic (see ChatGPT conversation: https://chatgpt.com/share/693762a3-9ea8-800f-a640-bc78170953d1)
|
* Add pkgmgr branch close subcommand, extend CLI parser wiring, and add unit tests for branch handling and version version-selection logic (see ChatGPT conversation: https://chatgpt.com/share/693762a3-9ea8-800f-a640-bc78170953d1)
|
||||||
|
|||||||
2
PKGBUILD
2
PKGBUILD
@@ -1,7 +1,7 @@
|
|||||||
# Maintainer: Kevin Veen-Birkenbach <info@veen.world>
|
# Maintainer: Kevin Veen-Birkenbach <info@veen.world>
|
||||||
|
|
||||||
pkgname=package-manager
|
pkgname=package-manager
|
||||||
pkgver=0.5.0
|
pkgver=0.5.1
|
||||||
pkgrel=1
|
pkgrel=1
|
||||||
pkgdesc="Local-flake wrapper for Kevin's package-manager (Nix-based)."
|
pkgdesc="Local-flake wrapper for Kevin's package-manager (Nix-based)."
|
||||||
arch=('any')
|
arch=('any')
|
||||||
|
|||||||
6
debian/changelog
vendored
6
debian/changelog
vendored
@@ -1,3 +1,9 @@
|
|||||||
|
package-manager (0.5.1-1) unstable; urgency=medium
|
||||||
|
|
||||||
|
* Refine pkgmgr release CLI close wiring and integration tests for --close flag (ChatGPT: https://chatgpt.com/share/69376b4e-8440-800f-9d06-535ec1d7a40e)
|
||||||
|
|
||||||
|
-- Kevin Veen-Birkenbach <kevin@veen.world> Tue, 09 Dec 2025 01:21:31 +0100
|
||||||
|
|
||||||
package-manager (0.5.0-1) unstable; urgency=medium
|
package-manager (0.5.0-1) unstable; urgency=medium
|
||||||
|
|
||||||
* Add pkgmgr branch close subcommand, extend CLI parser wiring, and add unit tests for branch handling and version version-selection logic (see ChatGPT conversation: https://chatgpt.com/share/693762a3-9ea8-800f-a640-bc78170953d1)
|
* Add pkgmgr branch close subcommand, extend CLI parser wiring, and add unit tests for branch handling and version version-selection logic (see ChatGPT conversation: https://chatgpt.com/share/693762a3-9ea8-800f-a640-bc78170953d1)
|
||||||
|
|||||||
@@ -31,7 +31,7 @@
|
|||||||
rec {
|
rec {
|
||||||
pkgmgr = pyPkgs.buildPythonApplication {
|
pkgmgr = pyPkgs.buildPythonApplication {
|
||||||
pname = "package-manager";
|
pname = "package-manager";
|
||||||
version = "0.5.0";
|
version = "0.5.1";
|
||||||
|
|
||||||
# Use the git repo as source
|
# Use the git repo as source
|
||||||
src = ./.;
|
src = ./.;
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
Name: package-manager
|
Name: package-manager
|
||||||
Version: 0.5.0
|
Version: 0.5.1
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
Summary: Wrapper that runs Kevin's package-manager via Nix flake
|
Summary: Wrapper that runs Kevin's package-manager via Nix flake
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ build-backend = "setuptools.build_meta"
|
|||||||
|
|
||||||
[project]
|
[project]
|
||||||
name = "package-manager"
|
name = "package-manager"
|
||||||
version = "0.5.0"
|
version = "0.5.1"
|
||||||
description = "Kevin's package-manager tool (pkgmgr)"
|
description = "Kevin's package-manager tool (pkgmgr)"
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
requires-python = ">=3.11"
|
requires-python = ">=3.11"
|
||||||
|
|||||||
@@ -4,10 +4,17 @@
|
|||||||
"""
|
"""
|
||||||
End-to-end style integration tests for the `pkgmgr release` CLI command.
|
End-to-end style integration tests for the `pkgmgr release` CLI command.
|
||||||
|
|
||||||
These tests exercise the top-level `pkgmgr` entry point by invoking
|
These tests exercise the real top-level entry point (main.py) and mock
|
||||||
the module as `__main__` and verifying that the underlying
|
the high-level helper used by the CLI wiring
|
||||||
`pkgmgr.release.release()` function is called with the expected
|
(pkgmgr.cli_core.commands.release.run_release) to ensure that argument
|
||||||
arguments, in particular the new `close` flag.
|
parsing and dispatch behave as expected, in particular the new `close`
|
||||||
|
flag.
|
||||||
|
|
||||||
|
The tests simulate real CLI calls like:
|
||||||
|
|
||||||
|
pkgmgr release minor --preview --close
|
||||||
|
|
||||||
|
by manipulating sys.argv and executing main.py as __main__ via runpy.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
@@ -21,55 +28,110 @@ from unittest.mock import patch
|
|||||||
class TestIntegrationReleaseCommand(unittest.TestCase):
|
class TestIntegrationReleaseCommand(unittest.TestCase):
|
||||||
"""Integration tests for `pkgmgr release` wiring."""
|
"""Integration tests for `pkgmgr release` wiring."""
|
||||||
|
|
||||||
def _run_pkgmgr(self, argv: list[str]) -> None:
|
def _run_pkgmgr(self, extra_args: list[str]) -> None:
|
||||||
"""
|
"""
|
||||||
Helper to invoke the `pkgmgr` console script via `run_module`.
|
Helper to invoke the `pkgmgr` console script via the real
|
||||||
|
entry point (main.py).
|
||||||
|
|
||||||
This simulates a real CLI call like:
|
This simulates a real CLI call like:
|
||||||
|
|
||||||
pkgmgr release minor --preview --close
|
pkgmgr <extra_args...>
|
||||||
|
|
||||||
|
by setting sys.argv accordingly and executing main.py as
|
||||||
|
__main__ using runpy.run_module.
|
||||||
"""
|
"""
|
||||||
original_argv = list(sys.argv)
|
original_argv = list(sys.argv)
|
||||||
try:
|
try:
|
||||||
sys.argv = argv
|
# argv[0] is the program name; the rest are CLI arguments.
|
||||||
# Entry point: the `pkgmgr` module is the console script.
|
sys.argv = ["pkgmgr"] + list(extra_args)
|
||||||
runpy.run_module("pkgmgr", run_name="__main__")
|
runpy.run_module("main", run_name="__main__")
|
||||||
finally:
|
finally:
|
||||||
sys.argv = original_argv
|
sys.argv = original_argv
|
||||||
|
|
||||||
@patch("pkgmgr.release.release")
|
# ------------------------------------------------------------------
|
||||||
def test_release_without_close_flag(self, mock_release) -> None:
|
# Behaviour without --close
|
||||||
|
# ------------------------------------------------------------------
|
||||||
|
|
||||||
|
@patch("pkgmgr.cli_core.commands.release.run_release")
|
||||||
|
@patch("pkgmgr.cli_core.dispatch._select_repo_for_current_directory")
|
||||||
|
def test_release_without_close_flag(
|
||||||
|
self,
|
||||||
|
mock_select_repo,
|
||||||
|
mock_run_release,
|
||||||
|
) -> None:
|
||||||
"""
|
"""
|
||||||
Calling `pkgmgr release patch --preview` should *not* enable
|
Calling `pkgmgr release patch --preview` should *not* enable
|
||||||
the `close` flag by default.
|
the `close` flag by default.
|
||||||
"""
|
"""
|
||||||
self._run_pkgmgr(["pkgmgr", "release", "patch", "--preview"])
|
# Ensure that the dispatch layer always selects a repository,
|
||||||
|
# independent of any real config in the test environment.
|
||||||
|
mock_select_repo.return_value = [
|
||||||
|
{
|
||||||
|
"directory": ".",
|
||||||
|
"provider": "local",
|
||||||
|
"account": "test",
|
||||||
|
"repository": "dummy",
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
mock_release.assert_called_once()
|
self._run_pkgmgr(["release", "patch", "--preview"])
|
||||||
_args, kwargs = mock_release.call_args
|
|
||||||
|
mock_run_release.assert_called_once()
|
||||||
|
_args, kwargs = mock_run_release.call_args
|
||||||
|
|
||||||
# CLI wiring
|
# CLI wiring
|
||||||
self.assertEqual(kwargs.get("release_type"), "patch")
|
self.assertEqual(kwargs.get("release_type"), "patch")
|
||||||
self.assertTrue(kwargs.get("preview"), "preview should be True when --preview is used")
|
self.assertTrue(
|
||||||
|
kwargs.get("preview"),
|
||||||
|
"preview should be True when --preview is used",
|
||||||
|
)
|
||||||
# Default: no --close → close=False
|
# Default: no --close → close=False
|
||||||
self.assertFalse(kwargs.get("close"), "close must be False when --close is not given")
|
self.assertFalse(
|
||||||
|
kwargs.get("close"),
|
||||||
|
"close must be False when --close is not given",
|
||||||
|
)
|
||||||
|
|
||||||
@patch("pkgmgr.release.release")
|
# ------------------------------------------------------------------
|
||||||
def test_release_with_close_flag(self, mock_release) -> None:
|
# Behaviour with --close
|
||||||
|
# ------------------------------------------------------------------
|
||||||
|
|
||||||
|
@patch("pkgmgr.cli_core.commands.release.run_release")
|
||||||
|
@patch("pkgmgr.cli_core.dispatch._select_repo_for_current_directory")
|
||||||
|
def test_release_with_close_flag(
|
||||||
|
self,
|
||||||
|
mock_select_repo,
|
||||||
|
mock_run_release,
|
||||||
|
) -> None:
|
||||||
"""
|
"""
|
||||||
Calling `pkgmgr release minor --preview --close` should pass
|
Calling `pkgmgr release minor --preview --close` should pass
|
||||||
close=True into pkgmgr.release.release().
|
close=True into the helper used by the CLI wiring.
|
||||||
"""
|
"""
|
||||||
self._run_pkgmgr(["pkgmgr", "release", "minor", "--preview", "--close"])
|
# Again: make sure there is always a selected repository.
|
||||||
|
mock_select_repo.return_value = [
|
||||||
|
{
|
||||||
|
"directory": ".",
|
||||||
|
"provider": "local",
|
||||||
|
"account": "test",
|
||||||
|
"repository": "dummy",
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
mock_release.assert_called_once()
|
self._run_pkgmgr(["release", "minor", "--preview", "--close"])
|
||||||
_args, kwargs = mock_release.call_args
|
|
||||||
|
mock_run_release.assert_called_once()
|
||||||
|
_args, kwargs = mock_run_release.call_args
|
||||||
|
|
||||||
# CLI wiring
|
# CLI wiring
|
||||||
self.assertEqual(kwargs.get("release_type"), "minor")
|
self.assertEqual(kwargs.get("release_type"), "minor")
|
||||||
self.assertTrue(kwargs.get("preview"), "preview should be True when --preview is used")
|
self.assertTrue(
|
||||||
|
kwargs.get("preview"),
|
||||||
|
"preview should be True when --preview is used",
|
||||||
|
)
|
||||||
# With --close → close=True
|
# With --close → close=True
|
||||||
self.assertTrue(kwargs.get("close"), "close must be True when --close is given")
|
self.assertTrue(
|
||||||
|
kwargs.get("close"),
|
||||||
|
"close must be True when --close is given",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
|||||||
Reference in New Issue
Block a user