discourse/spec/requests/badges_controller_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

97 lines
2.9 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require 'rails_helper'
describe BadgesController do
fab!(:badge) { Fabricate(:badge) }
fab!(:user) { Fabricate(:user) }
before do
SiteSetting.enable_badges = true
end
context 'index' do
it 'should return a list of all badges' do
get "/badges.json"
2015-01-09 12:04:02 -05:00
expect(response.status).to eq(200)
parsed = response.parsed_body
expect(parsed["badges"].length).to eq(Badge.enabled.count)
expect(response.headers['X-Robots-Tag']).to eq('noindex')
end
end
2014-04-16 10:56:11 -04:00
context 'show' do
it "should return a badge" do
get "/badges/#{badge.id}.json"
2015-01-09 12:04:02 -05:00
expect(response.status).to eq(200)
parsed = response.parsed_body
2015-01-09 12:04:02 -05:00
expect(parsed["badge"]).to be_present
2014-04-16 10:56:11 -04:00
end
it "should mark the notification as viewed" do
sign_in(user)
user_badge = BadgeGranter.grant(badge, user)
2015-01-09 12:04:02 -05:00
expect(user_badge.notification.read).to eq(false)
get "/badges/#{badge.id}.json"
2015-01-09 12:04:02 -05:00
expect(user_badge.notification.reload.read).to eq(true)
end
2017-08-08 16:21:42 -04:00
it 'renders rss feed of a badge' do
get "/badges/#{badge.id}.rss"
2017-08-08 16:21:42 -04:00
expect(response.status).to eq(200)
expect(response.media_type).to eq('application/rss+xml')
2017-08-08 16:21:42 -04:00
end
2014-04-16 10:56:11 -04:00
end
context "user profiles" do
let(:titled_badge) { Fabricate(:badge, name: 'Protector of the Realm', allow_title: true) }
let!(:grant) { UserBadge.create!(user_id: user.id, badge_id: titled_badge.id, granted_at: 1.minute.ago, granted_by_id: -1) }
it "can be assigned as a title by the user" do
sign_in(user)
put "/u/#{user.username}/preferences/badge_title.json", params: {
user_badge_id: grant.id,
}
expect(response.status).to eq(200)
user.reload
expect(user.title).to eq(titled_badge.display_name)
expect(user.user_profile.granted_title_badge_id).to eq(titled_badge.id)
end
end
describe "destroy" do
let(:admin) { Fabricate(:admin) }
context "while assigned as a title" do
let(:titled_badge) { Fabricate(:badge, name: 'Protector of the Realm', allow_title: true) }
let!(:grant) { UserBadge.create!(user_id: user.id, badge_id: titled_badge.id, granted_at: 1.minute.ago, granted_by_id: -1) }
before do
sign_in(user)
put "/u/#{user.username}/preferences/badge_title.json", params: {
user_badge_id: grant.id,
}
user.reload
sign_out
end
it "succeeds and unassigns the title from the user" do
expect(user.title).to eq(titled_badge.display_name)
sign_in(admin)
badge_id = titled_badge.id
delete "/admin/badges/#{titled_badge.id}.json"
expect(response.status).to be(200)
expect(Badge.find_by(id: badge_id)).to be(nil)
user.reload
expect(user.title).to_not eq(titled_badge.display_name)
expect(user.user_profile.granted_title_badge_id).to eq(nil)
end
end
end
end