parent
8cffc4872c
commit
086a39ca3d
@ -1,5 +0,0 @@ |
||||
require 'rails_helper' |
||||
|
||||
RSpec.describe ErrorsController, type: :controller do |
||||
|
||||
end |
@ -1,74 +0,0 @@ |
||||
require 'rails_helper' |
||||
|
||||
describe SessionsController, type: :controller do |
||||
|
||||
context "GET #new," do |
||||
it "renders the #new view." do |
||||
get :new |
||||
expect(response).to render_template :new |
||||
end |
||||
end |
||||
|
||||
context "POST #create," do |
||||
it "should signin user." do |
||||
user = create(:user) |
||||
post :create, params: {session: {email: user.email, password: user.password}} |
||||
|
||||
expect(response).to redirect_to room_path(user.room.uid) |
||||
expect(user.id).to eql(session[:user_id]) |
||||
end |
||||
|
||||
it "should render new on fail." do |
||||
user = create(:user) |
||||
post :create, params: {session: {email: user.email, password: "incorrect_password"}} |
||||
|
||||
expect(response).to render_template :new |
||||
end |
||||
end |
||||
|
||||
context "POST #launch," do |
||||
it "should login launched user." do |
||||
|
||||
end |
||||
end |
||||
|
||||
context "POST #omniauth," do |
||||
it "should login omniauth user." do |
||||
email = "omniauth@test.com" |
||||
uid = "123456789" |
||||
|
||||
OmniAuth.config.test_mode = true |
||||
OmniAuth.config.add_mock(:twitter, { |
||||
provider: "twitter", |
||||
uid: uid, |
||||
info: { |
||||
email: email, |
||||
name: "Omni User", |
||||
nickname: "username" |
||||
} |
||||
}) |
||||
|
||||
get "/auth/twitter" |
||||
|
||||
request.env["omniauth.auth"] = OmniAuth.config.mock_auth[:twitter] |
||||
get omniauth_session_path(provider: "twitter") |
||||
|
||||
user = User.find_by(email: email, uid: uid) |
||||
|
||||
expect(response).to redirect_to room_path(user.room.uid) |
||||
expect(user.id).to eql(session[:user_id]) |
||||
end |
||||
end |
||||
|
||||
context "GET #destroy," do |
||||
it "should logout user." do |
||||
user = create(:user) |
||||
session[:user_id] = user.id |
||||
get :destroy |
||||
|
||||
expect(response).to redirect_to root_path |
||||
expect(user.id).to_not eql(session[:user_id]) |
||||
end |
||||
end |
||||
|
||||
end |
@ -1,15 +0,0 @@ |
||||
require 'rails_helper' |
||||
|
||||
# Specs in this file have access to a helper object that includes |
||||
# the ErrorsHelper. For example: |
||||
# |
||||
# describe ErrorsHelper do |
||||
# describe "string concat" do |
||||
# it "concats two strings with spaces" do |
||||
# expect(helper.concat_strings("this","that")).to eq("this that") |
||||
# end |
||||
# end |
||||
# end |
||||
RSpec.describe ErrorsHelper, type: :helper do |
||||
pending "add some examples to (or delete) #{__FILE__}" |
||||
end |
@ -1,19 +0,0 @@ |
||||
require "rails_helper" |
||||
|
||||
describe Meeting, type: :model do |
||||
|
||||
it "should be valid." do |
||||
meeting = create(:meeting) |
||||
expect(meeting).to be_valid |
||||
end |
||||
|
||||
it "name should be present." do |
||||
meeting = build(:meeting, name: nil) |
||||
expect(meeting).to_not be_valid |
||||
end |
||||
|
||||
it "#random_password is random." do |
||||
meeting = create(:meeting) |
||||
expect(meeting.send(:random_password, 10)).to_not eql(meeting.send(:random_password, 10)) |
||||
end |
||||
end |
@ -1,21 +1,27 @@ |
||||
require "rails_helper" |
||||
|
||||
describe Room, type: :model do |
||||
before { @room = create(:room) } |
||||
|
||||
describe "#owned_by?" do |
||||
it "should identify correct owner." do |
||||
room = create(:room) |
||||
expect(room.owned_by?(room.user)).to eql(true) |
||||
end |
||||
context 'validations' do |
||||
it { should validate_presence_of :name } |
||||
end |
||||
|
||||
context 'associations' do |
||||
it { should belong_to(:owner).class_name("User") } |
||||
end |
||||
|
||||
it "should identify incorrect owner." do |
||||
room = create(:room) |
||||
expect(room.owned_by?(create(:user))).to eql(false) |
||||
context '#setup' do |
||||
it 'creates random uid and bbb_id' do |
||||
expect(@room.uid).to_not be_nil |
||||
expect(@room.bbb_id).to_not be_nil |
||||
end |
||||
end |
||||
|
||||
it "should return false when user is nil." do |
||||
room = create(:room) |
||||
expect(room.owned_by?(nil)).to eql(false) |
||||
context "#to_param" do |
||||
it "uses uid as the default identifier for routes" do |
||||
expect(@room.to_param).to eq(@room.uid) |
||||
end |
||||
end |
||||
end |
||||
|
||||
end |
||||
|
@ -1,105 +1,59 @@ |
||||
require "rails_helper" |
||||
|
||||
describe User, type: :model do |
||||
before { @user = create(:user) } |
||||
|
||||
it "should be valid." do |
||||
user = create(:user) |
||||
expect(user).to be_valid |
||||
end |
||||
|
||||
it "name should be present." do |
||||
user = build(:user, name: nil) |
||||
expect(user).to_not be_valid |
||||
end |
||||
|
||||
it "username should be present." do |
||||
user = build(:user, username: nil) |
||||
expect(user).to_not be_valid |
||||
end |
||||
|
||||
it "provider should be present." do |
||||
user = build(:user, provider: nil) |
||||
expect(user).to_not be_valid |
||||
end |
||||
|
||||
it "should allow nil email." do |
||||
user = build(:user, email: nil) |
||||
expect(user).to be_valid |
||||
end |
||||
|
||||
it "should allow nil uid." do |
||||
user = build(:user, uid: nil) |
||||
expect(user).to be_valid |
||||
end |
||||
|
||||
it "should allow nil password." do |
||||
user = build(:user, password: nil, password_confirmation: nil) |
||||
expect(user).to be_valid |
||||
end |
||||
context 'validations' do |
||||
it { should validate_presence_of(:name) } |
||||
it { should validate_length_of(:name).is_at_most(24) } |
||||
|
||||
it "password should be longer than six characters." do |
||||
user = build(:user, password: "short") |
||||
expect(user).to_not be_valid |
||||
end |
||||
|
||||
it "should create user from omniauth." do |
||||
auth = { |
||||
"uid" => "123456789", |
||||
"provider" => "twitter", |
||||
"info" => { |
||||
"name" => "Test Name", |
||||
"nickname" => "username", |
||||
"email" => "test@example.com" |
||||
} |
||||
} |
||||
it { should validate_presence_of(:provider) } |
||||
|
||||
user = User.from_omniauth(auth) |
||||
|
||||
expect(user.name).to eql(auth["info"]["name"]) |
||||
expect(user.username).to eql(auth["info"]["nickname"]) |
||||
end |
||||
it { should validate_uniqueness_of(:email).case_insensitive } |
||||
it { should validate_length_of(:email).is_at_most(60) } |
||||
it { should allow_value("", nil).for(:email) } |
||||
it { should allow_value("valid@email.com").for(:email) } |
||||
it { should_not allow_value("invalid_email").for(:email) } |
||||
|
||||
it "email addresses should be saved as lower-case." do |
||||
mixed = "ExAmPlE@eXaMpLe.CoM" |
||||
|
||||
user = build(:user, email: mixed) |
||||
user.save |
||||
|
||||
expect(user.email).to eql(mixed.downcase) |
||||
end |
||||
it { should allow_value("valid.jpg").for(:image) } |
||||
it { should allow_value("valid.png").for(:image) } |
||||
it { should_not allow_value("invalid.txt").for(:image) } |
||||
it { should allow_value("", nil).for(:image) } |
||||
|
||||
it "email validation should reject invalid addresses." do |
||||
invalid_addresses = %w[user@example,com user_at_foo.org user.name@example. foo@bar_baz.com foo@bar+baz.com] |
||||
user = create(:user) |
||||
context 'is greenlight account' do |
||||
before { allow(subject).to receive(:greenlight_account?).and_return(true) } |
||||
it { should validate_presence_of(:password) } |
||||
it { should validate_length_of(:password).is_at_least(6) } |
||||
end |
||||
|
||||
invalid_addresses.each do |invalid_address| |
||||
user.email = invalid_address |
||||
expect(user).to_not be_valid |
||||
context 'is not greenlight account' do |
||||
before { allow(subject).to receive(:greenlight_account?).and_return(false) } |
||||
it { should_not validate_presence_of(:password) } |
||||
end |
||||
end |
||||
|
||||
it "email should be unique." do |
||||
user = create(:user) |
||||
duplicate = user.dup |
||||
|
||||
expect(duplicate).to_not be_valid |
||||
context 'associations' do |
||||
it { should belong_to(:main_room).class_name("Room").with_foreign_key("room_id") } |
||||
it { should have_many(:rooms) } |
||||
end |
||||
|
||||
it "name should not be too long." do |
||||
user = build(:user, name: "a" * 25) |
||||
expect(user).to_not be_valid |
||||
context '#initialize_main_room' do |
||||
it 'creates random uid and main_room' do |
||||
expect(@user.uid).to_not be_nil |
||||
expect(@user.main_room).to be_a(Room) |
||||
end |
||||
end |
||||
|
||||
it "email should not be too long." do |
||||
user = build(:user, email: "a" * 50 + "@example.com") |
||||
expect(user).to_not be_valid |
||||
context "#to_param" do |
||||
it "uses uid as the default identifier for routes" do |
||||
expect(@user.to_param).to eq(@user.uid) |
||||
end |
||||
end |
||||
|
||||
it "should generate room and meeting when saved." do |
||||
user = create(:user) |
||||
user.save |
||||
|
||||
expect(user.room).to be_instance_of Room |
||||
expect(user.room.meeting).to be_instance_of Meeting |
||||
context '#first_name' do |
||||
it 'properly finds the users first name' do |
||||
user = create(:user, name: "Example User") |
||||
expect(user.firstname).to eq("Example") |
||||
end |
||||
end |
||||
end |
||||
end |
||||
|
@ -0,0 +1,9 @@ |
||||
# Configure Shoulda-Matchers. |
||||
|
||||
Shoulda::Matchers.configure do |config| |
||||
config.integrate do |with| |
||||
with.test_framework :rspec |
||||
|
||||
with.library :rails |
||||
end |
||||
end |
@ -1,7 +0,0 @@ |
||||
require 'test_helper' |
||||
|
||||
class MainControllerTest < ActionDispatch::IntegrationTest |
||||
# test "the truth" do |
||||
# assert true |
||||
# end |
||||
end |
@ -1,7 +0,0 @@ |
||||
require 'test_helper' |
||||
|
||||
class MeetingsControllerTest < ActionDispatch::IntegrationTest |
||||
# test "the truth" do |
||||
# assert true |
||||
# end |
||||
end |
@ -1,32 +0,0 @@ |
||||
require 'test_helper' |
||||
|
||||
class RoomsControllerTest < ActionDispatch::IntegrationTest |
||||
|
||||
def setup |
||||
@steve = users(:steve) |
||||
@mark = users(:mark) |
||||
|
||||
@kitchen = rooms(:kitchen) |
||||
@garage = rooms(:garage) |
||||
end |
||||
|
||||
test 'should redirect to root if not logged in.' do |
||||
get room_path(@kitchen.uid) |
||||
|
||||
assert_redirected_to root_path |
||||
end |
||||
|
||||
test 'should redirect to correct room if incorrect room.' do |
||||
post create_session_path, params: {session: {email: @mark.email, password: "mark12345"}} |
||||
get room_path(@kitchen.uid) |
||||
|
||||
assert_redirected_to room_path(@garage.uid) |
||||
end |
||||
|
||||
test 'should render room if user is owner.' do |
||||
post create_session_path, params: {session: {email: @steve.email, password: "steve12345"}} |
||||
get room_path(@kitchen.uid) |
||||
|
||||
assert_response :success |
||||
end |
||||
end |
@ -1,70 +0,0 @@ |
||||
require 'test_helper' |
||||
|
||||
class SessionsControllerTest < ActionDispatch::IntegrationTest |
||||
|
||||
def setup |
||||
@steve = users(:steve) |
||||
@kitchen = rooms(:kitchen) |
||||
|
||||
@steve.room = @kitchen |
||||
end |
||||
|
||||
test 'can signin with greenlight account.' do |
||||
post create_session_path, params: {session: {email: @steve.email, password: "steve12345"}} |
||||
|
||||
assert_redirected_to room_path(@steve.room.uid) |
||||
assert @steve.id, session[:user_id] |
||||
end |
||||
|
||||
test 'can signup/login with omniauth.' do |
||||
email = "omniauth@test.com" |
||||
uid = "123456789" |
||||
|
||||
OmniAuth.config.add_mock(:twitter, { |
||||
provider: "twitter", |
||||
uid: uid, |
||||
info: { |
||||
email: email, |
||||
name: "Omni User", |
||||
nickname: "username" |
||||
} |
||||
}) |
||||
|
||||
#get "/auth/twitter" |
||||
|
||||
request.env['omniauth.auth'] = OmniAuth.config.mock_auth[:twitter] |
||||
#get omniauth_session_path(provider: "twitter") |
||||
|
||||
user = User.find_by(email: email, uid: uid) |
||||
|
||||
assert_not_nil user |
||||
assert_redirected_to room_path(user.room.uid) |
||||
assert user.id, session[:user_id] |
||||
end |
||||
|
||||
test 'handles omniauth failure.' do |
||||
OmniAuth.config.on_failure = Proc.new do |env| |
||||
OmniAuth::FailureEndpoint.new(env).redirect_to_failure |
||||
end |
||||
|
||||
OmniAuth.config.mock_auth[:twitter] = :invalid_credentials |
||||
|
||||
get "/auth/twitter" |
||||
|
||||
request.env['omniauth.auth'] = OmniAuth.config.mock_auth[:twitter] |
||||
|
||||
assert_no_difference 'User.count' do |
||||
get omniauth_session_path(provider: "twitter") |
||||
end |
||||
|
||||
assert_redirected_to auth_failure_path(message: "invalid_credentials", strategy: "twitter") |
||||
end |
||||
|
||||
test 'can logout.' do |
||||
post create_session_path, params: {session: {email: @steve.email, password: "steve12345"}} |
||||
assert @steve.id, session[:user_id] |
||||
|
||||
get logout_path |
||||
assert_not_equal @steve.id, session[:user_id] |
||||
end |
||||
end |
@ -1,22 +0,0 @@ |
||||
require 'test_helper' |
||||
|
||||
class UsersControllerTest < ActionDispatch::IntegrationTest |
||||
|
||||
test 'can signup for greenlight account.' do |
||||
post signup_path, params: { |
||||
user: { |
||||
name: "Greenlight User", |
||||
username: "greenlight_user", |
||||
email: "greenlight@example.com", |
||||
password: "password", |
||||
password_confirmation: "password" |
||||
} |
||||
} |
||||
|
||||
user = User.find_by(email: "greenlight@example.com") |
||||
|
||||
assert_not_nil user |
||||
assert_redirected_to room_path(user.room.uid) |
||||
assert user.id, session[:user_id] |
||||
end |
||||
end |
@ -1,9 +0,0 @@ |
||||
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html |
||||
|
||||
# This model initially had no columns defined. If you add columns to the |
||||
# model remove the '{}' from the fixture names and add the columns immediately |
||||
# below each fixture, per the syntax in the comments below |
||||
# |
||||
|
||||
breakfast: |
||||
name: "Breakfast" |
@ -1,14 +0,0 @@ |
||||
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html |
||||
|
||||
# This model initially had no columns defined. If you add columns to the |
||||
# model remove the '{}' from the fixture names and add the columns immediately |
||||
# below each fixture, per the syntax in the comments below |
||||
# |
||||
|
||||
kitchen: |
||||
user: steve |
||||
uid: "13579" |
||||
|
||||
garage: |
||||
user: mark |
||||
uid: "02468" |
@ -1,20 +0,0 @@ |
||||
# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html |
||||
|
||||
# This model initially had no columns defined. If you add columns to the |
||||
# model remove the '{}' from the fixture names and add the columns immediately |
||||
# below each fixture, per the syntax in the comments below |
||||
# |
||||
|
||||
steve: |
||||
name: "Steve User" |
||||
username: "steve" |
||||
provider: "greenlight" |
||||
email: "steve@example.com" |
||||
password_digest: <%= BCrypt::Password.create('steve12345') %> |
||||
|
||||
mark: |
||||
name: "Mark User" |
||||
username: "mark" |
||||
provider: "greenlight" |
||||
email: "mark@example.com" |
||||
password_digest: <%= BCrypt::Password.create('mark12345') %> |
@ -1,23 +0,0 @@ |
||||
require 'test_helper' |
||||
|
||||
class MeetingTest < ActiveSupport::TestCase |
||||
|
||||
def setup |
||||
@steve = users(:steve) |
||||
|
||||
@kitchen = rooms(:kitchen) |
||||
|
||||
@breakfast = meetings(:breakfast) |
||||
@breakfast.room = @kitchen |
||||
end |
||||
|
||||
test "name should be present." do |
||||
@breakfast.name = nil |
||||
assert_not @breakfast.valid? |
||||
end |
||||
|
||||
test "should set uid on creation." do |
||||
@breakfast.send(:generate_meeting_id) |
||||
assert @breakfast.uid |
||||
end |
||||
end |
@ -1,20 +0,0 @@ |
||||
require 'test_helper' |
||||
|
||||
class RoomTest < ActiveSupport::TestCase |
||||
|
||||
def setup |
||||
@steve = users(:steve) |
||||
@mark = users(:mark) |
||||
|
||||
@kitchen = rooms(:kitchen) |
||||
@kitchen.user = @steve |
||||
end |
||||
|
||||
test "#owned_by? should identify correct owner." do |
||||
assert @kitchen.owned_by?(@steve) |
||||
end |
||||
|
||||
test "#owned_by? should identify incorrect owner." do |
||||
assert_not @kitchen.owned_by?(@mark) |
||||
end |
||||
end |
@ -1,118 +0,0 @@ |
||||
require 'test_helper' |
||||
|
||||
class UserTest < ActiveSupport::TestCase |
||||
|
||||
def setup |
||||
@steve = users(:steve) |
||||
end |
||||
|
||||
test "should be valid." do |
||||
assert @steve.valid? |
||||
end |
||||
|
||||
test "name should be present." do |
||||
@steve.name = nil |
||||
assert_not @steve.valid? |
||||
end |
||||
|
||||
test "should allow nil email." do |
||||
@steve.email = nil |
||||
assert @steve.valid? |
||||
end |
||||
|
||||
test "username should be present." do |
||||
@steve.username = nil |
||||
assert_not @steve.valid? |
||||
end |
||||
|
||||
test "provider should be present." do |
||||
@steve.provider = nil |
||||
assert_not @steve.valid? |
||||
end |
||||
|
||||
test "should allow nil uid." do |
||||
@steve.uid = nil |
||||
assert @steve.valid? |
||||
end |
||||
|
||||
test "should allow nil password." do |
||||
@steve.password = @steve.password_confirmation = nil |
||||
assert @steve.valid? |
||||
end |
||||
|
||||
test "password should be longer than 6 characters if it exists." do |
||||
@steve.password = "short" |
||||
assert_not @steve.valid? |
||||
end |
||||
|
||||
test "should create user from omniauth" do |
||||
auth = { |
||||
"uid" => "123456789", |
||||
"provider" => "twitter", |
||||
"info" => { |
||||
"name" => "Test Name", |
||||
"nickname" => "username", |
||||
"email" => "test@example.com" |
||||
} |
||||
} |
||||
|
||||
assert_difference 'User.count' do |
||||
User.from_omniauth(auth) |
||||
end |
||||
|
||||
user = User.find_by(uid: auth["uid"], provider: auth["provider"]) |
||||
|
||||
assert user.username, auth["info"]["nickname"] |
||||
assert user.name, auth["info"]["name"] |
||||
end |
||||
|
||||
test "email addresses should be saved as lower-case." do |
||||
mixed_case = "ExAmPlE@eXaMpLe.CoM" |
||||
@steve.email = mixed_case |
||||
@steve.save |
||||
assert_equal mixed_case.downcase, @steve.email |
||||
end |
||||
|
||||
test "email validation should reject invalid addresses." do |
||||
invalid_addresses = %w[user@example,com user_at_foo.org user.name@example. foo@bar_baz.com foo@bar+baz.com] |
||||
invalid_addresses.each do |invalid_address| |
||||
@steve.email = invalid_address |
||||
assert_not @steve.valid?, "#{invalid_address.inspect} should be invalid." |
||||
end |
||||
end |
||||
|
||||
test "email should be unique." do |
||||
duplicate_user = @steve.dup |
||||
duplicate_user.email = @steve.email.upcase |
||||
@steve.save |
||||
assert_not duplicate_user.valid? |
||||
end |
||||
|
||||
test "name should not be too long." do |
||||
@steve.name = "a" * 25 |
||||
assert_not @steve.valid? |
||||
end |
||||
|
||||
test "email should not be too long." do |
||||
@steve.email = "a" * 50 + "@example.com" |
||||
assert_not @steve.valid? |
||||
end |
||||
|
||||
test "password should have a minimum length." do |
||||
@steve.password = @steve.password_confirmation = "a" * 5 |
||||
assert_not @steve.valid? |
||||
end |
||||
|
||||
test "should authenticate on valid password." do |
||||
assert @steve.authenticate("steve12345") |
||||
end |
||||
|
||||
test "should not authenticate on invalid password." do |
||||
assert_not @steve.authenticate('incorrect') |
||||
end |
||||
|
||||
test "#initialize_room should create room." do |
||||
@steve.send(:initialize_room) |
||||
assert @steve.room |
||||
end |
||||
end |
@ -1,10 +0,0 @@ |
||||
ENV['RAILS_ENV'] ||= 'test' |
||||
require File.expand_path('../../config/environment', __FILE__) |
||||
require 'rails/test_help' |
||||
|
||||
class ActiveSupport::TestCase |
||||
# Setup all fixtures in test/fixtures/*.yml for all tests in alphabetical order. |
||||
fixtures :all |
||||
|
||||
OmniAuth.config.test_mode = true |
||||
end |
Reference in new issue