mirror of
				https://github.com/arcan1s/ahriman.git
				synced 2025-10-24 18:33:47 +00:00 
			
		
		
		
	Compare commits
	
		
			3 Commits
		
	
	
		
			2.15.0
			...
			3bdd2b618f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 3bdd2b618f | |||
| a075606330 | |||
| 547357a705 | 
| @ -266,6 +266,8 @@ def _set_package_add_parser(root: SubParserAction) -> argparse.ArgumentParser: | |||||||
|                                     "5) and finally you can add package from AUR.", |                                     "5) and finally you can add package from AUR.", | ||||||
|                              formatter_class=_formatter) |                              formatter_class=_formatter) | ||||||
|     parser.add_argument("package", help="package source (base name, path to local files, remote URL)", nargs="+") |     parser.add_argument("package", help="package source (base name, path to local files, remote URL)", nargs="+") | ||||||
|  |     parser.add_argument("--changes", help="calculate changes from the latest known commit if available", | ||||||
|  |                         action=argparse.BooleanOptionalAction, default=True) | ||||||
|     parser.add_argument("--dependencies", help="process missing package dependencies", |     parser.add_argument("--dependencies", help="process missing package dependencies", | ||||||
|                         action=argparse.BooleanOptionalAction, default=True) |                         action=argparse.BooleanOptionalAction, default=True) | ||||||
|     parser.add_argument("-e", "--exit-code", help="return non-zero exit status if result is empty", action="store_true") |     parser.add_argument("-e", "--exit-code", help="return non-zero exit status if result is empty", action="store_true") | ||||||
| @ -534,8 +536,7 @@ def _set_repo_check_parser(root: SubParserAction) -> argparse.ArgumentParser: | |||||||
|                              description="check for packages updates. Same as repo-update --dry-run --no-manual", |                              description="check for packages updates. Same as repo-update --dry-run --no-manual", | ||||||
|                              formatter_class=_formatter) |                              formatter_class=_formatter) | ||||||
|     parser.add_argument("package", help="filter check by package base", nargs="*") |     parser.add_argument("package", help="filter check by package base", nargs="*") | ||||||
|     parser.add_argument("--changes", help="calculate changes from the latest known commit if available. " |     parser.add_argument("--changes", help="calculate changes from the latest known commit if available", | ||||||
|                                           "Only applicable in dry run mode", |  | ||||||
|                         action=argparse.BooleanOptionalAction, default=True) |                         action=argparse.BooleanOptionalAction, default=True) | ||||||
|     parser.add_argument("--check-files", help="enable or disable checking of broken dependencies " |     parser.add_argument("--check-files", help="enable or disable checking of broken dependencies " | ||||||
|                                               "(e.g. dynamically linked libraries or modules directories)", |                                               "(e.g. dynamically linked libraries or modules directories)", | ||||||
|  | |||||||
| @ -57,6 +57,9 @@ class Add(Handler): | |||||||
|             return |             return | ||||||
|  |  | ||||||
|         packages = application.updates(args.package, aur=False, local=False, manual=True, vcs=False, check_files=False) |         packages = application.updates(args.package, aur=False, local=False, manual=True, vcs=False, check_files=False) | ||||||
|  |         if args.changes:  # generate changes if requested | ||||||
|  |             application.changes(packages) | ||||||
|  |  | ||||||
|         packages = application.with_dependencies(packages, process_dependencies=args.dependencies) |         packages = application.with_dependencies(packages, process_dependencies=args.dependencies) | ||||||
|         packagers = Packagers(args.username, {package.base: package.packager for package in packages}) |         packagers = Packagers(args.username, {package.base: package.packager for package in packages}) | ||||||
|  |  | ||||||
|  | |||||||
| @ -64,8 +64,9 @@ class Sources(LazyLogging): | |||||||
|             return None  # no previous reference found |             return None  # no previous reference found | ||||||
|  |  | ||||||
|         instance = Sources() |         instance = Sources() | ||||||
|         instance.fetch_until(source_dir, commit_sha=last_commit_sha) |         if instance.fetch_until(source_dir, commit_sha=last_commit_sha) is not None: | ||||||
|         return instance.diff(source_dir, last_commit_sha) |             return instance.diff(source_dir, last_commit_sha) | ||||||
|  |         return None | ||||||
|  |  | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def extend_architectures(sources_dir: Path, architecture: str) -> list[PkgbuildPatch]: |     def extend_architectures(sources_dir: Path, architecture: str) -> list[PkgbuildPatch]: | ||||||
| @ -298,7 +299,8 @@ class Sources(LazyLogging): | |||||||
|             args.append(sha) |             args.append(sha) | ||||||
|         return check_output(*self.git(), "diff", *args, cwd=sources_dir, logger=self.logger) |         return check_output(*self.git(), "diff", *args, cwd=sources_dir, logger=self.logger) | ||||||
|  |  | ||||||
|     def fetch_until(self, sources_dir: Path, *, branch: str | None = None, commit_sha: str | None = None) -> None: |     def fetch_until(self, sources_dir: Path, *, branch: str | None = None, commit_sha: str | None = None, | ||||||
|  |                     max_depth: int = 10) -> str | None: | ||||||
|         """ |         """ | ||||||
|         fetch repository until commit sha |         fetch repository until commit sha | ||||||
|  |  | ||||||
| @ -307,11 +309,16 @@ class Sources(LazyLogging): | |||||||
|             branch(str | None, optional): use specified branch (Default value = None) |             branch(str | None, optional): use specified branch (Default value = None) | ||||||
|             commit_sha(str | None, optional): commit hash to fetch. If none set, only one will be fetched |             commit_sha(str | None, optional): commit hash to fetch. If none set, only one will be fetched | ||||||
|                 (Default value = None) |                 (Default value = None) | ||||||
|  |             max_depth(int, optional): maximal amount of commits to fetch if ``commit_sha`` is set (Default value = 10) | ||||||
|  |  | ||||||
|  |         Returns: | ||||||
|  |             str | None: fetched ``commit_sha`` (if set) and ``None`` in case if commit wasn't found or | ||||||
|  |             ``commit_sha`` is not set | ||||||
|         """ |         """ | ||||||
|         commit_sha = commit_sha or "HEAD"  # if none set we just fetch the last commit |         commit_sha = commit_sha or "HEAD"  # if none set we just fetch the last commit | ||||||
|  |  | ||||||
|         commits_count = 1 |         commits_count = 1 | ||||||
|         while commit_sha is not None: |         while commits_count <= max_depth: | ||||||
|             command = self.git() + ["fetch", "--quiet", "--depth", str(commits_count)] |             command = self.git() + ["fetch", "--quiet", "--depth", str(commits_count)] | ||||||
|             if branch is not None: |             if branch is not None: | ||||||
|                 command += ["origin", branch] |                 command += ["origin", branch] | ||||||
| @ -320,10 +327,13 @@ class Sources(LazyLogging): | |||||||
|             try: |             try: | ||||||
|                 # check if there is an object in current git directory |                 # check if there is an object in current git directory | ||||||
|                 check_output(*self.git(), "cat-file", "-e", commit_sha, cwd=sources_dir, logger=self.logger) |                 check_output(*self.git(), "cat-file", "-e", commit_sha, cwd=sources_dir, logger=self.logger) | ||||||
|                 commit_sha = None  # reset search |                 return commit_sha  # found the required commit | ||||||
|             except CalledProcessError: |             except CalledProcessError: | ||||||
|                 commits_count += 1  # increase depth |                 commits_count += 1  # increase depth | ||||||
|  |  | ||||||
|  |         # no commits found at the requested depth | ||||||
|  |         return None | ||||||
|  |  | ||||||
|     def git(self, gitconfig: dict[str, str] | None = None) -> list[str]: |     def git(self, gitconfig: dict[str, str] | None = None) -> list[str]: | ||||||
|         """ |         """ | ||||||
|         git command prefix |         git command prefix | ||||||
|  | |||||||
| @ -153,6 +153,8 @@ class UpdateHandler(PackageInfo, Cleaner): | |||||||
|                     local = packages.get(remote.base) |                     local = packages.get(remote.base) | ||||||
|                     if local is None: |                     if local is None: | ||||||
|                         continue  # we don't add packages automatically |                         continue  # we don't add packages automatically | ||||||
|  |                     if local.remote.is_remote: | ||||||
|  |                         continue  # avoid checking AUR packages | ||||||
|  |  | ||||||
|                     if local.is_outdated(remote, self.paths, |                     if local.is_outdated(remote, self.paths, | ||||||
|                                          vcs_allowed_age=self.vcs_allowed_age, |                                          vcs_allowed_age=self.vcs_allowed_age, | ||||||
|  | |||||||
| @ -24,6 +24,7 @@ def _default_args(args: argparse.Namespace) -> argparse.Namespace: | |||||||
|         argparse.Namespace: generated arguments for these test cases |         argparse.Namespace: generated arguments for these test cases | ||||||
|     """ |     """ | ||||||
|     args.package = ["ahriman"] |     args.package = ["ahriman"] | ||||||
|  |     args.changes = True | ||||||
|     args.exit_code = False |     args.exit_code = False | ||||||
|     args.increment = True |     args.increment = True | ||||||
|     args.now = False |     args.now = False | ||||||
| @ -82,6 +83,7 @@ def test_run_with_updates(args: argparse.Namespace, configuration: Configuration | |||||||
|     mocker.patch("ahriman.core.repository.Repository.load", return_value=repository) |     mocker.patch("ahriman.core.repository.Repository.load", return_value=repository) | ||||||
|     application_mock = mocker.patch("ahriman.application.application.Application.update", return_value=result) |     application_mock = mocker.patch("ahriman.application.application.Application.update", return_value=result) | ||||||
|     check_mock = mocker.patch("ahriman.application.handlers.Handler.check_if_empty") |     check_mock = mocker.patch("ahriman.application.handlers.Handler.check_if_empty") | ||||||
|  |     changes_mock = mocker.patch("ahriman.application.application.Application.changes") | ||||||
|     updates_mock = mocker.patch("ahriman.application.application.Application.updates", return_value=[package_ahriman]) |     updates_mock = mocker.patch("ahriman.application.application.Application.updates", return_value=[package_ahriman]) | ||||||
|     dependencies_mock = mocker.patch("ahriman.application.application.Application.with_dependencies", |     dependencies_mock = mocker.patch("ahriman.application.application.Application.with_dependencies", | ||||||
|                                      return_value=[package_ahriman]) |                                      return_value=[package_ahriman]) | ||||||
| @ -91,6 +93,7 @@ def test_run_with_updates(args: argparse.Namespace, configuration: Configuration | |||||||
|     Add.run(args, repository_id, configuration, report=False) |     Add.run(args, repository_id, configuration, report=False) | ||||||
|     updates_mock.assert_called_once_with(args.package, |     updates_mock.assert_called_once_with(args.package, | ||||||
|                                          aur=False, local=False, manual=True, vcs=False, check_files=False) |                                          aur=False, local=False, manual=True, vcs=False, check_files=False) | ||||||
|  |     changes_mock.assert_called_once_with([package_ahriman]) | ||||||
|     application_mock.assert_called_once_with([package_ahriman], |     application_mock.assert_called_once_with([package_ahriman], | ||||||
|                                              Packagers(args.username, {package_ahriman.base: "packager"}), |                                              Packagers(args.username, {package_ahriman.base: "packager"}), | ||||||
|                                              bump_pkgrel=args.increment) |                                              bump_pkgrel=args.increment) | ||||||
| @ -99,6 +102,28 @@ def test_run_with_updates(args: argparse.Namespace, configuration: Configuration | |||||||
|     print_mock.assert_called_once_with([package_ahriman], log_fn=pytest.helpers.anyvar(int)) |     print_mock.assert_called_once_with([package_ahriman], log_fn=pytest.helpers.anyvar(int)) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def test_run_no_changes(args: argparse.Namespace, configuration: Configuration, repository: Repository, | ||||||
|  |                         mocker: MockerFixture) -> None: | ||||||
|  |     """ | ||||||
|  |     must skip changes calculation during package addition | ||||||
|  |     """ | ||||||
|  |     args = _default_args(args) | ||||||
|  |     args.now = True | ||||||
|  |     args.changes = False | ||||||
|  |     mocker.patch("ahriman.application.application.Application.add") | ||||||
|  |     mocker.patch("ahriman.core.repository.Repository.load", return_value=repository) | ||||||
|  |     mocker.patch("ahriman.application.application.Application.update") | ||||||
|  |     mocker.patch("ahriman.application.handlers.Handler.check_if_empty") | ||||||
|  |     mocker.patch("ahriman.application.application.Application.updates") | ||||||
|  |     mocker.patch("ahriman.application.application.Application.with_dependencies") | ||||||
|  |     mocker.patch("ahriman.application.application.Application.print_updates") | ||||||
|  |     changes_mock = mocker.patch("ahriman.application.application.Application.changes") | ||||||
|  |  | ||||||
|  |     _, repository_id = configuration.check_loaded() | ||||||
|  |     Add.run(args, repository_id, configuration, report=False) | ||||||
|  |     changes_mock.assert_not_called() | ||||||
|  |  | ||||||
|  |  | ||||||
| def test_run_empty_exception(args: argparse.Namespace, configuration: Configuration, repository: Repository, | def test_run_empty_exception(args: argparse.Namespace, configuration: Configuration, repository: Repository, | ||||||
|                              mocker: MockerFixture) -> None: |                              mocker: MockerFixture) -> None: | ||||||
|     """ |     """ | ||||||
|  | |||||||
| @ -39,6 +39,17 @@ def test_changes_skip(mocker: MockerFixture) -> None: | |||||||
|     diff_mock.assert_not_called() |     diff_mock.assert_not_called() | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def test_changes_unknown_commit(mocker: MockerFixture) -> None: | ||||||
|  |     """ | ||||||
|  |     must return none in case if commit sha wasn't found at the required depth | ||||||
|  |     """ | ||||||
|  |     mocker.patch("ahriman.core.build_tools.sources.Sources.fetch_until", return_value=None) | ||||||
|  |     diff_mock = mocker.patch("ahriman.core.build_tools.sources.Sources.diff") | ||||||
|  |  | ||||||
|  |     assert Sources.changes(Path("local"), "sha") is None | ||||||
|  |     diff_mock.assert_not_called() | ||||||
|  |  | ||||||
|  |  | ||||||
| def test_extend_architectures(mocker: MockerFixture) -> None: | def test_extend_architectures(mocker: MockerFixture) -> None: | ||||||
|     """ |     """ | ||||||
|     must update available architecture list |     must update available architecture list | ||||||
| @ -435,16 +446,17 @@ def test_fetch_until(sources: Sources, mocker: MockerFixture) -> None: | |||||||
|         "", |         "", | ||||||
|         "", |         "", | ||||||
|     ]) |     ]) | ||||||
|  |  | ||||||
|     local = Path("local") |     local = Path("local") | ||||||
|     sources.fetch_until(local, branch="master", commit_sha="sha") |     last_commit_sha = "sha" | ||||||
|  |  | ||||||
|  |     assert sources.fetch_until(local, branch="master", commit_sha="sha") == last_commit_sha | ||||||
|     check_output_mock.assert_has_calls([ |     check_output_mock.assert_has_calls([ | ||||||
|         MockCall(*sources.git(), "fetch", "--quiet", "--depth", "1", "origin", "master", |         MockCall(*sources.git(), "fetch", "--quiet", "--depth", "1", "origin", "master", | ||||||
|                  cwd=local, logger=sources.logger), |                  cwd=local, logger=sources.logger), | ||||||
|         MockCall(*sources.git(), "cat-file", "-e", "sha", cwd=local, logger=sources.logger), |         MockCall(*sources.git(), "cat-file", "-e", last_commit_sha, cwd=local, logger=sources.logger), | ||||||
|         MockCall(*sources.git(), "fetch", "--quiet", "--depth", "2", "origin", "master", |         MockCall(*sources.git(), "fetch", "--quiet", "--depth", "2", "origin", "master", | ||||||
|                  cwd=local, logger=sources.logger), |                  cwd=local, logger=sources.logger), | ||||||
|         MockCall(*sources.git(), "cat-file", "-e", "sha", cwd=local, logger=sources.logger), |         MockCall(*sources.git(), "cat-file", "-e", last_commit_sha, cwd=local, logger=sources.logger), | ||||||
|     ]) |     ]) | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -453,9 +465,9 @@ def test_fetch_until_first(sources: Sources, mocker: MockerFixture) -> None: | |||||||
|     must fetch first commit only |     must fetch first commit only | ||||||
|     """ |     """ | ||||||
|     check_output_mock = mocker.patch("ahriman.core.build_tools.sources.check_output") |     check_output_mock = mocker.patch("ahriman.core.build_tools.sources.check_output") | ||||||
|  |  | ||||||
|     local = Path("local") |     local = Path("local") | ||||||
|     sources.fetch_until(local, branch="master") |  | ||||||
|  |     assert sources.fetch_until(local, branch="master") == "HEAD" | ||||||
|     check_output_mock.assert_has_calls([ |     check_output_mock.assert_has_calls([ | ||||||
|         MockCall(*sources.git(), "fetch", "--quiet", "--depth", "1", "origin", "master", |         MockCall(*sources.git(), "fetch", "--quiet", "--depth", "1", "origin", "master", | ||||||
|                  cwd=local, logger=sources.logger), |                  cwd=local, logger=sources.logger), | ||||||
| @ -468,15 +480,28 @@ def test_fetch_until_all_branches(sources: Sources, mocker: MockerFixture) -> No | |||||||
|     must fetch all branches |     must fetch all branches | ||||||
|     """ |     """ | ||||||
|     check_output_mock = mocker.patch("ahriman.core.build_tools.sources.check_output") |     check_output_mock = mocker.patch("ahriman.core.build_tools.sources.check_output") | ||||||
|  |  | ||||||
|     local = Path("local") |     local = Path("local") | ||||||
|     sources.fetch_until(local) |  | ||||||
|  |     assert sources.fetch_until(local) == "HEAD" | ||||||
|     check_output_mock.assert_has_calls([ |     check_output_mock.assert_has_calls([ | ||||||
|         MockCall(*sources.git(), "fetch", "--quiet", "--depth", "1", cwd=local, logger=sources.logger), |         MockCall(*sources.git(), "fetch", "--quiet", "--depth", "1", cwd=local, logger=sources.logger), | ||||||
|         MockCall(*sources.git(), "cat-file", "-e", "HEAD", cwd=local, logger=sources.logger), |         MockCall(*sources.git(), "cat-file", "-e", "HEAD", cwd=local, logger=sources.logger), | ||||||
|     ]) |     ]) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def test_fetch_until_not_found(sources: Sources, mocker: MockerFixture) -> None: | ||||||
|  |     """ | ||||||
|  |     must return None in case if no commit found at the required maximal depth | ||||||
|  |     """ | ||||||
|  |     mocker.patch("ahriman.core.build_tools.sources.check_output", side_effect=[ | ||||||
|  |         "", | ||||||
|  |         CalledProcessError(1, ["command"], "error"), | ||||||
|  |         "", | ||||||
|  |         CalledProcessError(1, ["command"], "error"), | ||||||
|  |     ]) | ||||||
|  |     assert sources.fetch_until(Path("local"), branch="master", commit_sha="sha", max_depth=2) is None | ||||||
|  |  | ||||||
|  |  | ||||||
| def test_git(sources: Sources) -> None: | def test_git(sources: Sources) -> None: | ||||||
|     """ |     """ | ||||||
|     must correctly generate git command |     must correctly generate git command | ||||||
|  | |||||||
| @ -212,6 +212,7 @@ def test_updates_local(update_handler: UpdateHandler, package_ahriman: Package, | |||||||
|     """ |     """ | ||||||
|     must check for updates for locally stored packages |     must check for updates for locally stored packages | ||||||
|     """ |     """ | ||||||
|  |     package_ahriman.remote = RemoteSource(source=PackageSource.Local, git_url="", web_url="", path="", branch="") | ||||||
|     mocker.patch("ahriman.core.repository.update_handler.UpdateHandler.packages", return_value=[package_ahriman]) |     mocker.patch("ahriman.core.repository.update_handler.UpdateHandler.packages", return_value=[package_ahriman]) | ||||||
|     mocker.patch("pathlib.Path.iterdir", return_value=[Path(package_ahriman.base)]) |     mocker.patch("pathlib.Path.iterdir", return_value=[Path(package_ahriman.base)]) | ||||||
|     fetch_mock = mocker.patch("ahriman.core.build_tools.sources.Sources.fetch") |     fetch_mock = mocker.patch("ahriman.core.build_tools.sources.Sources.fetch") | ||||||
| @ -237,6 +238,7 @@ def test_updates_local_ignore_vcs(update_handler: UpdateHandler, package_ahriman | |||||||
|     """ |     """ | ||||||
|     must skip VCS packages check if requested for locally stored packages |     must skip VCS packages check if requested for locally stored packages | ||||||
|     """ |     """ | ||||||
|  |     package_ahriman.remote = RemoteSource(source=PackageSource.Local, git_url="", web_url="", path="", branch="") | ||||||
|     mocker.patch("ahriman.core.repository.update_handler.UpdateHandler.packages", return_value=[package_ahriman]) |     mocker.patch("ahriman.core.repository.update_handler.UpdateHandler.packages", return_value=[package_ahriman]) | ||||||
|     mocker.patch("pathlib.Path.iterdir", return_value=[Path(package_ahriman.base)]) |     mocker.patch("pathlib.Path.iterdir", return_value=[Path(package_ahriman.base)]) | ||||||
|     mocker.patch("ahriman.core.build_tools.sources.Sources.fetch") |     mocker.patch("ahriman.core.build_tools.sources.Sources.fetch") | ||||||
| @ -263,6 +265,19 @@ def test_updates_local_unknown(update_handler: UpdateHandler, package_ahriman: P | |||||||
|     assert update_handler.updates_local(vcs=True) == [] |     assert update_handler.updates_local(vcs=True) == [] | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def test_updates_local_remote(update_handler: UpdateHandler, package_ahriman: Package, mocker: MockerFixture) -> None: | ||||||
|  |     """ | ||||||
|  |     must skip packages with remote source | ||||||
|  |     """ | ||||||
|  |     mocker.patch("ahriman.core.repository.update_handler.UpdateHandler.packages", return_value=[package_ahriman]) | ||||||
|  |     mocker.patch("pathlib.Path.iterdir", return_value=[Path(package_ahriman.base)]) | ||||||
|  |     mocker.patch("ahriman.models.package.Package.is_outdated", return_value=True) | ||||||
|  |     mocker.patch("ahriman.core.build_tools.sources.Sources.fetch") | ||||||
|  |     mocker.patch("ahriman.models.package.Package.from_build", return_value=package_ahriman) | ||||||
|  |  | ||||||
|  |     assert update_handler.updates_local(vcs=True) == [] | ||||||
|  |  | ||||||
|  |  | ||||||
| def test_updates_local_with_failures(update_handler: UpdateHandler, package_ahriman: Package, | def test_updates_local_with_failures(update_handler: UpdateHandler, package_ahriman: Package, | ||||||
|                                      mocker: MockerFixture) -> None: |                                      mocker: MockerFixture) -> None: | ||||||
|     """ |     """ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user