[ARVADOS] updated: db9ccbd2fab6edf279408a6869a2cf2409d5f335

git at public.curoverse.com git at public.curoverse.com
Tue Sep 16 19:09:35 EDT 2014


Summary of changes:
 .../app/controllers/projects_controller.rb         | 39 ++++++++++++++--------
 apps/workbench/test/integration/projects_test.rb   |  4 +--
 2 files changed, 28 insertions(+), 15 deletions(-)

       via  db9ccbd2fab6edf279408a6869a2cf2409d5f335 (commit)
       via  b941bb69fdf0bfd2cc2ce0de82f570e70f7af86c (commit)
      from  893f659712cd9b742829b17e2cedc822901608ec (commit)

Those revisions listed above that are new to this repository have
not appeared on any other notification email; so we list those
revisions in full, below.


commit db9ccbd2fab6edf279408a6869a2cf2409d5f335
Author: Phil Hodgson <bitbucket at philhodgson.net>
Date:   Tue Sep 16 19:09:32 2014 -0400

    3338: move the user_is_manager and shared items to the already-overridden #find_object_by_uuid method so that these are available to all the same actions

diff --git a/apps/workbench/app/controllers/projects_controller.rb b/apps/workbench/app/controllers/projects_controller.rb
index 748072e..46b8d15 100644
--- a/apps/workbench/app/controllers/projects_controller.rb
+++ b/apps/workbench/app/controllers/projects_controller.rb
@@ -26,6 +26,17 @@ class ProjectsController < ApplicationController
     else
       super
     end
+
+    @user_is_manager = false
+    @share_links = []
+    if @object.uuid != current_user.uuid
+      begin
+        @share_links = Link.permissions_for(@object)
+        @user_is_manager = true
+      rescue ArvadosApiClient::AccessForbiddenException,
+        ArvadosApiClient::NotFoundException
+      end
+    end
   end
 
   def index_pane_list
@@ -59,14 +70,27 @@ class ProjectsController < ApplicationController
     ]
     # Note that adding :filters to 'Sharing' won't help show the count for it because @user_is_manager is only set in #show
     # Therefore if a count were desired there we'd want to set @user_is_manager in a before_filter or somesuch.
-    pane_list << { :name => 'Sharing' } if @user_is_manager
+    pane_list << { :name => 'Sharing',
+                   :count => @share_links.count } if @user_is_manager
     pane_list << { :name => 'Advanced' }
   end
 
+  # Called via AJAX and returns Javascript that populates tab counts into tab titles.
+  # References #show_pane_list action which should return an array of hashes each with :name 
+  # and then optionally a :filters to run or a straight up :count
+  #
+  # This action could easily be moved to the ApplicationController to genericize the tab_counts behaviour,
+  # but one or more new routes would have to be created, the js.erb would also have to be moved
   def tab_counts
     @tab_counts = {}
     show_pane_list.each do |pane|
-      @tab_counts[pane[:name]] = @object.contents(filters: pane[:filters]).count if pane[:filters]
+      if pane.is_a?(Hash)
+        if pane[:count]
+          @tab_counts[pane[:name]] = pane[:count]
+        elsif pane[:filters]
+          @tab_counts[pane[:name]] = @object.contents(filters: pane[:filters]).items_available
+        end
+      end
     end
   end
 
@@ -190,17 +214,6 @@ class ProjectsController < ApplicationController
       return render_not_found("object not found")
     end
 
-    @user_is_manager = false
-    @share_links = []
-    if @object.uuid != current_user.uuid
-      begin
-        @share_links = Link.permissions_for(@object)
-        @user_is_manager = true
-      rescue ArvadosApiClient::AccessForbiddenException,
-        ArvadosApiClient::NotFoundException
-      end
-    end
-
     if params[:partial]
       load_contents_objects
       respond_to do |f|

commit b941bb69fdf0bfd2cc2ce0de82f570e70f7af86c
Author: Phil Hodgson <bitbucket at philhodgson.net>
Date:   Tue Sep 16 19:05:45 2014 -0400

    3338: fix the integration test so that it checks the on-screen collection count
    rather than trying to use the fixtures which doesn't work anyway

diff --git a/apps/workbench/test/integration/projects_test.rb b/apps/workbench/test/integration/projects_test.rb
index d36e75b..e061b5f 100644
--- a/apps/workbench/test/integration/projects_test.rb
+++ b/apps/workbench/test/integration/projects_test.rb
@@ -9,9 +9,9 @@ class ProjectsTest < ActionDispatch::IntegrationTest
 
   test 'Check collection count for A Project in the tab pane titles' do
     project_uuid = api_fixture('groups')['aproject']['uuid']
-    collection_fixture_count = api_fixture('collections').select{|k,v| v['owner_uuid'] == project_uuid}.count
     visit page_with_token 'active', '/projects/' + project_uuid
-    assert_selector '#Data_collections-tab span', text: "(#{collection_fixture_count})"
+    collection_count = page.all("[data-pk*='collection']").count
+    assert_selector '#Data_collections-tab span', text: "(#{collection_count})"
   end
 
   test 'Find a project and edit its description' do

-----------------------------------------------------------------------


hooks/post-receive
-- 




More information about the arvados-commits mailing list