241ba4be79
This is step one of resolving
https://gitlab.com/gitlab-org/gitlab-ce/issues/56838.
Here is what changed:
- Revert the security fix from bdee9e8412
.
- Do not leak repository information (tag name, commit) to guests in API
responses.
- Do not include links to source code in API responses for users that do
not have download_code access.
- Show Releases in sidebar for guests.
- Do not display links to source code under Assets for users that do not
have download_code access.
GET ':id/releases/:tag_name' still do not allow guests to access
releases. This is to prevent guessing tag existence.
67 lines
2 KiB
Ruby
67 lines
2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe Release do
|
|
let(:user) { create(:user) }
|
|
let(:project) { create(:project, :public, :repository) }
|
|
let(:release) { create(:release, project: project, author: user) }
|
|
|
|
it { expect(release).to be_valid }
|
|
|
|
describe 'associations' do
|
|
it { is_expected.to belong_to(:project) }
|
|
it { is_expected.to belong_to(:author).class_name('User') }
|
|
it { is_expected.to have_many(:links).class_name('Releases::Link') }
|
|
end
|
|
|
|
describe 'validation' do
|
|
it { is_expected.to validate_presence_of(:project) }
|
|
it { is_expected.to validate_presence_of(:description) }
|
|
it { is_expected.to validate_presence_of(:name) }
|
|
|
|
context 'when a release exists in the database without a name' do
|
|
it 'does not require name' do
|
|
existing_release_without_name = build(:release, project: project, author: user, name: nil)
|
|
existing_release_without_name.save(validate: false)
|
|
|
|
existing_release_without_name.description = "change"
|
|
existing_release_without_name.save
|
|
existing_release_without_name.reload
|
|
|
|
expect(existing_release_without_name).to be_valid
|
|
expect(existing_release_without_name.description).to eq("change")
|
|
expect(existing_release_without_name.name).to be_nil
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#assets_count' do
|
|
subject { release.assets_count }
|
|
|
|
it 'returns the number of sources' do
|
|
is_expected.to eq(Releases::Source::FORMATS.count)
|
|
end
|
|
|
|
context 'when a links exists' do
|
|
let!(:link) { create(:release_link, release: release) }
|
|
|
|
it 'counts the link as an asset' do
|
|
is_expected.to eq(1 + Releases::Source::FORMATS.count)
|
|
end
|
|
|
|
it "excludes sources count when asked" do
|
|
assets_count = release.assets_count(except: [:sources])
|
|
expect(assets_count).to eq(1)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#sources' do
|
|
subject { release.sources }
|
|
|
|
it 'returns sources' do
|
|
is_expected.to all(be_a(Releases::Source))
|
|
end
|
|
end
|
|
end
|