Newer
Older
# Copyright (c) 2010-2011, Diaspora Inc. This file is
# licensed under the Affero General Public License version 3 or later. See
# the COPYRIGHT file.
require 'spec_helper'
describe PostsController do
before do
Raphael Sofaer
a validé
aspect = alice.aspects.first
@message = alice.build_post :status_message, :text => "ohai", :to => aspect.id
@message.save!
Raphael Sofaer
a validé
alice.add_to_streams(@message, [aspect])
alice.dispatch_post @message, :to => aspect.id
end
context 'user signed in' do
before do
sign_in :user, alice
Raphael Sofaer
a validé
it 'succeeds' do
get :show, "id" => @message.id
response.should be_success
end
it 'succeeds on mobile' do
get :show, "id" => @message.id
response.should be_success
end
it 'renders the application layout on mobile' do
get :show, :id => @message.id, :format => :mobile
response.should render_template('layouts/application')
end
it 'succeeds on mobile with a reshare' do
get :show, "id" => FactoryGirl.create(:reshare, :author => alice.person).id, :format => :mobile
Raphael Sofaer
a validé
it 'marks a corresponding notifications as read' do
FactoryGirl.create(:notification, :recipient => alice, :target => @message, :unread => true)
note = FactoryGirl.create(:notification, :recipient => alice, :target => @message, :unread => true)
expect {
get :show, :id => @message.id
note.reload
}.to change(Notification.where(:unread => true), :count).by(-2)
it 'marks a corresponding mention notification as read' do
status_msg = bob.post(:status_message, {text: "this is a text mentioning @{Mention User ; #{alice.diaspora_handle}} ... have fun testing!", :public => true, :to => 'all'})
mention = status_msg.mentions.where(person_id: alice.person.id).first
note = FactoryGirl.create(:notification, :recipient => alice, :target_type => "Mention", :target_id => mention.id, :unread => true)
expect {
get :show, :id => status_msg.id
note.reload
}.to change(Notification.where(:unread => true), :count).by(-1)
end
expect {
get :show, :id => 1234567
}.to raise_error(ActiveRecord::RecordNotFound)
Raphael Sofaer
a validé
end
context 'given a public post' do
before :each do
@status = alice.post(:status_message, :text => "hello", :public => true, :to => 'all')
end
it 'shows a public post' do
get :show, :id => @status.id
response.status.should == 200
end
it 'succeeds for statusnet' do
@request.env["HTTP_ACCEPT"] = "application/html+xml,text/html"
get :show, :id => @status.id
response.should be_success
end
it 'responds with diaspora xml if format is xml' do
get :show, :id => @status.guid, :format => :xml
response.body.should == @status.to_diaspora_xml
end
it 'does not show a private post' do
status = alice.post(:status_message, :text => "hello", :public => false, :to => 'all')
get :show, :id => status.id
response.status.should == 404
end
# We want to be using guids from now on for this post route, but do not want to break
# pre-exisiting permalinks. We can assume a guid is 8 characters long as we have
# guids set to hex(8) since we started using them.
context 'id/guid switch' do
before do
@status = alice.post(:status_message, :text => "hello", :public => true, :to => 'all')
end
it 'assumes guids less than 8 chars are ids and not guids' do
p = Post.where(:id => @status.id.to_s)
Post.should_receive(:where)
.with(hash_including(:id => @status.id.to_s))
.and_return(p)
response.should be_success
end
it 'assumes guids more than (or equal to) 8 chars are actually guids' do
p = Post.where(:guid => @status.guid)
Post.should_receive(:where)
.with(hash_including(:guid => @status.guid))
.and_return(p)
response.should be_success
end
end
end
Raphael Sofaer
a validé
end
Maxwell Salzberg
a validé
describe 'iframe' do
it 'contains an iframe' do
get :iframe, :id => @message.id
response.body.should match /iframe/
end
end
describe 'oembed' do
it 'works when you can see it' do
sign_in alice
get :oembed, :url => "/posts/#{@message.id}"
response.body.should match /iframe/
end
it 'returns a 404 response when the post is not found' do
get :oembed, :url => "/posts/#{@message.id}"
response.status.should == 404
Raphael Sofaer
a validé
describe '#destroy' do
Raphael Sofaer
a validé
it 'let a user delete his message' do
message = alice.post(:status_message, :text => "hey", :to => alice.aspects.first.id)
delete :destroy, :format => :js, :id => message.id
response.should be_success
StatusMessage.find_by_id(message.id).should be_nil
end
it 'sends a retraction on delete' do
Raphael Sofaer
a validé
message = alice.post(:status_message, :text => "hey", :to => alice.aspects.first.id)
alice.should_receive(:retract).with(message)
delete :destroy, :format => :js, :id => message.id
response.should be_success
Raphael Sofaer
a validé
it 'will not let you destroy posts visible to you' do
message = bob.post(:status_message, :text => "hey", :to => bob.aspects.first.id)
expect { delete :destroy, :format => :js, :id => message.id }.to raise_error(ActiveRecord::RecordNotFound)
Raphael Sofaer
a validé
StatusMessage.exists?(message.id).should be_true
Maxwell Salzberg
a validé
Raphael Sofaer
a validé
it 'will not let you destory posts you do not own' do
message = eve.post(:status_message, :text => "hey", :to => eve.aspects.first.id)
expect { delete :destroy, :format => :js, :id => message.id }.to raise_error(ActiveRecord::RecordNotFound)
Raphael Sofaer
a validé
StatusMessage.exists?(message.id).should be_true
Maxwell Salzberg
a validé
end