198 lines
9.7 KiB
Ruby
198 lines
9.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Additionals
|
|
module GlobalTestHelper
|
|
def after_setup
|
|
return super unless defined?(Bullet) && Bullet.enable?
|
|
|
|
Bullet.unused_eager_loading_enable = false
|
|
Bullet.raise = true
|
|
# @see https://github.com/flyerhzm/bullet#safe-list
|
|
# ignore missing n+1 problems in redmine core
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Attachment', association: :author
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Attachment', association: :container
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Board', association: :messages
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Dashboard', association: :author
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Dashboard', association: :dashboard_roles
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Dashboard', association: :project
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Issue', association: :assigned_to
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Issue', association: :category
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Issue', association: :custom_values
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Issue', association: :fixed_version
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Issue', association: :parent
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Issue', association: :tracker
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Journal', association: :details
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Journal', association: :journal_message
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Journal', association: :journalized
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Member', association: :member_roles
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Member', association: :project
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Message', association: :attachments
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Message', association: :children
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Message', association: :parent
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'News', association: :attachments
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :attachments
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :boards
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :contacts
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :dashboards
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :db_entries
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :documents
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :helpdesk_setting
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :invoice_setting
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :invoices
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :issues
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :messenger_setting
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :news
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :parent
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :passwords
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :repositories
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :tag_taggings
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :taggings
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :time_entries
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :versions
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Project', association: :wiki
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'TimeEntry', association: :automation_schedule
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'TimeEntry', association: :reporting_cost
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Tracker', association: :default_status
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'User', association: :local_avatar
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'User', association: :preference
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'Version', association: :attachments
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'WikiContent', association: :page
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'WikiPage', association: :attachments
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'WikiPage', association: :content
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'WikiPage', association: :links_from
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'WikiPage', association: :tag_taggings
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'WikiPage', association: :taggings
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'WikiPage', association: :wiki
|
|
Bullet.add_safelist type: :n_plus_one_query, class_name: 'WikiPage', association: :wiki_page_votes
|
|
Bullet.start_request
|
|
super
|
|
end
|
|
|
|
def before_teardown
|
|
super
|
|
return unless defined?(Bullet) && Bullet.enable?
|
|
|
|
Bullet.perform_out_of_channel_notifications if Bullet.notification?
|
|
Bullet.end_request
|
|
Bullet.raise = false
|
|
end
|
|
|
|
def assert_select_td_column(column_name, colspan: nil)
|
|
c = column_name.to_s
|
|
.gsub('issue.cf', 'issue_cf')
|
|
.gsub('project.cf', 'project_cf')
|
|
.gsub('user.cf', 'user_cf')
|
|
.tr('.', '-')
|
|
|
|
spec = +"td.#{c}"
|
|
spec << "[colspan='#{colspan}']" if colspan
|
|
assert_select spec
|
|
end
|
|
|
|
def assert_select_totalable_columns(columns)
|
|
assert_select 'p.query-totals' do
|
|
columns.each do |column_name|
|
|
c = column_name.to_s
|
|
.tr('_', '-')
|
|
|
|
assert_select ".total-for-#{c} span.value"
|
|
end
|
|
end
|
|
end
|
|
|
|
def assert_select_grouped_column(column_name)
|
|
assert_select 'tr.group.open', {}, "grouped_by with #{column_name} is missing tr.group.open"
|
|
end
|
|
|
|
def assert_select_query_tr(inline_columns:, block_columns:, inline_tr_select:, block_tr_select:, with_checkbox: true)
|
|
assert_select inline_tr_select do
|
|
inline_columns.each do |column_name|
|
|
assert_select_td_column column_name
|
|
end
|
|
end
|
|
|
|
colspan = inline_columns.count + 2
|
|
colspan -= 1 unless with_checkbox
|
|
assert_select block_tr_select do
|
|
block_columns.each do |column_name|
|
|
assert_select_td_column column_name, colspan: colspan
|
|
end
|
|
end
|
|
end
|
|
|
|
def with_plugin_settings(plugin, settings, &_block)
|
|
change_plugin_settings plugin, settings
|
|
yield
|
|
ensure
|
|
restore_plugin_settings plugin
|
|
end
|
|
|
|
def change_plugin_settings(plugin, settings)
|
|
instance_variable_set "@saved_#{plugin}_settings", Setting.send("plugin_#{plugin}").dup
|
|
new_settings = Setting.send("plugin_#{plugin}").dup
|
|
settings.each do |key, value|
|
|
new_settings[key] = value
|
|
end
|
|
|
|
Setting.send "plugin_#{plugin}=", new_settings
|
|
Setting.send :"plugin_#{plugin}=", new_settings
|
|
end
|
|
|
|
def restore_plugin_settings(plugin)
|
|
settings = instance_variable_get "@saved_#{plugin}_settings"
|
|
if settings
|
|
Setting.send "plugin_#{plugin}=", settings
|
|
Setting.send :"plugin_#{plugin}=", settings
|
|
else
|
|
Rails.logger.warn "warning: restore_plugin_settings could not restore settings for #{plugin}"
|
|
end
|
|
end
|
|
|
|
def assert_sorted_equal(list1, list2, comment = nil)
|
|
assert_equal list1.sort, list2.sort, comment
|
|
end
|
|
|
|
def assert_query_sort_order(table_css, column, action: nil, list_columns: [], params: {})
|
|
action = :index if action.blank?
|
|
column = column.to_s
|
|
column_css = column.tr('_', '-').gsub('.', '\.')
|
|
columns = (list_columns << column).uniq
|
|
|
|
params[:sort] = "#{column}:asc"
|
|
params[:c] = columns
|
|
|
|
get action, params: params
|
|
|
|
assert_response :success
|
|
assert_select "table.list.#{table_css}.sort-by-#{column_css}.sort-asc"
|
|
|
|
params[:sort] = "#{column}:desc"
|
|
|
|
get action, params: params
|
|
|
|
assert_response :success
|
|
assert_select "table.list.#{table_css}.sort-by-#{column_css}.sort-desc"
|
|
end
|
|
|
|
def assert_dashboard_query_blocks(blocks = [])
|
|
blocks.each do |block_def|
|
|
block_def[:user_id]
|
|
@request.session[:user_id] = block_def[:user_id].presence || 2
|
|
get block_def[:action].presence || :show,
|
|
params: { dashboard_id: block_def[:dashboard_id],
|
|
block: block_def[:block],
|
|
project_id: block_def[:project],
|
|
format: 'js' }
|
|
|
|
assert_response :success, "assert_response for #{block_def[:block]}"
|
|
assert_select "table.list.#{block_def[:entities_class]}"
|
|
end
|
|
end
|
|
|
|
# Return the columns that are displayed in the list
|
|
def columns_in_projects_list
|
|
css_select('table.projects thead th').map(&:text)
|
|
end
|
|
end
|
|
end
|