orders valuators by spending proposal count

This commit is contained in:
rgarcia
2016-04-26 23:33:19 +02:00
parent 99f16fcad9
commit aaca99b46f
5 changed files with 25 additions and 4 deletions

View File

@@ -26,7 +26,7 @@ class Admin::ValuatorsController < Admin::BaseController
end
def summary
@valuators = Valuator.all
@valuators = Valuator.order(spending_proposals_count: :desc)
end
private

View File

@@ -1,4 +1,4 @@
class ValuationAssignment < ActiveRecord::Base
belongs_to :valuator
belongs_to :valuator, counter_cache: :spending_proposals_count
belongs_to :spending_proposal, counter_cache: true
end

View File

@@ -0,0 +1,5 @@
class AddAssignmentsCounterCacheToValuators < ActiveRecord::Migration
def change
add_column :valuators, :spending_proposals_count, :integer, default: 0
end
end

View File

@@ -11,7 +11,7 @@
#
# It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema.define(version: 20160422094733) do
ActiveRecord::Schema.define(version: 20160426211658) do
# These are extensions that must be enabled in order to support this database
enable_extension "plpgsql"
@@ -448,6 +448,7 @@ ActiveRecord::Schema.define(version: 20160422094733) do
create_table "valuators", force: :cascade do |t|
t.integer "user_id"
t.string "description"
t.integer "spending_proposals_count", default: 0
end
add_index "valuators", ["user_id"], name: "index_valuators_on_user_id", using: :btree

View File

@@ -408,7 +408,6 @@ feature 'Valuation spending proposals' do
in_evaluation1 = create(:spending_proposal, feasible: true, valuation_finished: false)
in_evaluation2 = create(:spending_proposal, feasible: true, valuation_finished: false)
finished_and_feasible1.valuators << scarlett
finished_and_feasible2.valuators << scarlett
@@ -443,6 +442,22 @@ feature 'Valuation spending proposals' do
end
end
scenario "Order by investment project count" do
isabel = create(:valuator)
john = create(:valuator)
scarlett = create(:valuator)
3.times { create(:spending_proposal, valuators: [scarlett])}
1.times { create(:spending_proposal, valuators: [john])}
2.times { create(:spending_proposal, valuators: [isabel])}
visit admin_spending_proposals_path
click_link "Valuator summary"
expect(scarlett.email).to appear_before(isabel.email)
expect(isabel.email).to appear_before(john.email)
end
scenario "Back link" do
visit admin_spending_proposals_path