Commit fdb09d35e2389249959d754ffa348922ad7c5ad0
Committed by
Rodrigo Souto
1 parent
a9b65794
Exists in
master
and in
12 other branches
Fix logic readability for duplicated votes
Signed-off-by: Victor Costa <vfcosta@gmail.com>
Showing
2 changed files
with
11 additions
and
3 deletions
Show diff stats
lib/noosfero/vote_ext.rb
| ... | ... | @@ -2,10 +2,10 @@ require_dependency 'models/vote' |
| 2 | 2 | |
| 3 | 3 | class Vote |
| 4 | 4 | |
| 5 | - validates_uniqueness_of :voteable_id, :scope => [:voteable_type, :voter_type, :voter_id], :if => :allow_duplicated_vote? | |
| 5 | + validates_uniqueness_of :voteable_id, :scope => [:voteable_type, :voter_type, :voter_id], :unless => :allow_duplicate? | |
| 6 | 6 | |
| 7 | - def allow_duplicated_vote? | |
| 8 | - voter.present? | |
| 7 | + def allow_duplicate? | |
| 8 | + voter.blank? | |
| 9 | 9 | end |
| 10 | 10 | |
| 11 | 11 | end | ... | ... |
test/unit/article_test.rb
| ... | ... | @@ -2190,6 +2190,14 @@ class ArticleTest < ActiveSupport::TestCase |
| 2190 | 2190 | article.destroy |
| 2191 | 2191 | end |
| 2192 | 2192 | |
| 2193 | + should 'be able to vote in an article without a user' do | |
| 2194 | + article = create(Article, :name => 'Test', :profile => profile, :last_changed_by => nil) | |
| 2195 | + assert_difference 'article.votes_for', 2 do | |
| 2196 | + Vote.create!(:voteable => article, :vote => 1) | |
| 2197 | + Vote.create!(:voteable => article, :vote => 1) | |
| 2198 | + end | |
| 2199 | + end | |
| 2200 | + | |
| 2193 | 2201 | should 'have can_display_media_panel with default false' do |
| 2194 | 2202 | a = Article.new |
| 2195 | 2203 | assert !a.can_display_media_panel? | ... | ... |