Newer
Older
# licensed under the Affero General Public License version 3 or later. See
Daniel Vincent Grippi
a validé
require File.join(Rails.root, "spec", "shared_behaviors", "log_override")
@user = Factory.create(:user)
@user2 = Factory.create(:user)
@aspect0 = @user.aspects.create(:name => "lame-os")
@aspect1 = @user.aspects.create(:name => "another aspect")
@aspect2 = @user2.aspects.create(:name => "party people")
connect_users(@user, @aspect0, @user2, @aspect2)
Raphael
a validé
@contact = @user.contact_for(@user2.person)
@controller.stub(:current_user).and_return(@user)
request.env["HTTP_REFERER"] = 'http://' + request.host
describe "custom logging on success" do
before do
@action = :index
end
it_should_behave_like "it overrides the logs on success"
end
describe "custom logging on redirect" do
before do
@action = :show
@action_params = {'id' => @aspect0.id.to_s}
end
it_should_behave_like "it overrides the logs on redirect"
end
it "assigns @contacts to all the user's contacts" do
assigns[:contacts].map{|c| c.id}.should == @user.contacts.map{|c| c.id}
before do
@posts = []
@users = []
8.times do |n|
@users << user
aspect = user.aspects.create(:name => 'people')
connect_users(@user, @aspect0, user, aspect)
post = @user.post(:status_message, :message => "hello#{n}", :to => eval("@aspect#{(n%2)}.id"))
@posts << post
end
end
it "returns all posts" do
@user.aspects.reload
get :index
assigns(:posts).length.should == 8
end
it "returns posts filtered by a single aspect" do
get :index, :a_ids => [@aspect1.id.to_s]
assigns(:posts).length.should == 4
end
it "returns posts from filtered aspects" do
get :index, :a_ids => [@aspect0.id.to_s, @aspect1.id.to_s]
assigns(:posts).length.should == 8
end
end
context 'performance' do
before do
require 'benchmark'
@posts = []
@users = []
8.times do |n|
user = Factory.create(:user)
@users << user
aspect = user.aspects.create(:name => 'people')
connect_users(@user, @aspect0, user, aspect)
post = @user.post(:status_message, :message => "hello#{n}", :to => @aspect1.id)
@posts << post
user.comment "yo#{post.message}", :on => post
end
end
it 'takes time' do
Benchmark.realtime{
get :index
maxwell
a validé
get :show, 'id' => @aspect0.id.to_s
it "creates an aspect" do
post :create, "aspect" => {"name" => "new aspect"}
end
it "redirects to the aspect page" do
post :create, "aspect" => {"name" => "new aspect"}
response.should redirect_to(aspect_path(Aspect.find_by_name("new aspect")))
end
end
it "does not create an aspect" do
post :create, "aspect" => {"name" => ""}
it "goes back to the page you came from" do
post :create, "aspect" => {"name" => ""}
response.should redirect_to(:back)
describe "#manage" do
it "succeeds" do
get :manage
response.should be_success
end
it "assigns aspect to manage" do
get :manage
assigns(:aspect).should == :manage
end
it "assigns remote_requests" do
get :manage
assigns(:remote_requests).should be_empty
end
it "assigns contacts to only non-pending" do
@user.contacts.count.should == 1
@user.send_contact_request_to(Factory(:user).person, @aspect0)
@user.contacts.count.should == 2
get :manage
contacts = assigns(:contacts)
contacts.count.should == 1
contacts.first.should == @contact
end
context "when the user has pending requests" do
before do
requestor = Factory.create(:user)
requestor_aspect = requestor.aspects.create(:name => "Meh")
requestor.send_contact_request_to(@user.person, requestor_aspect)
requestor.reload
requestor_aspect.reload
@user.reload
end
it "succeeds" do
get :manage
response.should be_success
end
it "assigns aspect to manage" do
get :manage
assigns(:aspect).should == :manage
end
it "assigns remote_requests" do
get :manage
assigns(:remote_requests).count.should == 1
end
Sarah Mei
a validé
it "generates a jasmine fixture" do
get :manage
save_fixture(html_for("body"), "aspects_manage")
end
end
end
describe "#move_contact" do
before do
@person = Factory.create(:person)
@opts = {
:person_id => @person.id,
:to =>
{:to => @aspect1.id}
}
end
it 'calls the move_contact_method' do
@controller.stub!(:current_user).and_return(@user)
@user.should_receive(:move_contact)
post :move_contact, @opts
describe "#hashes_for_contacts" do
before do
@people = []
10.times {@people << Factory.create(:person)}
@people.each{|p| @user.reload.activate_contact(p, @user.aspects.first.reload)}
@hashes = @controller.send(:hashes_for_contacts,@user.reload.contacts)
@hash = @hashes.first
end
it 'has as many hashes as contacts' do
@hashes.length.should == @user.contacts.length
end
it 'has a contact' do
@hash[:contact].should == @user.contacts.first
end
it 'has a person' do
@hash[:person].should == @user.contacts.first.person
end
it "does not select the person's rsa key" do
@hash[:person].serialized_public_key.should be_nil
end
describe "#hashes_for_aspects" do
before do
@people = []
10.times {@people << Factory.create(:person)}
@people.each do |p|
@user.reload.activate_contact(p, @user.aspects.first.reload)
@user.add_contact_to_aspect(@user.contact_for(p), @aspect1)
end
@hashes = @controller.send(:hashes_for_aspects, @user.aspects, @user.contacts, :limit => 9)
end
it 'has aspects' do
@hash[:aspect].should == @aspect0
Raphael
a validé
it 'has a contact_count' do
@hash[:contact_count].should == @aspect0.contacts.count
Raphael
a validé
it 'takes a limit on contacts returned' do
@hash[:contacts].count.should == 9
Raphael
a validé
it 'has a person in each hash' do
@aspect0.contacts.map{|c| c.person}.include?(@hash[:contacts].first[:person]).should be_true
Raphael
a validé
@hash[:contacts].first[:person].serialized_public_key.should be_nil
end
it 'has a contact in each hash' do
@aspect0.contacts.include?(@hash[:contacts].first[:contact]).should be_true
@hashes = @controller.send(:hashes_for_aspects, @user.aspects, @user.contacts)
@hash = @hashes.first
flattened = @hash[:contacts].map{|c| c[:person].id}
flattened.uniq.should == flattened
describe "#update" do
before do
@aspect0 = @user.aspects.create(:name => "Bruisers")
end
it "doesn't overwrite random attributes" do
new_user = Factory.create :user
params = {"name" => "Bruisers"}
params[:user_id] = new_user.id
put('update', :id => @aspect0.id, "aspect" => params)
Aspect.find(@aspect0.id).user_id.should == @user.id
Raphael
a validé
context 'with an incoming request' do
before do
@user3 = Factory.create(:user)
Raphael
a validé
@user3.send_contact_request_to(@user.person, @user3.aspects.create(:name => "Walruses"))
end
it 'deletes the request' do
post 'add_to_aspect',
:format => 'js',
:person_id => @user3.person.id,
:aspect_id => @aspect1.id
Request.where(:sender_id => @user3.person.id, :recipient_id => @user.person.id).first.should be_nil
Raphael
a validé
end
it 'does not leave the contact pending' do
post 'add_to_aspect',
:format => 'js',
:person_id => @user3.person.id,
:aspect_id => @aspect1.id
@user.contact_for(@user3.person).should_not be_pending
end
end
Raphael
a validé
before do
@person = Factory(:person)
end
it 'calls send_contact_request_to' do
@user.should_receive(:send_contact_request_to).with(@person, @aspect1)
post 'add_to_aspect',
:format => 'js',
:person_id => @person.id,
:aspect_id => @aspect1.id
end
it 'does not call add_contact_to_aspect' do
@user.should_not_receive(:add_contact_to_aspect)
post 'add_to_aspect',
:format => 'js',
:person_id => @person.id,
:aspect_id => @aspect1.id
@user.should_receive(:add_contact_to_aspect)
post 'add_to_aspect',
:format => 'js',
:person_id => @user2.person.id,
:aspect_id => @aspect1.id
end
describe '#edit' do
it 'renders' do
get :edit, :id => @aspect0.id
response.should be_success
end
end
describe "#remove_from_aspect" do
it 'removes contacts from an aspect' do
Raphael
a validé
@user.add_contact_to_aspect(@contact, @aspect1)
post 'remove_from_aspect',
:format => 'js',
:person_id => @user2.person.id,
@aspect0.reload
@aspect0.contacts.include?(@contact).should be false
end