forked from External/greenlight
* Added the administrator role and functionality that comes with it (#403) * GRN-20: Added roles to the user model * GRN-75: Added a view for admins to see their users * GRN-77: Added Edit/Delete/Promote ability for admins * GRN-71: Added admin account by default * Changed the way locales are shown * Updated the rest of the locales * Changed the way available_locales are defined * Updated locales in Russian * Updated locaales for German * Update user.rb * Update admins.js * GRN-15: Added the ability to change color and image from admin interface (#425) * GRN-20: Added roles to the user model * GRN-75: Added a view for admins to see their users * GRN-77: Added Edit/Delete/Promote ability for admins * GRN-71: Added admin account by default * Changed the way locales are shown * Updated the rest of the locales * Changed the way available_locales are defined * Updated locales in Russian * Updated locaales for German * GRN-15: Added the ability for admins to customize color and image * Update user.rb * Update user.rb * Update routes.rb * Update admins_controller.rb * GRN-87:Added a super admin role and made changes to how to the design works (#430) * GRN-20: Added roles to the user model * GRN-75: Added a view for admins to see their users * GRN-77: Added Edit/Delete/Promote ability for admins * GRN-71: Added admin account by default * Changed the way locales are shown * Updated the rest of the locales * Changed the way available_locales are defined * Updated locales in Russian * Updated locaales for German * GRN-15: Added the ability for admins to customize color and image * Added the super admin and completed the design tab * Update user.rb * Update themes_controller_spec.rb * Update routes.rb * Update admins_controller.rb * Removed duplicated code that broke the build after last merge * GRN-78: Restructured some of the views to make the UI more consistent and responsive (#435) * GRN-20: Added roles to the user model * GRN-75: Added a view for admins to see their users * GRN-77: Added Edit/Delete/Promote ability for admins * GRN-71: Added admin account by default * GRN-15: Added the ability for admins to customize color and image * Added the super admin and completed the design tab * GRN-78: Cleaned up buttons and moved signin to its own page * GRN-78: Moved the Rooms and Recordings link to nav bar * Merge fix * Views restructure fix (#458) * Added cache to gitlab-ci.yml * Restructured seed * GRN2-99 -> GRN2-106: UI cleanup and refactoring (#478) * GRN2-98: Change Fullname to Full name * GRN2-105: Changed View Users to Manage Users * GRN2-101/103: Updated email to match branding * GRN2-100: Updated Email Sent flash to be more descriptive * GRN2-104: Redirect user to sign in page w/ flash after clicking activation link * GRN2-102: Changed the wording in the verification email * GRN2-99: Added email form validation * GRN2-106: Cleaned up Users list front end * Fixes to rake and admin password validator for passing rubocop * GRN2-113: Fixed issues with admin panel (#479) * GRN2-116: Code clean up after restructure of views (#482) * Removed unused references * Rubocop * Added pagination to admin view (#483) * GRN2-114: Added the ability for admins to ban/unban users (#487) * Added the ability for admins to ban and unban users * Update sessions_helper.rb * Merge branch 'master' into admin-panel (#492) * Updated rubocop gem * Updated rubocop and fixed issues (#490) * Rubocop fixes * GRN2-122: Updated sign in flow for admins and switch design tab to site settings (#489) * Switched design tab to site settings * Update _header with spaces instead of tabs * Added more test cases to increase coverage (#494)
235 lines
6.9 KiB
Ruby
235 lines
6.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
# BigBlueButton open source conferencing system - http://www.bigbluebutton.org/.
|
|
#
|
|
# Copyright (c) 2018 BigBlueButton Inc. and by respective authors (see below).
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify it under the
|
|
# terms of the GNU Lesser General Public License as published by the Free Software
|
|
# Foundation; either version 3.0 of the License, or (at your option) any later
|
|
# version.
|
|
#
|
|
# BigBlueButton is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
# PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public License along
|
|
# with BigBlueButton; if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
require "rails_helper"
|
|
|
|
describe SessionsController, type: :controller do
|
|
describe "GET #destroy" do
|
|
before(:each) do
|
|
user = create(:user, provider: "greenlight")
|
|
@request.session[:user_id] = user.id
|
|
get :destroy
|
|
end
|
|
|
|
it "should logout user" do
|
|
expect(@request.session[:user_id]).to be_nil
|
|
end
|
|
|
|
it "should redirect to root" do
|
|
expect(response).to redirect_to(root_path)
|
|
end
|
|
end
|
|
|
|
describe "POST #create" do
|
|
before { allow(Rails.configuration).to receive(:enable_email_verification).and_return(true) }
|
|
before(:each) do
|
|
@user1 = create(:user, provider: 'greenlight', password: 'example', password_confirmation: 'example')
|
|
@user2 = create(:user, password: 'example', password_confirmation: "example")
|
|
end
|
|
|
|
it "should login user in if credentials valid" do
|
|
post :create, params: {
|
|
session: {
|
|
email: @user1.email,
|
|
password: 'example',
|
|
},
|
|
}
|
|
|
|
expect(@request.session[:user_id]).to eql(@user1.id)
|
|
end
|
|
|
|
it "should not login user in if credentials invalid" do
|
|
post :create, params: {
|
|
session: {
|
|
email: @user1.email,
|
|
password: 'invalid',
|
|
},
|
|
}
|
|
|
|
expect(@request.session[:user_id]).to be_nil
|
|
end
|
|
|
|
it "should not login user in if account mismatch" do
|
|
post :create, params: {
|
|
session: {
|
|
email: @user2.email,
|
|
password: "example",
|
|
},
|
|
}
|
|
|
|
expect(@request.session[:user_id]).to be_nil
|
|
end
|
|
|
|
it "should not login user if account is not verified" do
|
|
@user3 = create(:user, email_verified: false, provider: "greenlight",
|
|
password: "example", password_confirmation: 'example')
|
|
|
|
post :create, params: {
|
|
session: {
|
|
email: @user3.email,
|
|
password: 'example',
|
|
},
|
|
}
|
|
|
|
expect(@request.session[:user_id]).to be_nil
|
|
expect(response).to redirect_to(account_activation_path(email: @user3.email))
|
|
end
|
|
|
|
it "redirects the user to the page they clicked sign in from" do
|
|
user = create(:user, provider: "greenlight",
|
|
password: "example", password_confirmation: 'example')
|
|
|
|
url = Faker::Internet.domain_name
|
|
|
|
@request.cookies[:return_to] = url
|
|
|
|
post :create, params: {
|
|
session: {
|
|
email: user.email,
|
|
password: 'example',
|
|
},
|
|
}
|
|
|
|
expect(@request.session[:user_id]).to eql(user.id)
|
|
expect(response).to redirect_to(url)
|
|
end
|
|
|
|
it "redirects the user to their home room if they clicked the sign in button from root" do
|
|
user = create(:user, provider: "greenlight",
|
|
password: "example", password_confirmation: 'example')
|
|
|
|
@request.cookies[:return_to] = root_url
|
|
|
|
post :create, params: {
|
|
session: {
|
|
email: user.email,
|
|
password: 'example',
|
|
},
|
|
}
|
|
|
|
expect(@request.session[:user_id]).to eql(user.id)
|
|
expect(response).to redirect_to(user.main_room)
|
|
end
|
|
|
|
it "redirects the user to their home room if return_to cookie doesn't exist" do
|
|
user = create(:user, provider: "greenlight",
|
|
password: "example", password_confirmation: 'example')
|
|
|
|
post :create, params: {
|
|
session: {
|
|
email: user.email,
|
|
password: 'example',
|
|
},
|
|
}
|
|
|
|
expect(@request.session[:user_id]).to eql(user.id)
|
|
expect(response).to redirect_to(user.main_room)
|
|
end
|
|
|
|
it "redirects to the admins page for admins" do
|
|
user = create(:user, provider: "greenlight",
|
|
password: "example", password_confirmation: 'example')
|
|
user.add_role :super_admin
|
|
|
|
post :create, params: {
|
|
session: {
|
|
email: user.email,
|
|
password: 'example',
|
|
},
|
|
}
|
|
|
|
expect(@request.session[:user_id]).to eql(user.id)
|
|
expect(response).to redirect_to(admins_path)
|
|
end
|
|
end
|
|
|
|
describe "GET/POST #omniauth" do
|
|
before(:all) do
|
|
OmniAuth.config.test_mode = true
|
|
|
|
OmniAuth.config.mock_auth[:twitter] = OmniAuth::AuthHash.new(
|
|
provider: "twitter",
|
|
uid: "twitter-user",
|
|
info: {
|
|
email: "user@twitter.com",
|
|
name: "Twitter User",
|
|
nickname: "twitteruser",
|
|
image: "example.png",
|
|
},
|
|
)
|
|
|
|
OmniAuth.config.mock_auth[:bn_launcher] = OmniAuth::AuthHash.new(
|
|
provider: "bn_launcher",
|
|
uid: "bn-launcher-user",
|
|
info: {
|
|
email: "user@google.com",
|
|
name: "Google User",
|
|
nickname: "googleuser",
|
|
image: "touch.png",
|
|
customer: 'customer1',
|
|
}
|
|
)
|
|
|
|
OmniAuth.config.on_failure = proc { |env|
|
|
OmniAuth::FailureEndpoint.new(env).redirect_to_failure
|
|
}
|
|
end
|
|
|
|
unless Rails.configuration.omniauth_bn_launcher
|
|
it "should create and login user with omniauth twitter" do
|
|
request.env["omniauth.auth"] = OmniAuth.config.mock_auth[:twitter]
|
|
get :omniauth, params: { provider: :twitter }
|
|
|
|
u = User.last
|
|
expect(u.provider).to eql("twitter")
|
|
expect(u.email).to eql("user@twitter.com")
|
|
expect(@request.session[:user_id]).to eql(u.id)
|
|
end
|
|
|
|
it "should create and login user with omniauth bn launcher" do
|
|
request.env["omniauth.auth"] = OmniAuth.config.mock_auth[:bn_launcher]
|
|
get :omniauth, params: { provider: 'bn_launcher' }
|
|
|
|
u = User.last
|
|
expect(u.provider).to eql("customer1")
|
|
expect(u.email).to eql("user@google.com")
|
|
expect(@request.session[:user_id]).to eql(u.id)
|
|
end
|
|
|
|
it "should redirect to root on invalid omniauth login" do
|
|
request.env["omniauth.auth"] = :invalid_credentials
|
|
get :omniauth, params: { provider: :twitter }
|
|
|
|
expect(response).to redirect_to(root_path)
|
|
end
|
|
|
|
it "should not create session without omniauth env set for google" do
|
|
get :omniauth, params: { provider: 'google' }
|
|
|
|
expect(response).to redirect_to(root_path)
|
|
end
|
|
end
|
|
|
|
it "should not create session without omniauth env set for bn_launcher" do
|
|
get :omniauth, params: { provider: 'bn_launcher' }
|
|
|
|
expect(response).to redirect_to(root_path)
|
|
end
|
|
end
|
|
end
|