168 lines
4.1 KiB
Ruby
168 lines
4.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe GroupChildEntity do
|
|
include ExternalAuthorizationServiceHelpers
|
|
include Gitlab::Routing.url_helpers
|
|
|
|
let(:user) { create(:user) }
|
|
let(:request) { double('request') }
|
|
let(:entity) { described_class.new(object, request: request) }
|
|
|
|
subject(:json) { entity.as_json }
|
|
|
|
before do
|
|
allow(request).to receive(:current_user).and_return(user)
|
|
stub_commonmark_sourcepos_disabled
|
|
end
|
|
|
|
shared_examples 'group child json' do
|
|
it 'renders json' do
|
|
is_expected.not_to be_nil
|
|
end
|
|
|
|
%w[id
|
|
full_name
|
|
avatar_url
|
|
name
|
|
description
|
|
markdown_description
|
|
visibility
|
|
type
|
|
can_edit
|
|
visibility
|
|
permission
|
|
relative_path].each do |attribute|
|
|
it "includes #{attribute}" do
|
|
expect(json[attribute.to_sym]).to be_present
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'for a project' do
|
|
let(:object) do
|
|
create(:project, :with_avatar,
|
|
description: 'Awesomeness')
|
|
end
|
|
|
|
before do
|
|
object.add_maintainer(user)
|
|
end
|
|
|
|
it 'has the correct type' do
|
|
expect(json[:type]).to eq('project')
|
|
end
|
|
|
|
it 'includes the star count' do
|
|
expect(json[:star_count]).to be_present
|
|
end
|
|
|
|
it 'has the correct edit path' do
|
|
expect(json[:edit_path]).to eq(edit_project_path(object))
|
|
end
|
|
|
|
it_behaves_like 'group child json'
|
|
end
|
|
|
|
describe 'for a group' do
|
|
let(:description) { 'Awesomeness' }
|
|
let(:object) do
|
|
create(:group, :nested, :with_avatar,
|
|
description: description)
|
|
end
|
|
|
|
before do
|
|
object.add_owner(user)
|
|
end
|
|
|
|
it 'has the correct type' do
|
|
expect(json[:type]).to eq('group')
|
|
end
|
|
|
|
it 'counts projects and subgroups as children' do
|
|
create(:project, namespace: object)
|
|
create(:group, parent: object)
|
|
|
|
expect(json[:children_count]).to eq(2)
|
|
end
|
|
|
|
%w[children_count leave_path parent_id number_users_with_delimiter project_count subgroup_count].each do |attribute|
|
|
it "includes #{attribute}" do
|
|
expect(json[attribute.to_sym]).to be_present
|
|
end
|
|
end
|
|
|
|
it 'allows an owner to leave when there is another one' do
|
|
object.add_owner(create(:user))
|
|
|
|
expect(json[:can_leave]).to be_truthy
|
|
end
|
|
|
|
it 'has the correct edit path' do
|
|
expect(json[:edit_path]).to eq(edit_group_path(object))
|
|
end
|
|
|
|
context 'emoji in description' do
|
|
let(:description) { ':smile:' }
|
|
|
|
it 'has the correct markdown_description' do
|
|
expect(json[:markdown_description]).to eq('<p dir="auto"><gl-emoji title="smiling face with open mouth and smiling eyes" data-name="smile" data-unicode-version="6.0">😄</gl-emoji></p>')
|
|
end
|
|
end
|
|
|
|
it_behaves_like 'group child json'
|
|
end
|
|
|
|
describe 'for a private group' do
|
|
let(:object) do
|
|
create(:group, :private)
|
|
end
|
|
|
|
describe 'user is member of the group' do
|
|
before do
|
|
object.add_owner(user)
|
|
end
|
|
|
|
it 'includes the counts' do
|
|
expect(json.keys).to include(*%i(project_count subgroup_count))
|
|
end
|
|
end
|
|
|
|
describe 'user is not a member of the group' do
|
|
it 'does not include the counts' do
|
|
expect(json.keys).not_to include(*%i(project_count subgroup_count))
|
|
end
|
|
end
|
|
|
|
describe 'user is only a member of a project in the group' do
|
|
let(:project) { create(:project, namespace: object) }
|
|
|
|
before do
|
|
project.add_guest(user)
|
|
end
|
|
|
|
it 'does not include the counts' do
|
|
expect(json.keys).not_to include(*%i(project_count subgroup_count))
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'for a project with external authorization enabled' do
|
|
let(:object) do
|
|
create(:project, :with_avatar,
|
|
description: 'Awesomeness')
|
|
end
|
|
|
|
before do
|
|
enable_external_authorization_service_check
|
|
object.add_maintainer(user)
|
|
end
|
|
|
|
it 'does not hit the external authorization service' do
|
|
expect(::Gitlab::ExternalAuthorization).not_to receive(:access_allowed?)
|
|
|
|
expect(json[:can_edit]).to eq(false)
|
|
end
|
|
end
|
|
end
|