unscoped_associations 0.6.1 → 0.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/README.md +1 -1
- data/lib/unscoped_associations/version.rb +1 -1
- data/lib/unscoped_associations.rb +6 -6
- data/spec/support/models.rb +12 -2
- data/spec/unscoped_associations_spec.rb +35 -31
- metadata +2 -2
data/README.md
CHANGED
@@ -53,7 +53,7 @@ NOTE: Rails 4 introduces some updates (and more planned for upcoming releases) r
|
|
53
53
|
|
54
54
|
```ruby
|
55
55
|
class User < ActiveRecord::Base
|
56
|
-
has_many :all_comments, -> { where
|
56
|
+
has_many :all_comments, -> { where(public: [true, false]) }, class_name: 'Comment'
|
57
57
|
end
|
58
58
|
```
|
59
59
|
|
@@ -17,8 +17,8 @@ module UnscopedAssociations
|
|
17
17
|
build_unscoped(:belongs_to, name, scope, options)
|
18
18
|
end
|
19
19
|
|
20
|
-
def has_many_with_unscoped(name, scope = nil, options = {})
|
21
|
-
build_unscoped(:has_many, name, scope, options)
|
20
|
+
def has_many_with_unscoped(name, scope = nil, options = {}, &extension)
|
21
|
+
build_unscoped(:has_many, name, scope, options, &extension)
|
22
22
|
end
|
23
23
|
|
24
24
|
def has_one_with_unscoped(name, scope = nil, options = {})
|
@@ -27,7 +27,7 @@ module UnscopedAssociations
|
|
27
27
|
|
28
28
|
private
|
29
29
|
|
30
|
-
def build_unscoped(assoc_type, assoc_name, scope = nil, options = {})
|
30
|
+
def build_unscoped(assoc_type, assoc_name, scope = nil, options = {}, &extension)
|
31
31
|
if scope.is_a?(Hash)
|
32
32
|
options = scope
|
33
33
|
scope = nil
|
@@ -38,9 +38,9 @@ module UnscopedAssociations
|
|
38
38
|
end
|
39
39
|
|
40
40
|
if scope
|
41
|
-
self.send("#{assoc_type}_without_unscoped", assoc_name, scope, options)
|
41
|
+
self.send("#{assoc_type}_without_unscoped", assoc_name, scope, options, &extension)
|
42
42
|
else
|
43
|
-
self.send("#{assoc_type}_without_unscoped", assoc_name, options)
|
43
|
+
self.send("#{assoc_type}_without_unscoped", assoc_name, options, &extension)
|
44
44
|
end
|
45
45
|
end
|
46
46
|
|
@@ -54,4 +54,4 @@ module UnscopedAssociations
|
|
54
54
|
end
|
55
55
|
end
|
56
56
|
|
57
|
-
ActiveRecord::Base.instance_eval { include UnscopedAssociations }
|
57
|
+
ActiveRecord::Base.instance_eval { include UnscopedAssociations }
|
data/spec/support/models.rb
CHANGED
@@ -1,6 +1,16 @@
|
|
1
1
|
class User < ActiveRecord::Base
|
2
|
-
has_many :comments
|
3
|
-
|
2
|
+
has_many :comments do
|
3
|
+
def today
|
4
|
+
where('created_at <= ?', Time.now.end_of_day)
|
5
|
+
end
|
6
|
+
end
|
7
|
+
|
8
|
+
has_many :unscoped_comments, class_name: 'Comment', unscoped: true do
|
9
|
+
def today
|
10
|
+
where('created_at <= ?', Time.now.end_of_day)
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
4
14
|
has_one :last_comment, class_name: 'Comment', order: 'created_at DESC'
|
5
15
|
has_one :unscoped_last_comment, class_name: 'Comment', order: 'created_at DESC', unscoped: true
|
6
16
|
|
@@ -1,50 +1,54 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
3
|
describe UnscopedAssociations do
|
4
|
-
|
5
|
-
|
6
|
-
user = User.create(active: false)
|
7
|
-
comment = Comment.create(user_id: user.id)
|
4
|
+
let(:user) { User.create active: false }
|
5
|
+
let(:comment) { Comment.create user_id: user.id, public: false }
|
8
6
|
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
it 'has_many' do
|
13
|
-
user = User.create
|
14
|
-
comment = Comment.create(user_id: user.id, public: false)
|
7
|
+
context 'a belongs to association' do
|
8
|
+
subject { comment }
|
15
9
|
|
16
|
-
|
10
|
+
context 'scoped' do
|
11
|
+
its(:user) { should be_nil }
|
12
|
+
its(:scoped_user) { should be_nil }
|
17
13
|
end
|
18
14
|
|
19
|
-
|
20
|
-
user
|
21
|
-
comment = Comment.create(user_id: user.id, public: false)
|
22
|
-
|
23
|
-
expect(user.unscoped_last_comment).to be_present
|
15
|
+
context 'unscoped' do
|
16
|
+
its(:unscoped_user) { should eq user }
|
24
17
|
end
|
25
18
|
end
|
26
19
|
|
27
|
-
context '
|
28
|
-
|
29
|
-
user = User.create(active: false)
|
30
|
-
comment = Comment.create(user_id: user.id)
|
20
|
+
context 'a has one association' do
|
21
|
+
subject { user }
|
31
22
|
|
32
|
-
|
33
|
-
|
23
|
+
context 'scoped' do
|
24
|
+
its(:last_comment) { should be_nil }
|
34
25
|
end
|
35
26
|
|
36
|
-
|
37
|
-
|
38
|
-
|
27
|
+
context 'unscoped' do
|
28
|
+
its(:unscoped_last_comment) { should eq comment }
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
context 'a has many association' do
|
33
|
+
subject { user }
|
34
|
+
|
35
|
+
context 'scoped' do
|
36
|
+
its(:comments) { should be_empty }
|
39
37
|
|
40
|
-
|
38
|
+
context 'with an extension' do
|
39
|
+
its('comments.today') { should be_empty }
|
40
|
+
end
|
41
41
|
end
|
42
42
|
|
43
|
-
|
44
|
-
|
45
|
-
comment = Comment.create(user_id: user.id, public: false)
|
43
|
+
context 'unscoped' do
|
44
|
+
its(:unscoped_comments) { should eq [comment] }
|
46
45
|
|
47
|
-
|
46
|
+
context 'with an extension' do
|
47
|
+
# Extended methods take the default_scope
|
48
|
+
its('unscoped_comments.today') { should be_empty }
|
49
|
+
# Ideally, it should skip the default_scope
|
50
|
+
# its('unscoped_comments.today') { should eq [comment] }
|
51
|
+
end
|
48
52
|
end
|
49
53
|
end
|
50
|
-
end
|
54
|
+
end
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: unscoped_associations
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.6.
|
4
|
+
version: 0.6.2
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2014-
|
12
|
+
date: 2014-04-06 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: activerecord
|