Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

DNF5 prototype #5857

Draft
wants to merge 42 commits into
base: main
Choose a base branch
from
Draft

Conversation

pkratoch
Copy link
Contributor

No description provided.

@pep8speaks
Copy link

pep8speaks commented Aug 28, 2024

Hello @pkratoch! Thanks for updating this PR. We checked the lines you've touched for PEP 8 issues, and found:

Line 106:13: E265 block comment should start with '# '
Line 135:13: E265 block comment should start with '# '

Line 514:100: E501 line too long (100 > 99 characters)

Line 26:1: E265 block comment should start with '# '
Line 31:1: E265 block comment should start with '# '
Line 32:1: E265 block comment should start with '# '
Line 33:1: E265 block comment should start with '# '
Line 34:1: E265 block comment should start with '# '
Line 35:1: E265 block comment should start with '# '
Line 36:1: E265 block comment should start with '# '

Comment last updated at 2025-01-16 15:20:04 UTC

@github-actions github-actions bot added the f42 Fedora 42 label Aug 28, 2024
@pkratoch
Copy link
Contributor Author

This dnf5 PR is needed for the prototype to finish the installation: rpm-software-management/dnf5#1697

Comment on lines 88 to 113
class DNFConfigWrapper(object):
"""This is a temporary wrapper of a DNF config object."""

def __init__(self, config):
"""Wrap the DNF config object."""
self._config = config

def __getattr__(self, name):
"""Get the attribute.

Called when an attribute lookup has not found
the attribute in the usual places.
"""
option = getattr(self._config, name)()
return option.get_value()

def __setattr__(self, name, value):
"""Set the attribute.

Called when an attribute assignment is attempted.
"""
if name in ["_config"]:
return super().__setattr__(name, value)

option = getattr(self._config, name)()
option.set(value)
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Regarding the DNFConfigWrapper, right now, it is quite ugly, since the option names are in the form get_<name>_option. I have two possible solutions:

  1. Remove the wrapper and access the options directly. This would look like this:

    config.get_cachedir_option().get_value()
    config.get_cachedir_option().set(DNF_CACHE_DIR)
    
  2. Keep the wrapper, but use simple <name> form in anaconda and wrap it with "get_" + name + "_option" in the DNFConfigWrapper.

The second solution would mean more readable access to the options, but the disadvantage is that it relies on a specific naming scheme in libdnf5. This could become a problem if we needed something else from the config e.g. to load config from parser (ConfigMain::load_from_parser), but it's not needed now. I prefer the second solution, but I don't know why the DNFConfigWrapper is described as temporary and what was the plan for future.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think i prefer to remove the wrapper. Or if you keep the wrapper, create access getters and settings for all used attributes.
I am not fond of the 2nd option - where we assume the "get" + name + "_option" naming scheme
As this can break easily
Does it make sense?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I changed the wrapper to contain all the necessary options as properties. It got quite long, so let me know if it's acceptable. Maybe it could be moved to a separate file? Alternatively, I will change it to remove the wrapper entirely.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@pkratoch I like it how it is now. Thanks

@pkratoch
Copy link
Contributor Author

I also pushed 2 commits changing the mocking in unit tests. Sorry I didn't notice it sooner that the tests do not pass. I am not totally sure about the second one that adds the try block, though. It's ok to do it like that in the test, but I am not sure if we can rely on dnf always sending the quit or error callback. If dnf crashed and didn't send anything, anaconda would wait forever. But I don't think there is anything that can be done on anaconda side.

Also, I put the commits on top of the branch, but I would like to eventually amend the relevant commits in history, so that the history is not so chaotic. Let me know if it's ok to do that.

@KKoukiou
Copy link
Contributor

I also pushed 2 commits changing the mocking in unit tests. Sorry I didn't notice it sooner that the tests do not pass. I am not totally sure about the second one that adds the try block, though. It's ok to do it like that in the test, but I am not sure if we can rely on dnf always sending the quit or error callback. If dnf crashed and didn't send anything, anaconda would wait forever. But I don't think there is anything that can be done on anaconda side.

Also, I put the commits on top of the branch, but I would like to eventually amend the relevant commits in history, so that the history is not so chaotic. Let me know if it's ok to do that.

Sure feel free to amend.

