152 lines
4.3 KiB
Ruby
152 lines
4.3 KiB
Ruby
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(Discourse::InvalidParameters)
|
|
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(:destroy)
|
|
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.expects(:restrict_access?).returns(false)
|
|
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.expects(:restrict_access?).returns(true)
|
|
SiteSetting.expects(: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
|