Commit a39ccf33 authored by Clement Ho's avatar Clement Ho

Merge branch 'license_badge_for_gitlab_com' into 'master'

Show license badge for Gitlab.com member overview

See merge request gitlab-org/gitlab!23521
parents f5d0c7c5 563e95e3
...@@ -22,6 +22,8 @@ ...@@ -22,6 +22,8 @@
- if user == current_user - if user == current_user
%span.badge.badge-success.prepend-left-5= _("It's you") %span.badge.badge-success.prepend-left-5= _("It's you")
= render_if_exists 'shared/members/ee/license_badge', user: user, group: @group
- if user.blocked? - if user.blocked?
%label.badge.badge-danger %label.badge.badge-danger
%strong= _("Blocked") %strong= _("Blocked")
......
...@@ -284,6 +284,18 @@ module EE ...@@ -284,6 +284,18 @@ module EE
end end
end end
def using_gitlab_com_seat?(namespace)
return false unless ::Gitlab.com?
return false unless namespace.present?
return false if namespace.free_plan?
if namespace.gold_plan?
highest_role > ::Gitlab::Access::GUEST
else
true
end
end
def group_sso?(group) def group_sso?(group)
return false unless group return false unless group
......
- if group.present? && group.has_owner?(current_user) && user.using_gitlab_com_seat?(group)
%span.badge.badge-light= _("Is using seat")
---
title: Show license badge for Gitlab.com member overview
merge_request: 23521
author:
type: added
...@@ -682,6 +682,76 @@ describe User do ...@@ -682,6 +682,76 @@ describe User do
end end
end end
describe '#using_gitlab_com_seat?' do
let(:user) { create(:user) }
context 'when Gitlab.com? is false' do
before do
allow(Gitlab).to receive(:com?).and_return(false)
end
it 'returns false' do
expect(user.using_gitlab_com_seat?(nil)).to eq(false)
end
end
context 'when Gitlab.com? is true' do
let(:namespace) { create(:namespace) }
before do
allow(Gitlab).to receive(:com?).and_return(true)
allow(namespace).to receive(:gold_plan?).and_return(false)
allow(namespace).to receive(:free_plan?).and_return(false)
end
context 'when namespace is nil' do
let(:namespace) { nil }
it 'returns false' do
expect(user.using_gitlab_com_seat?(namespace)).to eq(false)
end
end
context 'when namespace is on a free plan' do
before do
allow(namespace).to receive(:free_plan?).and_return(true)
end
it 'returns false' do
expect(user.using_gitlab_com_seat?(namespace)).to eq(false)
end
end
context 'when namespace is on a gold plan' do
before do
allow(namespace).to receive(:gold_plan?).and_return(true)
end
context 'user is not a guest' do
let(:user) { create(:project_member, :developer).user }
it 'returns true' do
expect(user.using_gitlab_com_seat?(namespace)).to eq(true)
end
end
context 'user is guest' do
let(:user) { create(:project_member, :guest).user }
it 'returns false' do
expect(user.using_gitlab_com_seat?(namespace)).to eq(false)
end
end
end
context 'when namespace is on a plan that is not free or gold' do
it 'returns true' do
expect(user.using_gitlab_com_seat?(namespace)).to eq(true)
end
end
end
end
describe '.username_suggestion' do describe '.username_suggestion' do
context 'namespace with input name does not exist' do context 'namespace with input name does not exist' do
let(:name) { 'Arthur Morgan' } let(:name) { 'Arthur Morgan' }
......
...@@ -10419,6 +10419,9 @@ msgstr "" ...@@ -10419,6 +10419,9 @@ msgstr ""
msgid "Is using license seat:" msgid "Is using license seat:"
msgstr "" msgstr ""
msgid "Is using seat"
msgstr ""
msgid "IssuableStatus|Closed" msgid "IssuableStatus|Closed"
msgstr "" msgstr ""
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment