fb_graph 2.2.2 → 2.2.3
Sign up to get free protection for your applications and to get access to all the features.
- data/Gemfile.lock +11 -15
- data/VERSION +1 -1
- data/lib/fb_graph/album.rb +1 -1
- data/lib/fb_graph/connections/comments.rb +1 -5
- data/lib/fb_graph/connections/former_participants.rb +1 -5
- data/lib/fb_graph/connections/likes.rb +1 -5
- data/lib/fb_graph/connections/messages.rb +1 -5
- data/lib/fb_graph/connections/participants.rb +1 -5
- data/lib/fb_graph/connections/question_options.rb +2 -6
- data/lib/fb_graph/connections/senders.rb +1 -5
- data/lib/fb_graph/connections/tags.rb +7 -8
- data/lib/fb_graph/link.rb +1 -1
- data/lib/fb_graph/message.rb +1 -1
- data/lib/fb_graph/node.rb +32 -7
- data/lib/fb_graph/note.rb +1 -1
- data/lib/fb_graph/open_graph/action.rb +1 -2
- data/lib/fb_graph/page.rb +2 -2
- data/lib/fb_graph/photo.rb +1 -2
- data/lib/fb_graph/post.rb +1 -2
- data/lib/fb_graph/question.rb +2 -4
- data/lib/fb_graph/searchable.rb +2 -1
- data/lib/fb_graph/status.rb +1 -2
- data/lib/fb_graph/thread.rb +5 -11
- data/lib/fb_graph/user_achievement.rb +1 -2
- data/lib/fb_graph/video.rb +1 -1
- data/spec/fb_graph/connections/comments_spec.rb +25 -13
- data/spec/fb_graph/connections/former_participants_spec.rb +30 -12
- data/spec/fb_graph/connections/likes_spec.rb +32 -0
- data/spec/fb_graph/connections/messages_spec.rb +30 -12
- data/spec/fb_graph/connections/participants_spec.rb +30 -12
- data/spec/fb_graph/connections/question_options_spec.rb +3 -3
- data/spec/fb_graph/connections/questions_spec.rb +13 -0
- data/spec/fb_graph/connections/senders_spec.rb +30 -12
- data/spec/fb_graph/page_spec.rb +9 -6
- data/spec/fb_graph/question_spec.rb +26 -25
- data/spec/fb_graph/searchable_spec.rb +17 -5
- data/spec/fb_graph/thread_spec.rb +0 -30
- data/spec/mock_json/pages/platform_public.json +2 -1
- data/spec/mock_json/users/questions/sample.json +465 -0
- data/spec/spec_helper.rb +0 -3
- metadata +21 -19
@@ -1,18 +1,6 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
3
|
describe FbGraph::Connections::Participants, '#participants' do
|
4
|
-
it 'should use cached contents as default' do
|
5
|
-
lambda do
|
6
|
-
FbGraph::Thread.new(12345, :access_token => 'access_token').participants
|
7
|
-
end.should_not request_to '12345/participants?access_token=access_token'
|
8
|
-
end
|
9
|
-
|
10
|
-
it 'should not use cached contents when options are specified' do
|
11
|
-
lambda do
|
12
|
-
FbGraph::Thread.new(12345).participants(:no_cache => true)
|
13
|
-
end.should request_to '12345/participants?no_cache=true'
|
14
|
-
end
|
15
|
-
|
16
4
|
it 'should return participants as FbGraph::User' do
|
17
5
|
mock_graph :get, '12345/participants', 'thread/participants/private', :params => {:no_cache => 'true'}, :access_token => 'access_token' do
|
18
6
|
participants = FbGraph::Thread.new(12345, :access_token => 'access_token').participants(:no_cache => true)
|
@@ -21,4 +9,34 @@ describe FbGraph::Connections::Participants, '#participants' do
|
|
21
9
|
end
|
22
10
|
end
|
23
11
|
end
|
12
|
+
|
13
|
+
describe 'cached messages' do
|
14
|
+
context 'when cached' do
|
15
|
+
let(:thread) { FbGraph::Thread.new(12345, :access_token => 'access_token', :participants => {}) }
|
16
|
+
|
17
|
+
it 'should use cache' do
|
18
|
+
lambda do
|
19
|
+
thread.participants
|
20
|
+
end.should_not request_to '12345/participants?access_token=access_token'
|
21
|
+
end
|
22
|
+
|
23
|
+
context 'when options are specified' do
|
24
|
+
it 'should not use cache' do
|
25
|
+
lambda do
|
26
|
+
thread.participants(:no_cache => true)
|
27
|
+
end.should request_to '12345/participants?access_token=access_token&no_cache=true'
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
context 'otherwise' do
|
33
|
+
let(:thread) { FbGraph::Thread.new(12345, :access_token => 'access_token') }
|
34
|
+
|
35
|
+
it 'should not use cache' do
|
36
|
+
lambda do
|
37
|
+
thread.participants
|
38
|
+
end.should request_to '12345/participants?access_token=access_token'
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
24
42
|
end
|
@@ -4,9 +4,9 @@ describe FbGraph::Connections::QuestionOptions, '#options' do
|
|
4
4
|
context 'when included by FbGraph::Question' do
|
5
5
|
it 'should return options as FbGraph::QuestionOption' do
|
6
6
|
mock_graph :get, '12345/question_options', 'questions/options/matake_private', :access_token => 'access_token' do
|
7
|
-
|
8
|
-
|
9
|
-
|
7
|
+
question_options = FbGraph::Question.new('12345', :access_token => 'access_token').question_options
|
8
|
+
question_options.each do |question_option|
|
9
|
+
question_option.should be_instance_of(FbGraph::QuestionOption)
|
10
10
|
end
|
11
11
|
end
|
12
12
|
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe FbGraph::Connections::Questions do
|
4
|
+
it 'should return an Array of Questions' do
|
5
|
+
mock_graph :get, 'me/questions', 'users/questions/sample', :access_token => 'access_token' do
|
6
|
+
questions = FbGraph::User.me('access_token').questions
|
7
|
+
questions.class.should == FbGraph::Connection
|
8
|
+
questions.each do |question|
|
9
|
+
question.should be_instance_of(FbGraph::Question)
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
@@ -1,18 +1,6 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
3
|
describe FbGraph::Connections::Senders, '#senders' do
|
4
|
-
it 'should use cached contents as default' do
|
5
|
-
lambda do
|
6
|
-
FbGraph::Thread.new(12345, :access_token => 'access_token').senders
|
7
|
-
end.should_not request_to '12345/senders?access_token=access_token'
|
8
|
-
end
|
9
|
-
|
10
|
-
it 'should not use cached contents when options are specified' do
|
11
|
-
lambda do
|
12
|
-
FbGraph::Thread.new(12345).senders(:no_cache => true)
|
13
|
-
end.should request_to '12345/senders?no_cache=true'
|
14
|
-
end
|
15
|
-
|
16
4
|
it 'should return senders as FbGraph::User' do
|
17
5
|
mock_graph :get, '12345/senders', 'thread/senders/private', :params => {:no_cache => 'true'}, :access_token => 'access_token' do
|
18
6
|
senders = FbGraph::Thread.new(12345, :access_token => 'access_token').senders(:no_cache => true)
|
@@ -21,4 +9,34 @@ describe FbGraph::Connections::Senders, '#senders' do
|
|
21
9
|
end
|
22
10
|
end
|
23
11
|
end
|
12
|
+
|
13
|
+
describe 'cached messages' do
|
14
|
+
context 'when cached' do
|
15
|
+
let(:thread) { FbGraph::Thread.new(12345, :access_token => 'access_token', :senders => {}) }
|
16
|
+
|
17
|
+
it 'should use cache' do
|
18
|
+
lambda do
|
19
|
+
thread.senders
|
20
|
+
end.should_not request_to '12345/senders?access_token=access_token'
|
21
|
+
end
|
22
|
+
|
23
|
+
context 'when options are specified' do
|
24
|
+
it 'should not use cache' do
|
25
|
+
lambda do
|
26
|
+
thread.senders(:no_cache => true)
|
27
|
+
end.should request_to '12345/senders?access_token=access_token&no_cache=true'
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
context 'otherwise' do
|
33
|
+
let(:thread) { FbGraph::Thread.new(12345, :access_token => 'access_token') }
|
34
|
+
|
35
|
+
it 'should not use cache' do
|
36
|
+
lambda do
|
37
|
+
thread.senders
|
38
|
+
end.should request_to '12345/senders?access_token=access_token'
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
24
42
|
end
|
data/spec/fb_graph/page_spec.rb
CHANGED
@@ -7,18 +7,20 @@ describe FbGraph::Page do
|
|
7
7
|
:category => 'Technology',
|
8
8
|
:likes => 578246,
|
9
9
|
:name => 'Facebook Platform',
|
10
|
-
:username => 'platform'
|
10
|
+
:username => 'platform',
|
11
|
+
:talking_about_count => 3232
|
11
12
|
}
|
12
13
|
end
|
13
14
|
subject do
|
14
15
|
FbGraph::Page.new(attributes[:id], attributes)
|
15
16
|
end
|
16
17
|
|
17
|
-
its(:identifier)
|
18
|
-
its(:category)
|
19
|
-
its(:like_count)
|
20
|
-
its(:name)
|
21
|
-
its(:username)
|
18
|
+
its(:identifier) { should == attributes[:id] }
|
19
|
+
its(:category) { should == attributes[:category] }
|
20
|
+
its(:like_count) { should == attributes[:likes] }
|
21
|
+
its(:name) { should == attributes[:name] }
|
22
|
+
its(:username) { should == attributes[:username] }
|
23
|
+
its(:talking_about_count) { should == attributes[:talking_about_count] }
|
22
24
|
|
23
25
|
describe '.fetch' do
|
24
26
|
subject do
|
@@ -30,6 +32,7 @@ describe FbGraph::Page do
|
|
30
32
|
its(:name) { should == 'Facebook Platform' }
|
31
33
|
its(:category) { should == 'Technology' }
|
32
34
|
its(:like_count) { should == 578214 }
|
35
|
+
its(:talking_about_count) { should == 40945 }
|
33
36
|
|
34
37
|
context 'when access_token field fetched' do
|
35
38
|
subject do
|
@@ -39,31 +39,32 @@ describe FbGraph::Question do
|
|
39
39
|
}
|
40
40
|
}
|
41
41
|
question = FbGraph::Question.new(attributes.delete(:id), attributes)
|
42
|
-
question.identifier.should
|
43
|
-
question.from.should
|
44
|
-
question.question.should
|
45
|
-
question.created_time.should
|
46
|
-
question.updated_time.should
|
47
|
-
question.
|
48
|
-
|
49
|
-
|
50
|
-
:
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
:
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
42
|
+
question.identifier.should == '12345'
|
43
|
+
question.from.should == FbGraph::User.new('23456', :name => 'Mahmoud Khaled')
|
44
|
+
question.question.should == 'question 1'
|
45
|
+
question.created_time.should == Time.parse('2009-12-29T15:24:50+0000')
|
46
|
+
question.updated_time.should == Time.parse('2010-01-02T15:37:41+0000')
|
47
|
+
question.question_options.should == [
|
48
|
+
FbGraph::QuestionOption.new(
|
49
|
+
'34567',
|
50
|
+
:from => {
|
51
|
+
:id => '23456',
|
52
|
+
:name => 'Mahmoud Khaled',
|
53
|
+
},
|
54
|
+
:name => "option 1",
|
55
|
+
:votes => 2,
|
56
|
+
:created_time => "2011-11-07T19:49:51+0000"
|
57
|
+
),
|
58
|
+
FbGraph::QuestionOption.new(
|
59
|
+
'34568',
|
60
|
+
:from => {
|
61
|
+
:id => '23457',
|
62
|
+
:name => 'Mustafa Badawy',
|
63
|
+
},
|
64
|
+
:name => "option 2",
|
65
|
+
:votes => 0,
|
66
|
+
:created_time => "2011-11-07T19:49:48+0000"
|
67
|
+
)
|
67
68
|
]
|
68
69
|
end
|
69
70
|
|
@@ -1,11 +1,23 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
3
|
describe FbGraph::Searchable do
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
4
|
+
describe '.search' do
|
5
|
+
context 'when included by FbGraph::Page' do
|
6
|
+
it 'should with type=page' do
|
7
|
+
lambda do
|
8
|
+
FbGraph::Searchable.search('FbGraph')
|
9
|
+
end.should request_to('search?q=FbGraph')
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
describe '#search' do
|
15
|
+
context 'when included by FbGraph::Page' do
|
16
|
+
it 'should with type=page' do
|
17
|
+
lambda do
|
18
|
+
FbGraph::Page.search('FbGraph')
|
19
|
+
end.should request_to('search?q=FbGraph&type=page')
|
20
|
+
end
|
9
21
|
end
|
10
22
|
end
|
11
23
|
end
|
@@ -83,34 +83,4 @@ describe FbGraph::Thread, '.new' do
|
|
83
83
|
FbGraph::User.new('1575327134', :name => 'Nov Matake', :email => 'abc@facebook.com')
|
84
84
|
]
|
85
85
|
end
|
86
|
-
|
87
|
-
|
88
|
-
describe FbGraph::Thread::BeforeTransition do
|
89
|
-
describe '#messages' do
|
90
|
-
it 'should use cached contents as default' do
|
91
|
-
lambda do
|
92
|
-
FbGraph::Thread::BeforeTransition.new(12345, :access_token => 'access_token').messages
|
93
|
-
end.should_not request_to '12345/comments?access_token=access_token'
|
94
|
-
end
|
95
|
-
|
96
|
-
it 'should not use cached contents when options are specified' do
|
97
|
-
lambda do
|
98
|
-
FbGraph::Thread::BeforeTransition.new(12345).messages(:no_cache => true)
|
99
|
-
end.should request_to '12345/comments?no_cache=true'
|
100
|
-
end
|
101
|
-
|
102
|
-
it 'should return threads as FbGraph::Message' do
|
103
|
-
mock_graph :get, '12345/comments', 'thread/messages/private', :params => {:no_cache => 'true'}, :access_token => 'access_token' do
|
104
|
-
messages = FbGraph::Thread::BeforeTransition.new(12345, :access_token => 'access_token').messages(:no_cache => true)
|
105
|
-
messages.each do |message|
|
106
|
-
message.should be_instance_of(FbGraph::Message)
|
107
|
-
end
|
108
|
-
lambda do
|
109
|
-
messages.next
|
110
|
-
end.should request_to '12345/comments'
|
111
|
-
end
|
112
|
-
end
|
113
|
-
end
|
114
|
-
end
|
115
|
-
|
116
86
|
end
|
@@ -9,5 +9,6 @@
|
|
9
9
|
"company_overview": "Facebook Platform enables anyone to build social applications on Facebook and the web.",
|
10
10
|
"mission": "To make the web more open and social.",
|
11
11
|
"products": "Facebook Application Programming Interface (API)\nFacebook Query Language (FQL)\nFacebook Markup Language (FBML)\nFacebook JavaScript (FBJS)\nFacebook Connect\n",
|
12
|
-
"likes": 578214
|
12
|
+
"likes": 578214,
|
13
|
+
"talking_about_count": 40945
|
13
14
|
}
|