mirror of
				https://github.com/arcan1s/ahriman.git
				synced 2025-10-25 10:53:45 +00:00 
			
		
		
		
	fix: update Repo.init to the latest pacman release
This commit is contained in:
		| @ -68,7 +68,7 @@ class Repo(LazyLogging): | |||||||
|             path(Path): path to archive to add |             path(Path): path to archive to add | ||||||
|         """ |         """ | ||||||
|         check_output( |         check_output( | ||||||
|             "repo-add", *self.sign_args, "-R", str(self.repo_path), str(path), |             "repo-add", *self.sign_args, "--remove", str(self.repo_path), str(path), | ||||||
|             exception=BuildError.from_process(path.name), |             exception=BuildError.from_process(path.name), | ||||||
|             cwd=self.paths.repository, |             cwd=self.paths.repository, | ||||||
|             logger=self.logger, |             logger=self.logger, | ||||||
| @ -78,8 +78,13 @@ class Repo(LazyLogging): | |||||||
|         """ |         """ | ||||||
|         create empty repository database. It just calls add with empty arguments |         create empty repository database. It just calls add with empty arguments | ||||||
|         """ |         """ | ||||||
|         check_output("repo-add", *self.sign_args, str(self.repo_path), |         # since pacman-6.1.0 repo-add doesn't create empty database in case if no packages supplied | ||||||
|                      cwd=self.paths.repository, logger=self.logger, user=self.uid) |         # this code creates empty files instead | ||||||
|  |         if self.repo_path.exists(): | ||||||
|  |             return  # database is already created, skip this part | ||||||
|  |  | ||||||
|  |         self.repo_path.touch(exist_ok=True) | ||||||
|  |         (self.paths.repository / f"{self.name}.db").symlink_to(self.repo_path) | ||||||
|  |  | ||||||
|     def remove(self, package: str, filename: Path) -> None: |     def remove(self, package: str, filename: Path) -> None: | ||||||
|         """ |         """ | ||||||
|  | |||||||
| @ -26,13 +26,28 @@ def test_repo_add(repo: Repo, mocker: MockerFixture) -> None: | |||||||
|  |  | ||||||
| def test_repo_init(repo: Repo, mocker: MockerFixture) -> None: | def test_repo_init(repo: Repo, mocker: MockerFixture) -> None: | ||||||
|     """ |     """ | ||||||
|     must call repo-add with empty package list on repo initializing |     must create empty database files | ||||||
|     """ |     """ | ||||||
|     check_output_mock = mocker.patch("ahriman.core.alpm.repo.check_output") |     mocker.patch("pathlib.Path.exists", return_value=False) | ||||||
|  |     touch_mock = mocker.patch("pathlib.Path.touch") | ||||||
|  |     symlink_mock = mocker.patch("pathlib.Path.symlink_to") | ||||||
|  |  | ||||||
|     repo.init() |     repo.init() | ||||||
|     check_output_mock.assert_called_once()  # it will be checked later |     touch_mock.assert_called_once_with(exist_ok=True) | ||||||
|     assert check_output_mock.call_args[0][0] == "repo-add" |     symlink_mock.assert_called_once_with(repo.repo_path) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def test_repo_init_skip(repo: Repo, mocker: MockerFixture) -> None: | ||||||
|  |     """ | ||||||
|  |     must do not create files if database already exists | ||||||
|  |     """ | ||||||
|  |     mocker.patch("pathlib.Path.exists", return_value=True) | ||||||
|  |     touch_mock = mocker.patch("pathlib.Path.touch") | ||||||
|  |     symlink_mock = mocker.patch("pathlib.Path.symlink_to") | ||||||
|  |  | ||||||
|  |     repo.init() | ||||||
|  |     touch_mock.assert_not_called() | ||||||
|  |     symlink_mock.assert_not_called() | ||||||
|  |  | ||||||
|  |  | ||||||
| def test_repo_remove(repo: Repo, mocker: MockerFixture) -> None: | def test_repo_remove(repo: Repo, mocker: MockerFixture) -> None: | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user