@pkratoch pkratoch force-pushed the master-dnf5_prototype branch from ed6f3f2 to 0365101 Compare September 19, 2024 09:24
@pkratoch pkratoch force-pushed the master-dnf5_prototype branch from 0365101 to 34f137e Compare September 19, 2024 09:26
@pkratoch pkratoch force-pushed the master-dnf5_prototype branch from 34f137e to fca17eb Compare September 24, 2024 13:11
@pkratoch pkratoch force-pushed the master-dnf5_prototype branch from fca17eb to c5b29fc Compare September 26, 2024 11:31
@pkratoch pkratoch force-pushed the master-dnf5_prototype branch from c5b29fc to d34a250 Compare September 30, 2024 11:52
@pkratoch pkratoch force-pushed the master-dnf5_prototype branch from d34a250 to 4c78c94 Compare October 29, 2024 08:09
@pkratoch pkratoch force-pushed the master-dnf5_prototype branch from 4c78c94 to b2d9c31 Compare November 6, 2024 14:45

@property
def baseurl(self):
return self._config.get_baseurl_option().get_value()

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems not necessary as dnf5 is already providing these attributes in Python bindings. Check the implementation in our SWIG interface file and e.g. this test.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh, wow, how did I miss that? It was even done in the same PR as the renaming, but I guess I focused too much on how the wrapped had been done before that I didn't notice. This is really neat, I will change the PR to drop the wrapper and use the attributes directly.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this is the case, when presenting a simple demo of new features added to our projects during the sprint review or retrospective would be useful. 🙂

The ValidationReport is now created within the mocked
DNFManager.resolve_selection, so it must be mocked as well.
Also, there are no longer exceptions raised from the DNF transaction,
instead, the problems are stored in a report, so there are no
exceptions to mock.
The transaction callbacks take libdnf5::base::TransactionPackage, not
libdnf5::transaction::Package.
The base is no longer being closed and the resetting of base is tested
in test_module_payload_dnf5_manager.DNFManagerTestCase.test_reset_base.
These tests probably didn't work at the time they were marked as
skipped, but are working now.
The transaction can fail even if it doesn't contain any transaction
items with an error status.
The transaction_stop is actually for RPMCALLBACK_TRANS_STOP from rpm,
which is only the end of preparation phase. The after_complete is called
by dnf after the whole transaction completes.

Also, the queue cannot be closed at this point, because transaction
errors are written there after the transaction completes and then
TransactionProgress.quit is called, which closes the queue as well.
In libdnf5, the `repos_updated_and_loaded` bool attribute, which serves
the same purpose, is private.

Check if the repositories are loaded before making queries.
To reset the repo sack, the whole base must be created anew, because it
is not possible to lead repositories multiple times in dnf5.
There is no way to remove a repository from the RepoSack without dropping
the entire Base. Therefore, a repository can be only configured again,
but not replaced. Since it cannot be removed, the test for repository
removal was removed as well.
Progress is reported as summary of how much is downloaded out of total.

This also removes the debug logs for all the progress messages and adds
only logs for starting and finishing the downloads. The debug logs cannot
be in the _report_progress class, because that one is paced.
The exceptions are not actually raised anywhere and the report is now
constructed right away in the resolve_selection method, so it doesn't
make sense to raise these and catch elsewhere to add the messages to
the report as it was done previously.
The `_goal.add_remove` was not a correct way to exclude packages, since
dnf then just complained that the spec was not found and, therefore,
couldn't be removed.
@pkratoch
Copy link
Contributor Author

Hi, @M4rtinK, I pushed a commit which adds the progress during package installation (the (installed/total) numbers). I am not adding it for the configuration, because that's just callbacks for scriptlets running and it's not actually a phase, since some scriptlets (pre-install) are running in between the package installs. Also, there is no progress to report coming from dnf.

I have yet to look into the comps order and kickstart tests results.

@M4rtinK
Copy link
Contributor

M4rtinK commented Jan 20, 2025

Hi, @M4rtinK, I pushed a commit which adds the progress during package installation (the (installed/total) numbers). I am not adding it for the configuration, because that's just callbacks for scriptlets running and it's not actually a phase, since some scriptlets (pre-install) are running in between the package installs. Also, there is no progress to report coming from dnf.

That's totally fine - I was wondering why it was not implemented before for the configuration phase & I guess it was likely similar architectural limitations. :)

I have yet to look into the comps order and kickstart tests results.

ACK :)

@pkratoch
Copy link
Contributor Author

Regarding the repo-* tests, I think the root cause of their failures is actually, surprisingly, that dnf5 cannot yet merge group definitions from multiple repositories: rpm-software-management/dnf5#183

The optional-package-from-addon-a is installed, because it's explicitely mentioned in the %packages section, but the mandatory-package-from-addon-a comes from group @core defined in the additional repo, but the same group is also in the Fedora repository and only one definition (from the Fedora repo) is taken.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
f42 Fedora 42
Development

Successfully merging this pull request may close these issues.

6 participants