Project

General

Profile

Actions

Idea #2871

closed

Improve workbench performance by using helper methods to cache API lookups during view rendering

Added by Tom Clegg over 10 years ago. Updated over 10 years ago.

Status:
Resolved
Priority:
Normal
Assigned To:
Radhika Chippada
Category:
-
Start date:
06/05/2014
Due date:
Story points:
3.0

Description

Example pages
  • Show new/ready pipeline instance with lots of collections in script_parameters (e.g., GATK exome pipeline): this currently does multiple API lookups for each "select a collection" drop-down.
  • Dashboard has a similar problem
  • "Metadata" tab on a "show" page does multiple API lookups for each link it displays
Approach
  • For a common type of lookup like "links pointing to X", create helper methods in ApplicationController to handle preloading and on-demand lookups.
helper_method :links_for_object
def links_for_object object_or_uuid
  uuid = object_or_uuid.is_a?(String) ? object_or_uuid : object_or_uuid.uuid
  preload_links_for_objects([uuid])
  @all_links_for[uuid]
end

helper_method :preload_links_for_object
def preload_links_for_objects objects_and_uuids
  uuids = objects_and_uuids.collect { |x| x.is_a?(String) ? x : x.uuid }
  @all_links_for ||= {}
  if not uuids.select { |x| @all_links_for[x].nil? }.any?
    # already preloaded for all of these uuids
    return
  end
  uuids.each do |x|
    @all_links_for[x] = []
  end
  # TODO: make sure we get every page of results from API server
  Link.filter([['head_uuid','in',uuids]]).each do |link|
    @all_links_for[link.head_uuid] << link
  end
end

In any controller/helper/view, when you expect to be looking up links for a set of objects:

preload_links_for_objects @objects

In any controller/helper/view when you need a list of links referencing a given object, instead of doing Link.where(), do:

links_for_object(@object).each do |link|
  if link.link_class == 'name'
    # do stuff with link.name
  end
end

This will at least avoid doing multiple lookups for the same collection ID when rendering N select widgets, etc. Judicious use of "preload" will reduce round-trips further: e.g., combine all of the name/tag lookups for collections#index list into one API call by doing preload_links_for_objects(@objects).


Subtasks 5 (0 open5 closed)

Task #2970: Preload objects used in dashboardResolvedRadhika Chippada06/05/2014Actions
Task #2971: Preload objects used in metadata tabResolvedRadhika Chippada06/05/2014Actions
Task #2972: Preload object used in pipeline instance displayResolvedRadhika Chippada06/05/2014Actions
Task #2973: Add tests for the preload methods added to workbench application_controllerResolvedRadhika Chippada06/05/2014Actions
Task #2969: Review branch: 2871-preload-objectsResolvedPeter Amstutz06/05/2014Actions
Actions

Also available in: Atom PDF