2011-02-04 04:13:41 +00:00
|
|
|
require 'spec_helper.rb'
|
|
|
|
|
|
|
|
describe ArticlesController do
|
2011-02-10 21:13:30 +00:00
|
|
|
fixtures :articles,:impressions,:posts
|
2011-02-04 04:13:41 +00:00
|
|
|
render_views
|
|
|
|
|
|
|
|
it "should make the impressionable_hash available" do
|
|
|
|
get "index"
|
|
|
|
response.body.include?("false").should eq true
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should log an impression with a message" do
|
|
|
|
get "index"
|
|
|
|
Impression.all.size.should eq 11
|
|
|
|
Article.first.impressions.last.message.should eq "this is a test article impression"
|
2011-02-17 13:11:06 +00:00
|
|
|
Article.first.impressions.last.controller_name.should eq "articles"
|
|
|
|
Article.first.impressions.last.action_name.should eq "index"
|
2011-02-04 04:13:41 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should log an impression without a message" do
|
2011-02-13 19:18:34 +00:00
|
|
|
get "show", :id=> 1
|
2011-02-04 04:13:41 +00:00
|
|
|
Impression.all.size.should eq 11
|
|
|
|
Article.first.impressions.last.message.should eq nil
|
2011-02-17 13:11:06 +00:00
|
|
|
Article.first.impressions.last.controller_name.should eq "articles"
|
|
|
|
Article.first.impressions.last.action_name.should eq "show"
|
2011-02-04 04:13:41 +00:00
|
|
|
end
|
2011-02-10 21:13:30 +00:00
|
|
|
|
|
|
|
it "should log the user_id if user is authenticated (@current_user before_filter method)" do
|
|
|
|
session[:user_id] = 123
|
2011-02-13 19:18:34 +00:00
|
|
|
get "show", :id=> 1
|
2011-02-10 21:13:30 +00:00
|
|
|
Article.first.impressions.last.user_id.should eq 123
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not log the user_id if user is authenticated" do
|
2011-02-13 19:18:34 +00:00
|
|
|
get "show", :id=> 1
|
2011-02-10 21:13:30 +00:00
|
|
|
Article.first.impressions.last.user_id.should eq nil
|
|
|
|
end
|
2011-02-04 04:13:41 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
describe PostsController do
|
|
|
|
it "should log impression at the action level" do
|
2011-02-13 19:18:34 +00:00
|
|
|
get "show", :id=> 1
|
2011-02-04 04:13:41 +00:00
|
|
|
Impression.all.size.should eq 11
|
|
|
|
Impression.last.controller_name.should eq "posts"
|
2011-02-17 13:11:06 +00:00
|
|
|
Impression.last.action_name.should eq "show"
|
2011-02-04 04:13:41 +00:00
|
|
|
Impression.last.impressionable_type.should eq "Post"
|
|
|
|
Impression.last.impressionable_id.should eq 1
|
|
|
|
end
|
2011-02-10 21:13:30 +00:00
|
|
|
|
|
|
|
it "should log the user_id if user is authenticated (current_user helper method)" do
|
|
|
|
session[:user_id] = 123
|
2011-02-13 19:18:34 +00:00
|
|
|
get "show", :id=> 1
|
2011-02-10 21:13:30 +00:00
|
|
|
Post.first.impressions.last.user_id.should eq 123
|
|
|
|
end
|
2011-02-04 04:13:41 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
describe WidgetsController do
|
|
|
|
it "should log impression at the per action level" do
|
2011-02-13 19:18:34 +00:00
|
|
|
get "show", :id=> 1
|
2011-02-04 04:13:41 +00:00
|
|
|
Impression.all.size.should eq 11
|
|
|
|
get "index"
|
|
|
|
Impression.all.size.should eq 12
|
|
|
|
get "new"
|
|
|
|
Impression.all.size.should eq 12
|
|
|
|
end
|
2011-02-04 16:11:04 +00:00
|
|
|
|
|
|
|
it "should not log impression when user-agent is in wildcard list" do
|
|
|
|
request.stub!(:user_agent).and_return('somebot')
|
2011-02-13 19:18:34 +00:00
|
|
|
get "show", :id=> 1
|
2011-02-04 16:11:04 +00:00
|
|
|
Impression.all.size.should eq 10
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not log impression when user-agent is in the bot list" do
|
|
|
|
request.stub!(:user_agent).and_return('Acoon Robot v1.50.001')
|
2011-02-13 19:18:34 +00:00
|
|
|
get "show", :id=> 1
|
2011-02-04 16:11:04 +00:00
|
|
|
Impression.all.size.should eq 10
|
|
|
|
end
|
2011-02-04 04:13:41 +00:00
|
|
|
end
|
|
|
|
|