Newer
Older
# licensed under the Affero General Public License version 3 or later. See
Daniel Vincent Grippi
a validé
let(:connected_person) { Factory.create(:person) }
let(:connected_person_2) { Factory.create(:person) }
ilya
a validé
let(:aspect) {user.aspects.first }
let(:aspect2) {user2.aspects.first }
danielvincent
a validé
let(:aspect1) {user.aspects.create(:name => 'cats')}
let(:user3) {Factory.create(:user)}
danielvincent
a validé
let(:aspect3) {user3.aspects.create(:name => "lala")}
describe 'creation' do
danielvincent
a validé
let!(:aspect){user.aspects.create(:name => 'losers')}
it 'has a name' do
it 'does not allow duplicate names' do
danielvincent
a validé
invalid_aspect = user.aspects.create(:name => "losers ")
}.should_not change(Aspect, :count)
end
it 'validates case insensitiveness on names' do
lambda {
invalid_aspect = user.aspects.create(:name => "Losers ")
}.should_not change(Aspect, :count)
end
it 'has a 20 character limit on names' do
aspect = Aspect.new(:name => "this name is really too too too too too long")
aspect.valid?.should == false
end
it 'is able to have other users as contacts' do
Contact.create(:user => user, :person => user2.person, :aspects => [aspect])
aspect.contacts.where(:person_id => user.person.id).should be_empty
aspect.contacts.where(:person_id => user2.person.id).should_not be_empty
danielvincent
a validé
aspect.contacts.size.should == 1
it 'is able to have users and people and contacts' do
contact1 = Contact.create(:user => user, :person => user2.person, :aspects => [aspect])
contact2 = Contact.create(:user => user, :person => connected_person_2, :aspects => [aspect])
danielvincent
a validé
aspect.contacts.include?(contact1).should be_true
aspect.contacts.include?(contact2).should be_true
aspect.save.should be_true
it 'has a contacts_visible? method' do
aspect.contacts_visible?.should be_true
end
describe 'validation' do
it 'has a unique name for one user' do
danielvincent
a validé
aspect2 = user.aspects.create(:name => aspect.name)
aspect2.valid?.should be_false
end
it 'has no uniqueness between users' do
aspect = user.aspects.create(:name => "New Aspect")
danielvincent
a validé
aspect2 = user2.aspects.create(:name => aspect.name)
aspect2.should be_valid
describe 'querying' do
before do
user.activate_contact(connected_person, aspect)
end
it 'belong to a user' do
aspect.user.id.should == user.id
user.aspects.should == [aspect]
danielvincent
a validé
it 'should have contacts' do
aspect.contacts.size.should == 2
end
describe '#aspects_with_person' do
let!(:aspect_without_contact) {user.aspects.create(:name => "Another aspect")}
it 'should return the aspects with given contact' do
aspects = user.aspects_with_person(connected_person)
end
it 'returns multiple aspects if the person is there' do
user.reload
Raphael
a validé
contact = user.contact_for(connected_person)
user.add_contact_to_aspect(contact, aspect1)
aspects = user.aspects_with_person(connected_person)
danielvincent
a validé
aspects.each{ |asp| asp.contacts.include?(contact).should be_true }
aspects.include?(aspect_without_contact).should be_false
aspect = user.aspects.create(:name => 'losers')
contact = aspect.contacts.create(:person => connected_person)
ilya
a validé
status_message = user.post( :status_message, :message => "hey", :to => aspect.id )
aspect.reload
aspect.posts.include?(status_message).should be true
danielvincent
a validé
aspect = user.aspects.create(:name => 'losers')
aspect2 = user2.aspects.create(:name => 'winners')
connect_users(user, aspect, user2, aspect2)
ilya
a validé
message = user2.post(:status_message, :message => "Hey Dude", :to => aspect2.id)
aspect.reload
aspect.posts.include?(message).should be true
ilya
a validé
user.visible_posts(:by_members_of => aspect).include?(message).should be true
it 'should retract the post from the aspects as well' do
danielvincent
a validé
aspect = user.aspects.create(:name => 'losers')
aspect2 = user2.aspects.create(:name => 'winners')
connect_users(user, aspect, user2, aspect2)
ilya
a validé
message = user2.post(:status_message, :message => "Hey Dude", :to => aspect2.id)
aspect.reload.post_ids.include?(message.id).should be true
fantasy_resque do
retraction = user2.retract(message)
end
aspect.posts(true).include?(message).should be false
ilya
a validé
context "aspect management" do
before do
connect_users(user, aspect, user2, aspect2)
ilya
a validé
user.reload
Raphael
a validé
@contact = user.contact_for(user2.person)
Raphael
a validé
describe "#add_contact_to_aspect" do
it 'adds the contact to the aspect' do
aspect1.contacts.include?(@contact).should be_false
user.add_contact_to_aspect(@contact, aspect1)
aspect1.reload
aspect1.contacts.include?(@contact).should be_true
Raphael
a validé
it 'returns true if they are already in the aspect' do
user.add_contact_to_aspect(@contact, aspect).should == true
describe '#delete_person_from_aspect' do
it 'deletes a user from the aspect' do
Raphael
a validé
user.add_contact_to_aspect(@contact, aspect1)
user.reload
user.delete_person_from_aspect(user2.person.id, aspect1.id)
user.reload
aspect1.contacts(true).include?(@contact).should be_false
end
it 'should check to make sure you have the aspect ' do
ilya
a validé
proc{user.delete_person_from_aspect(user2.person.id, aspect2.id) }.should raise_error /Can not delete a person from an aspect you do not own/
end
Raphael
a validé
user.add_contact_to_aspect(@contact, aspect1)
user.reload
user2.post(:status_message, :message => "Hey Dude", :to => aspect2.id)
lambda{
user.delete_person_from_aspect(user2.person.id, aspect1.id)
}.should_not change(Post, :count)
end
ilya
a validé
it 'should not allow removing a contact from their last aspect' do
proc{user.delete_person_from_aspect(user2.person.id, aspect.id) }.should raise_error /Can not delete a person from last aspect/
end
it 'should allow a force removal of a contact from an aspect' do
Raphael
a validé
@contact.aspect_ids.should_receive(:count).exactly(0).times
Raphael
a validé
user.add_contact_to_aspect(@contact, aspect1)
user.delete_person_from_aspect(user2.person.id, aspect.id, :force => true)
end
ilya
a validé
end
ilya
a validé
context 'moving and removing posts' do
ilya
a validé
before do
@message = user2.post(:status_message, :message => "Hey Dude", :to => aspect2.id)
ilya
a validé
aspect.reload
user.reload
end
Raphael
a validé
it 'should keep the contact\'s posts in previous aspect' do
aspect.post_ids.count.should == 1
user.delete_person_from_aspect(user2.person.id, aspect.id, :force => true)
ilya
a validé
aspect.reload
aspect.post_ids.count.should == 1
ilya
a validé
end
ilya
a validé
it 'should not delete other peoples posts' do
connect_users(user, aspect, user3, aspect3)
user.delete_person_from_aspect(user3.person.id, aspect.id, :force => true)
ilya
a validé
aspect.reload
ilya
a validé
end
describe '#move_contact' do
it 'should be able to move a contact from one of users existing aspects to another' do
Raphael
a validé
user.move_contact(user2.person, aspect1, aspect)
aspect.contacts(true).include?(@contact).should be_false
aspect1.contacts(true).include?(@contact).should be_true
ilya
a validé
end
it "should not move a person who is not a contact" do
Raphael
a validé
proc{
user.move_contact(connected_person, aspect1, aspect)
}.should raise_error
ilya
a validé
aspect.reload
aspect1.reload
aspect.contacts.where(:person_id => connected_person.id).should be_empty
aspect1.contacts.where(:person_id => connected_person.id).should be_empty
ilya
a validé
end
ilya
a validé
it 'does not try to delete if add person did not go through' do
Raphael
a validé
user.should_receive(:add_contact_to_aspect).and_return(false)
ilya
a validé
user.should_not_receive(:delete_person_from_aspect)
Raphael
a validé
user.move_contact(user2.person, aspect1, aspect)
ilya
a validé
end