require 'spec_helper' describe InvitesController do context '.destroy' do it 'requires you to be logged in' do lambda { delete :destroy, email: 'jake@adventuretime.ooo' }.should raise_error(Discourse::NotLoggedIn) end context 'while logged in' do let!(:user) { log_in } let!(:invite) { Fabricate(:invite, invited_by: user) } let(:another_invite) { Fabricate(:invite, email: 'anotheremail@address.com') } it 'raises an error when the email is missing' do lambda { delete :destroy }.should raise_error(ActionController::ParameterMissing) end it "raises an error when the email cannot be found" do lambda { delete :destroy, email: 'finn@adventuretime.ooo' }.should raise_error(Discourse::InvalidParameters) end it 'raises an error when the invite is not yours' do lambda { delete :destroy, email: another_invite.email }.should raise_error(Discourse::InvalidParameters) end it "destroys the invite" do Invite.any_instance.expects(:trash!) delete :destroy, email: invite.email end end end context '.show' do context 'with an invalid invite id' do before do get :show, id: "doesn't exist" end it "redirects to the root" do response.should redirect_to("/") end it "should not change the session" do session[:current_user_id].should be_blank end end context 'with a deleted invite' do let(:topic) { Fabricate(:topic) } let(:invite) { topic.invite_by_email(topic.user, "iceking@adventuretime.ooo") } let(:deleted_invite) { invite.destroy; invite } before do get :show, id: deleted_invite.invite_key end it "redirects to the root" do response.should redirect_to("/") end it "should not change the session" do session[:current_user_id].should be_blank end end context 'with a valid invite id' do let(:topic) { Fabricate(:topic) } let(:invite) { topic.invite_by_email(topic.user, "iceking@adventuretime.ooo") } it 'redeems the invite' do Invite.any_instance.expects(:redeem) get :show, id: invite.invite_key end context 'when redeem returns a user' do let(:user) { Fabricate(:coding_horror) } context 'success' do before do Invite.any_instance.expects(:redeem).returns(user) get :show, id: invite.invite_key end it 'logs in the user' do session[:current_user_id].should == user.id end it 'redirects to the first topic the user was invited to' do response.should redirect_to(topic.relative_url) end end context 'welcome message' do before do Invite.any_instance.stubs(:redeem).returns(user) Jobs.expects(:enqueue).with(:invite_email, has_key(:invite_id)) end it 'sends a welcome message if set' do user.send_welcome_message = true user.expects(:enqueue_welcome_message).with('welcome_invite') get :show, id: invite.invite_key end it "doesn't send a welcome message if not set" do user.expects(:enqueue_welcome_message).with('welcome_invite').never get :show, id: invite.invite_key end end context 'access_required' do it "doesn't set a cookie for access if there is no access required" do SiteSetting.stubs(:access_password).returns(nil) Invite.any_instance.expects(:redeem).returns(user) get :show, id: invite.invite_key cookies[:_access].should be_blank end it "sets the cookie when access is required" do SiteSetting.stubs(:access_password).returns('adventure time!') Invite.any_instance.expects(:redeem).returns(user) get :show, id: invite.invite_key cookies[:_access].should == 'adventure time!' end end end end end end