mirror of
https://github.com/Growstuff/growstuff.git
synced 2025-12-24 01:57:46 -05:00
97 lines
3.0 KiB
Ruby
97 lines
3.0 KiB
Ruby
require 'rails_helper'
|
|
|
|
describe NotificationsController do
|
|
|
|
login_member
|
|
|
|
def valid_attributes
|
|
{
|
|
"recipient_id" => subject.current_member.id,
|
|
"sender_id" => FactoryGirl.create(:member).id,
|
|
"subject" => 'test'
|
|
}
|
|
end
|
|
|
|
# this gets a bit confused because for most of the notification tests
|
|
# (reading, etc) the logged in member needs to be the recipient.
|
|
# However, for sending private messages (create, etc) the logged in
|
|
# member needs to be the sender. Hence this separate set of
|
|
# attributes.
|
|
def valid_attributes_for_sender
|
|
{
|
|
"sender_id" => subject.current_member.id,
|
|
"recipient_id" => FactoryGirl.create(:member).id,
|
|
"subject" => 'test'
|
|
}
|
|
end
|
|
|
|
def valid_session
|
|
{}
|
|
end
|
|
|
|
describe "GET index" do
|
|
it "assigns all notifications as @notifications" do
|
|
notification = FactoryGirl.create(:notification, :recipient_id => subject.current_member.id)
|
|
get :index, {}
|
|
assigns(:notifications).should eq([notification])
|
|
end
|
|
end
|
|
|
|
describe "GET show" do
|
|
it "assigns the requested notification as @notification" do
|
|
notification = FactoryGirl.create(:notification, :recipient_id => subject.current_member.id)
|
|
get :show, {:id => notification.to_param}
|
|
assigns(:notification).should eq(notification)
|
|
end
|
|
|
|
it "assigns the reply link for a PM" do
|
|
notification = FactoryGirl.create(:notification, :recipient_id => subject.current_member.id, :post_id => nil)
|
|
subject = "Re: " + notification.subject
|
|
|
|
get :show, {:id => notification.to_param}
|
|
assigns(:reply_link).should_not be_nil
|
|
assigns(:reply_link).should eq new_notification_url(
|
|
:recipient_id => notification.sender_id,
|
|
:subject => subject
|
|
)
|
|
end
|
|
|
|
it "assigns the reply link for a post comment" do
|
|
notification = FactoryGirl.create(:notification, :recipient_id => subject.current_member.id)
|
|
|
|
get :show, {:id => notification.to_param}
|
|
assigns(:reply_link).should_not be_nil
|
|
assigns(:reply_link).should eq new_comment_url(
|
|
:post_id => notification.post.id
|
|
)
|
|
end
|
|
|
|
it "marks notifications as read" do
|
|
notification = FactoryGirl.create(:notification, :recipient_id => subject.current_member.id)
|
|
get :show, {:id => notification.to_param}
|
|
# we need to fetch it from the db again, can't test against the old one
|
|
n = Notification.find(notification.id)
|
|
n.read.should eq true
|
|
end
|
|
end
|
|
|
|
describe "GET new" do
|
|
it "assigns a recipient" do
|
|
@recipient = FactoryGirl.create(:member)
|
|
get :new, {:recipient_id => @recipient.id }
|
|
assigns(:recipient).should be_an_instance_of(Member)
|
|
end
|
|
end
|
|
|
|
describe "POST create" do
|
|
describe "with valid params" do
|
|
it "redirects to the recipient's profile" do
|
|
@recipient = FactoryGirl.create(:member)
|
|
post :create, { :notification => { :recipient_id => @recipient.id, :subject => 'foo' } }
|
|
response.should redirect_to(notifications_path)
|
|
end
|
|
end
|
|
|
|
end
|
|
end
|