Skip to content

Commit

Permalink
Don't run MiqExpression twice on reports
Browse files Browse the repository at this point in the history
We are already passing conditions into Rbac.filtered, so the
MiqExpression will be applied in rbac. There is no reason to
also apply it to the where clause here.

The reason for making this change now, is we are changing the
way the references from an MiqExpression are added.
(instead of using a hash, we're converting into an array)
I prefer to make this code introduction in as few places as
possible.
  • Loading branch information
kbrock committed Sep 27, 2019
1 parent 154aed5 commit 3638143
Showing 1 changed file with 2 additions and 9 deletions.
11 changes: 2 additions & 9 deletions app/models/miq_report/generator.rb
Original file line number Diff line number Diff line change
Expand Up @@ -250,18 +250,15 @@ def generate_performance_results(options = {})
def generate_daily_metric_rollup_results(options = {})
unless conditions.nil?
conditions.preprocess_options = {:vim_performance_daily_adhoc => (time_profile && time_profile.rollup_daily_metrics)}
exp_sql, exp_includes = conditions.to_sql
# only_cols += conditions.columns_for_sql # Add cols references in expression to ensure they are present for evaluation
end

time_range = Metric::Helper.time_range_from_offset(interval, db_options[:start_offset], db_options[:end_offset], tz)
results = Metric::Helper.find_for_interval_name('daily', time_profile || tz, db_klass)
.where(where_clause).where(exp_sql)
.where(where_clause)
.where(options[:where_clause])
.where(:timestamp => time_range)
.includes(get_include_for_find)
.references(Rbac.includes_to_references(db_klass, get_include))
.includes(exp_includes || [])
.limit(options[:limit])
results = Rbac.filtered(results, :class => db,
:filter => conditions,
Expand All @@ -274,18 +271,14 @@ def generate_daily_metric_rollup_results(options = {})
def generate_interval_metric_results(options = {})
time_range = Metric::Helper.time_range_from_offset(interval, db_options[:start_offset], db_options[:end_offset])

# Only build where clause from expression for hourly report. It will not work properly for daily because many values are rolled up from hourly.
exp_sql, exp_includes = conditions.to_sql(tz) unless conditions.nil? || db_klass.respond_to?(:instances_are_derived?)

results = db_klass.with_interval_and_time_range(interval, time_range)
.where(where_clause)
.where(options[:where_clause])
.where(exp_sql)
.includes(get_include_for_find)
.references(Rbac.includes_to_references(db_klass, get_include))
.includes(exp_includes || [])
.limit(options[:limit])

# Rbac will only add miq_expression for hourly report. It will not work properly for daily because many values are rolled up from hourly.
results = Rbac.filtered(results, :class => db,
:filter => conditions,
:userid => options[:userid],
Expand Down

0 comments on commit 3638143

Please sign in to comment.