2019-04-30 08:27:42 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2015-10-11 17:41:23 +08:00
|
|
|
require 'rails_helper'
|
2014-03-05 20:52:20 +08:00
|
|
|
|
|
|
|
describe Admin::BadgesController do
|
|
|
|
context "while logged in as an admin" do
|
2019-05-07 11:12:20 +08:00
|
|
|
fab!(:admin) { Fabricate(:admin) }
|
|
|
|
fab!(:badge) { Fabricate(:badge) }
|
2014-03-05 20:52:20 +08:00
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
before do
|
|
|
|
sign_in(admin)
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#index' do
|
2014-07-30 06:35:15 +08:00
|
|
|
it 'returns badge index' do
|
2018-06-11 12:50:56 +08:00
|
|
|
get "/admin/badges.json"
|
2018-06-07 16:11:09 +08:00
|
|
|
expect(response.status).to eq(200)
|
2014-07-30 06:35:15 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
describe '#preview' do
|
2016-07-28 07:03:00 +08:00
|
|
|
it 'allows preview enable_badge_sql is enabled' do
|
|
|
|
SiteSetting.enable_badge_sql = true
|
2017-08-31 12:06:56 +08:00
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
post "/admin/badges/preview.json", params: {
|
2017-08-31 12:06:56 +08:00
|
|
|
sql: 'select id as user_id, created_at granted_at from users'
|
2018-06-11 12:50:56 +08:00
|
|
|
}
|
2017-08-31 12:06:56 +08:00
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
expect(response.status).to eq(200)
|
2020-05-07 23:04:12 +08:00
|
|
|
expect(response.parsed_body["grant_count"]).to be > 0
|
2016-07-28 07:03:00 +08:00
|
|
|
end
|
2018-06-11 12:50:56 +08:00
|
|
|
|
2016-07-28 07:03:00 +08:00
|
|
|
it 'does not allow anything if enable_badge_sql is disabled' do
|
|
|
|
SiteSetting.enable_badge_sql = false
|
2017-08-31 12:06:56 +08:00
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
post "/admin/badges/preview.json", params: {
|
2017-08-31 12:06:56 +08:00
|
|
|
sql: 'select id as user_id, created_at granted_at from users'
|
2018-06-11 12:50:56 +08:00
|
|
|
}
|
2017-08-31 12:06:56 +08:00
|
|
|
|
|
|
|
expect(response.status).to eq(403)
|
2016-07-28 07:03:00 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
describe '#create' do
|
2017-05-09 21:25:57 +08:00
|
|
|
it 'can create badges correctly' do
|
|
|
|
SiteSetting.enable_badge_sql = true
|
2017-08-31 12:06:56 +08:00
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
post "/admin/badges.json", params: {
|
2017-08-31 12:06:56 +08:00
|
|
|
name: 'test', query: 'select 1 as user_id, null as granted_at', badge_type_id: 1
|
2018-06-11 12:50:56 +08:00
|
|
|
}
|
2017-08-31 12:06:56 +08:00
|
|
|
|
2020-05-07 23:04:12 +08:00
|
|
|
json = response.parsed_body
|
2017-08-31 12:06:56 +08:00
|
|
|
expect(response.status).to eq(200)
|
2017-05-09 21:25:57 +08:00
|
|
|
expect(json["badge"]["name"]).to eq('test')
|
|
|
|
expect(json["badge"]["query"]).to eq('select 1 as user_id, null as granted_at')
|
2018-05-18 00:09:27 +08:00
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
expect(UserHistory.where(acting_user_id: admin.id, action: UserHistory.actions[:create_badge]).exists?).to eq(true)
|
2017-05-09 21:25:57 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
describe '#save_badge_groupings' do
|
2014-07-27 16:22:01 +08:00
|
|
|
it 'can save badge groupings' do
|
|
|
|
groupings = BadgeGrouping.all.order(:position).to_a
|
|
|
|
groupings << BadgeGrouping.new(name: 'Test 1')
|
|
|
|
groupings << BadgeGrouping.new(name: 'Test 2')
|
|
|
|
|
|
|
|
groupings.shuffle!
|
|
|
|
|
|
|
|
names = groupings.map { |g| g.name }
|
|
|
|
ids = groupings.map { |g| g.id.to_s }
|
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
post "/admin/badges/badge_groupings.json", params: { ids: ids, names: names }
|
|
|
|
expect(response.status).to eq(200)
|
2014-07-27 16:22:01 +08:00
|
|
|
|
|
|
|
groupings2 = BadgeGrouping.all.order(:position).to_a
|
|
|
|
|
2015-01-10 01:04:02 +08:00
|
|
|
expect(groupings2.map { |g| g.name }).to eq(names)
|
|
|
|
expect((groupings.map(&:id) - groupings2.map { |g| g.id }).compact).to be_blank
|
2020-05-07 23:04:12 +08:00
|
|
|
expect(response.parsed_body["badge_groupings"].length).to eq(groupings2.length)
|
2014-07-27 16:22:01 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
describe '#badge_types' do
|
2014-03-05 20:52:20 +08:00
|
|
|
it 'returns JSON' do
|
2018-06-11 12:50:56 +08:00
|
|
|
get "/admin/badges/types.json"
|
2017-08-31 12:06:56 +08:00
|
|
|
|
2018-06-07 16:11:09 +08:00
|
|
|
expect(response.status).to eq(200)
|
2020-05-07 23:04:12 +08:00
|
|
|
expect(response.parsed_body["badge_types"]).to be_present
|
2014-03-05 20:52:20 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
describe '#destroy' do
|
2014-03-05 20:52:20 +08:00
|
|
|
it 'deletes the badge' do
|
2018-06-11 12:50:56 +08:00
|
|
|
delete "/admin/badges/#{badge.id}.json"
|
2018-06-07 16:11:09 +08:00
|
|
|
expect(response.status).to eq(200)
|
2018-05-18 00:09:27 +08:00
|
|
|
expect(Badge.where(id: badge.id).exists?).to eq(false)
|
2018-06-11 12:50:56 +08:00
|
|
|
expect(UserHistory.where(acting_user_id: admin.id, action: UserHistory.actions[:delete_badge]).exists?).to eq(true)
|
2014-03-05 20:52:20 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
describe '#update' do
|
2017-02-20 21:35:05 +08:00
|
|
|
it 'does not update the name of system badges' do
|
|
|
|
editor_badge = Badge.find(Badge::Editor)
|
|
|
|
editor_badge_name = editor_badge.name
|
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
put "/admin/badges/#{editor_badge.id}.json", params: {
|
2017-08-31 12:06:56 +08:00
|
|
|
name: "123456"
|
2018-06-11 12:50:56 +08:00
|
|
|
}
|
2017-02-20 21:35:05 +08:00
|
|
|
|
2018-06-07 16:11:09 +08:00
|
|
|
expect(response.status).to eq(200)
|
2017-02-20 21:35:05 +08:00
|
|
|
editor_badge.reload
|
|
|
|
expect(editor_badge.name).to eq(editor_badge_name)
|
2018-05-18 00:09:27 +08:00
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
expect(UserHistory.where(acting_user_id: admin.id, action: UserHistory.actions[:change_badge]).exists?).to eq(true)
|
2017-02-20 21:35:05 +08:00
|
|
|
end
|
|
|
|
|
2016-07-28 07:03:00 +08:00
|
|
|
it 'does not allow query updates if badge_sql is disabled' do
|
|
|
|
badge.query = "select 123"
|
|
|
|
badge.save
|
|
|
|
|
|
|
|
SiteSetting.enable_badge_sql = false
|
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
put "/admin/badges/#{badge.id}.json", params: {
|
2017-08-31 12:06:56 +08:00
|
|
|
name: "123456",
|
|
|
|
query: "select id user_id, created_at granted_at from users",
|
|
|
|
badge_type_id: badge.badge_type_id,
|
|
|
|
allow_title: false,
|
|
|
|
multiple_grant: false,
|
|
|
|
enabled: true
|
2018-06-11 12:50:56 +08:00
|
|
|
}
|
2016-07-28 07:03:00 +08:00
|
|
|
|
2018-06-07 16:11:09 +08:00
|
|
|
expect(response.status).to eq(200)
|
2016-07-28 07:03:00 +08:00
|
|
|
badge.reload
|
|
|
|
expect(badge.name).to eq('123456')
|
|
|
|
expect(badge.query).to eq('select 123')
|
2014-03-05 20:52:20 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'updates the badge' do
|
2016-07-28 07:03:00 +08:00
|
|
|
SiteSetting.enable_badge_sql = true
|
|
|
|
sql = "select id user_id, created_at granted_at from users"
|
2021-03-17 13:55:23 +08:00
|
|
|
image = Fabricate(:upload)
|
2016-07-28 07:03:00 +08:00
|
|
|
|
2018-06-11 12:50:56 +08:00
|
|
|
put "/admin/badges/#{badge.id}.json", params: {
|
2017-08-31 12:06:56 +08:00
|
|
|
name: "123456",
|
|
|
|
query: sql,
|
|
|
|
badge_type_id: badge.badge_type_id,
|
|
|
|
allow_title: false,
|
|
|
|
multiple_grant: false,
|
2021-03-17 13:55:23 +08:00
|
|
|
enabled: true,
|
|
|
|
image_upload_id: image.id,
|
|
|
|
icon: "fa-rocket",
|
2018-06-11 12:50:56 +08:00
|
|
|
}
|
2016-07-28 07:03:00 +08:00
|
|
|
|
2018-06-07 16:11:09 +08:00
|
|
|
expect(response.status).to eq(200)
|
2016-07-28 07:03:00 +08:00
|
|
|
badge.reload
|
|
|
|
expect(badge.name).to eq('123456')
|
|
|
|
expect(badge.query).to eq(sql)
|
2021-03-17 13:55:23 +08:00
|
|
|
expect(badge.image_upload.id).to eq(image.id)
|
|
|
|
expect(badge.icon).to eq("fa-rocket")
|
2014-03-05 20:52:20 +08:00
|
|
|
end
|
2019-11-08 13:34:24 +08:00
|
|
|
|
|
|
|
context 'when there is a user with a title granted using the badge' do
|
|
|
|
fab!(:user_with_badge_title) { Fabricate(:active_user) }
|
|
|
|
fab!(:badge) { Fabricate(:badge, name: 'Oathbreaker', allow_title: true) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
BadgeGranter.grant(badge, user_with_badge_title)
|
|
|
|
user_with_badge_title.update(title: 'Oathbreaker')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'updates the user title in a job' do
|
2020-07-24 17:16:52 +08:00
|
|
|
expect_enqueued_with(job: :bulk_user_title_update, args: {
|
2019-11-08 13:34:24 +08:00
|
|
|
new_title: 'Shieldbearer',
|
|
|
|
granted_badge_id: badge.id,
|
|
|
|
action: Jobs::BulkUserTitleUpdate::UPDATE_ACTION
|
2020-07-24 17:16:52 +08:00
|
|
|
}) do
|
|
|
|
put "/admin/badges/#{badge.id}.json", params: {
|
|
|
|
name: "Shieldbearer"
|
|
|
|
}
|
|
|
|
end
|
2019-11-08 13:34:24 +08:00
|
|
|
end
|
|
|
|
end
|
2014-03-05 20:52:20 +08:00
|
|
|
end
|
2020-01-13 22:20:26 +08:00
|
|
|
|
|
|
|
describe '#mass_award' do
|
2020-02-27 22:07:46 +08:00
|
|
|
before { @user = Fabricate(:user, email: 'user1@test.com', username: 'username1') }
|
|
|
|
|
2020-01-13 22:20:26 +08:00
|
|
|
it 'does nothing when there is no file' do
|
|
|
|
post "/admin/badges/award/#{badge.id}.json", params: { file: '' }
|
|
|
|
|
|
|
|
expect(response.status).to eq(400)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does nothing when the badge id is not valid' do
|
|
|
|
post '/admin/badges/award/fake_id.json', params: { file: fixture_file_upload(Tempfile.new) }
|
|
|
|
|
|
|
|
expect(response.status).to eq(400)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does nothing when the file is not a csv' do
|
|
|
|
file = file_from_fixtures('cropped.png')
|
|
|
|
|
|
|
|
post "/admin/badges/award/#{badge.id}.json", params: { file: fixture_file_upload(file) }
|
|
|
|
|
|
|
|
expect(response.status).to eq(400)
|
|
|
|
end
|
|
|
|
|
2020-02-18 21:53:12 +08:00
|
|
|
it 'awards the badge using a list of user emails' do
|
2020-01-13 22:20:26 +08:00
|
|
|
Jobs.run_immediately!
|
|
|
|
|
|
|
|
file = file_from_fixtures('user_emails.csv', 'csv')
|
|
|
|
|
|
|
|
post "/admin/badges/award/#{badge.id}.json", params: { file: fixture_file_upload(file) }
|
|
|
|
|
2020-02-27 22:07:46 +08:00
|
|
|
expect(UserBadge.exists?(user: @user, badge: badge)).to eq(true)
|
2020-01-13 22:20:26 +08:00
|
|
|
end
|
2020-02-18 21:53:12 +08:00
|
|
|
|
|
|
|
it 'awards the badge using a list of usernames' do
|
|
|
|
Jobs.run_immediately!
|
|
|
|
|
|
|
|
file = file_from_fixtures('usernames.csv', 'csv')
|
|
|
|
|
|
|
|
post "/admin/badges/award/#{badge.id}.json", params: { file: fixture_file_upload(file) }
|
|
|
|
|
2020-02-27 22:07:46 +08:00
|
|
|
expect(UserBadge.exists?(user: @user, badge: badge)).to eq(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'works with a CSV containing nil values' do
|
|
|
|
Jobs.run_immediately!
|
|
|
|
|
|
|
|
file = file_from_fixtures('usernames_with_nil_values.csv', 'csv')
|
|
|
|
|
|
|
|
post "/admin/badges/award/#{badge.id}.json", params: { file: fixture_file_upload(file) }
|
|
|
|
|
|
|
|
expect(UserBadge.exists?(user: @user, badge: badge)).to eq(true)
|
2020-02-18 21:53:12 +08:00
|
|
|
end
|
2021-03-13 01:28:27 +08:00
|
|
|
|
|
|
|
it 'fails when the badge is disabled' do
|
|
|
|
badge.update!(enabled: false)
|
|
|
|
|
|
|
|
file = file_from_fixtures('usernames_with_nil_values.csv', 'csv')
|
|
|
|
|
|
|
|
post "/admin/badges/award/#{badge.id}.json", params: { file: fixture_file_upload(file) }
|
|
|
|
|
|
|
|
expect(response.status).to eq(422)
|
|
|
|
end
|
2020-01-13 22:20:26 +08:00
|
|
|
end
|
2014-03-05 20:52:20 +08:00
|
|
|
end
|
|
|
|
end
|