Bug #32449
closedpulp3_migration_stats rake task can underestimate the migration timing
Description
Cloned from https://bugzilla.redhat.com/show_bug.cgi?id=1954820
Description of problem:
Internally, there is an error with the migration timing code that can cause a variable to go negative. This can occur if the user has many on-demand repositories that are included in content views.
The fix involves changing this line (https://github.com/Katello/katello/blob/KATELLO-3.18/lib/katello/tasks/pulp3_migration_stats.rake#L13) to be `Katello::RepositoryRpm.where(:repository_id => Katello::Repository.yum_type.on_demand).select(:rpm_id).distinct.count`.
Version-Release number of selected component (if applicable):
3.18
How reproducible:
Always, if there are on-demand repositories inside of content views.
Steps to Reproduce:
1. Create any repository that is on-demand
2. Put that repository in a content view and publish it
3. Run `Katello::RepositoryRpm.where(:repository_id => Katello::Repository.yum_type.on_demand).distinct.count` in the foreman console and notice that it is negative.
Actual results:
The `on_demand_rpm_count` is negative, which causes the estimation time to be too low.
Expected results:
The `on_demand_rpm_count` is accurate.
Additional info: