mirror of
				https://github.com/arcan1s/ahriman.git
				synced 2025-11-04 07:43:42 +00:00 
			
		
		
		
	feat: add patch controls to web, review web, enrich info tab (#115)
* add ability to specify one-time patch on package addition * support vars in interface
This commit is contained in:
		@ -9,6 +9,7 @@ from ahriman.core.repository import Repository
 | 
			
		||||
from ahriman.models.package import Package
 | 
			
		||||
from ahriman.models.package_source import PackageSource
 | 
			
		||||
from ahriman.models.packagers import Packagers
 | 
			
		||||
from ahriman.models.pkgbuild_patch import PkgbuildPatch
 | 
			
		||||
from ahriman.models.result import Result
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -22,7 +23,7 @@ def _default_args(args: argparse.Namespace) -> argparse.Namespace:
 | 
			
		||||
    Returns:
 | 
			
		||||
        argparse.Namespace: generated arguments for these test cases
 | 
			
		||||
    """
 | 
			
		||||
    args.package = []
 | 
			
		||||
    args.package = ["ahriman"]
 | 
			
		||||
    args.exit_code = False
 | 
			
		||||
    args.increment = True
 | 
			
		||||
    args.now = False
 | 
			
		||||
@ -30,6 +31,7 @@ def _default_args(args: argparse.Namespace) -> argparse.Namespace:
 | 
			
		||||
    args.source = PackageSource.Auto
 | 
			
		||||
    args.dependencies = True
 | 
			
		||||
    args.username = "username"
 | 
			
		||||
    args.variable = None
 | 
			
		||||
    return args
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -51,6 +53,22 @@ def test_run(args: argparse.Namespace, configuration: Configuration, repository:
 | 
			
		||||
    on_start_mock.assert_called_once_with()
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def test_run_with_patches(args: argparse.Namespace, configuration: Configuration, repository: Repository,
 | 
			
		||||
                          mocker: MockerFixture) -> None:
 | 
			
		||||
    """
 | 
			
		||||
    must run command and insert temporary patches
 | 
			
		||||
    """
 | 
			
		||||
    args = _default_args(args)
 | 
			
		||||
    args.variable = ["KEY=VALUE"]
 | 
			
		||||
    mocker.patch("ahriman.core.repository.Repository.load", return_value=repository)
 | 
			
		||||
    mocker.patch("ahriman.application.application.Application.add")
 | 
			
		||||
    application_mock = mocker.patch("ahriman.core.database.SQLite.patches_insert")
 | 
			
		||||
 | 
			
		||||
    _, repository_id = configuration.check_loaded()
 | 
			
		||||
    Add.run(args, repository_id, configuration, report=False)
 | 
			
		||||
    application_mock.assert_called_once_with(args.package[0], [PkgbuildPatch("KEY", "VALUE")])
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def test_run_with_updates(args: argparse.Namespace, configuration: Configuration, repository: Repository,
 | 
			
		||||
                          package_ahriman: Package, mocker: MockerFixture) -> None:
 | 
			
		||||
    """
 | 
			
		||||
 | 
			
		||||
@ -180,7 +180,7 @@ def test_patch_set_create(application: Application, package_ahriman: Package, mo
 | 
			
		||||
    """
 | 
			
		||||
    create_mock = mocker.patch("ahriman.core.database.SQLite.patches_insert")
 | 
			
		||||
    Patch.patch_set_create(application, package_ahriman.base, PkgbuildPatch("version", package_ahriman.version))
 | 
			
		||||
    create_mock.assert_called_once_with(package_ahriman.base, PkgbuildPatch("version", package_ahriman.version))
 | 
			
		||||
    create_mock.assert_called_once_with(package_ahriman.base, [PkgbuildPatch("version", package_ahriman.version)])
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def test_patch_set_remove(application: Application, package_ahriman: Package, mocker: MockerFixture) -> None:
 | 
			
		||||
 | 
			
		||||
@ -254,6 +254,22 @@ def test_subparsers_package_add_option_refresh(parser: argparse.ArgumentParser)
 | 
			
		||||
    assert args.refresh == 2
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def test_subparsers_package_add_option_variable_empty(parser: argparse.ArgumentParser) -> None:
 | 
			
		||||
    """
 | 
			
		||||
    package-add command must accept empty variable list as None
 | 
			
		||||
    """
 | 
			
		||||
    args = parser.parse_args(["package-add", "ahriman"])
 | 
			
		||||
    assert args.variable is None
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def test_subparsers_package_add_option_variable_multiple(parser: argparse.ArgumentParser) -> None:
 | 
			
		||||
    """
 | 
			
		||||
    repo-rebuild command must accept multiple depends-on
 | 
			
		||||
    """
 | 
			
		||||
    args = parser.parse_args(["package-add", "ahriman", "-v", "var1", "-v", "var2"])
 | 
			
		||||
    assert args.variable == ["var1", "var2"]
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def test_subparsers_package_remove_option_architecture(parser: argparse.ArgumentParser) -> None:
 | 
			
		||||
    """
 | 
			
		||||
    package-remove command must correctly parse architecture list
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user