debian-mirror-gitlab/spec/models/group_spec.rb

107 lines
2.9 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
# == Schema Information
#
# Table name: namespaces
#
# id :integer not null, primary key
# name :string(255) not null
# path :string(255) not null
# owner_id :integer
# created_at :datetime
# updated_at :datetime
# type :string(255)
# description :string(255) default(""), not null
# avatar :string(255)
#
require 'spec_helper'
2015-12-23 02:04:40 +05:30
describe Group, models: true do
2014-09-02 18:07:02 +05:30
let!(:group) { create(:group) }
2015-09-11 14:41:01 +05:30
describe 'associations' do
2015-04-26 12:48:37 +05:30
it { is_expected.to have_many :projects }
it { is_expected.to have_many :group_members }
2014-09-02 18:07:02 +05:30
end
2015-09-11 14:41:01 +05:30
describe 'modules' do
subject { described_class }
it { is_expected.to include_module(Referable) }
end
describe 'validations' do
it { is_expected.to validate_presence_of :name }
it { is_expected.to validate_uniqueness_of(:name) }
it { is_expected.to validate_presence_of :path }
it { is_expected.to validate_uniqueness_of(:path) }
it { is_expected.not_to validate_presence_of :owner }
end
2015-11-26 14:37:03 +05:30
describe '.visible_to_user' do
let!(:group) { create(:group) }
let!(:user) { create(:user) }
subject { described_class.visible_to_user(user) }
describe 'when the user has access to a group' do
before do
group.add_user(user, Gitlab::Access::MASTER)
end
it { is_expected.to eq([group]) }
end
describe 'when the user does not have access to any groups' do
it { is_expected.to eq([]) }
end
end
2015-09-11 14:41:01 +05:30
describe '#to_reference' do
it 'returns a String reference to the object' do
expect(group.to_reference).to eq "@#{group.name}"
end
end
2014-09-02 18:07:02 +05:30
describe :users do
2015-04-26 12:48:37 +05:30
it { expect(group.users).to eq(group.owners) }
2014-09-02 18:07:02 +05:30
end
describe :human_name do
2015-04-26 12:48:37 +05:30
it { expect(group.human_name).to eq(group.name) }
2014-09-02 18:07:02 +05:30
end
describe :add_users do
let(:user) { create(:user) }
2015-04-26 12:48:37 +05:30
before { group.add_user(user, GroupMember::MASTER) }
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
it { expect(group.group_members.masters.map(&:user)).to include(user) }
2014-09-02 18:07:02 +05:30
end
describe :add_users do
let(:user) { create(:user) }
2015-04-26 12:48:37 +05:30
before { group.add_users([user.id], GroupMember::GUEST) }
2014-09-02 18:07:02 +05:30
it "should update the group permission" do
2015-04-26 12:48:37 +05:30
expect(group.group_members.guests.map(&:user)).to include(user)
group.add_users([user.id], GroupMember::DEVELOPER)
expect(group.group_members.developers.map(&:user)).to include(user)
expect(group.group_members.guests.map(&:user)).not_to include(user)
2014-09-02 18:07:02 +05:30
end
end
describe :avatar_type do
let(:user) { create(:user) }
2015-04-26 12:48:37 +05:30
before { group.add_user(user, GroupMember::MASTER) }
2014-09-02 18:07:02 +05:30
it "should be true if avatar is image" do
group.update_attribute(:avatar, 'uploads/avatar.png')
2015-04-26 12:48:37 +05:30
expect(group.avatar_type).to be_truthy
2014-09-02 18:07:02 +05:30
end
it "should be false if avatar is html page" do
group.update_attribute(:avatar, 'uploads/avatar.html')
2015-04-26 12:48:37 +05:30
expect(group.avatar_type).to eq(["only images allowed"])
2014-09-02 18:07:02 +05:30
end
end
end