Commit 36f01a2d authored by jakeburden's avatar jakeburden

Add rspec tests for sorting the releases view

parent c447823a
...@@ -47,6 +47,7 @@ export default { ...@@ -47,6 +47,7 @@ export default {
<gl-sorting <gl-sorting
:text="sortText" :text="sortText"
:is-ascending="isSortAscending" :is-ascending="isSortAscending"
data-testid="releases-sort"
@sortDirectionChange="onDirectionChange" @sortDirectionChange="onDirectionChange"
> >
<gl-sorting-item <gl-sorting-item
......
...@@ -3,8 +3,14 @@ ...@@ -3,8 +3,14 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe 'User views releases', :js do RSpec.describe 'User views releases', :js do
let_it_be(:today) { Time.now }
let_it_be(:yesterday) { today - 1.day }
let_it_be(:tomorrow) { today + 1.day }
let_it_be(:project) { create(:project, :repository, :private) } let_it_be(:project) { create(:project, :repository, :private) }
let_it_be(:release) { create(:release, project: project, name: 'The first release' ) } let_it_be(:release_v1) { create(:release, project: project, tag: 'v1', name: 'The first release', released_at: yesterday, created_at: today) }
let_it_be(:release_v2) { create(:release, project: project, tag: 'v2-with-a/slash', name: 'The second release', released_at: today, created_at: yesterday) }
let_it_be(:release_v3) { create(:release, project: project, tag: 'v3', name: 'The third release', released_at: tomorrow, created_at: tomorrow) }
let_it_be(:maintainer) { create(:user) } let_it_be(:maintainer) { create(:user) }
let_it_be(:guest) { create(:user) } let_it_be(:guest) { create(:user) }
...@@ -17,38 +23,36 @@ RSpec.describe 'User views releases', :js do ...@@ -17,38 +23,36 @@ RSpec.describe 'User views releases', :js do
context('when the user is a maintainer') do context('when the user is a maintainer') do
before do before do
sign_in(maintainer) sign_in(maintainer)
end
it 'sees the release' do
visit project_releases_path(project) visit project_releases_path(project)
end
expect(page).to have_content(release.name) it 'sees the release' do
expect(page).to have_content(release.tag) page.within("##{release_v1.tag}") do
expect(page).not_to have_content('Upcoming Release') expect(page).to have_content(release_v1.name)
expect(page).to have_content(release_v1.tag)
expect(page).not_to have_content('Upcoming Release')
end
end end
context 'when there is a link as an asset' do context 'when there is a link as an asset' do
let!(:release_link) { create(:release_link, release: release, url: url ) } let!(:release_link) { create(:release_link, release: release_v1, url: url ) }
let(:url) { "#{project.web_url}/-/jobs/1/artifacts/download" } let(:url) { "#{project.web_url}/-/jobs/1/artifacts/download" }
let(:direct_asset_link) { Gitlab::Routing.url_helpers.project_release_url(project, release) << release_link.filepath } let(:direct_asset_link) { Gitlab::Routing.url_helpers.project_release_url(project, release_v1) << release_link.filepath }
it 'sees the link' do it 'sees the link' do
visit project_releases_path(project) page.within("##{release_v1.tag} .js-assets-list") do
page.within('.js-assets-list') do
expect(page).to have_link release_link.name, href: direct_asset_link expect(page).to have_link release_link.name, href: direct_asset_link
expect(page).not_to have_css('[data-testid="external-link-indicator"]') expect(page).not_to have_css('[data-testid="external-link-indicator"]')
end end
end end
context 'when there is a link redirect' do context 'when there is a link redirect' do
let!(:release_link) { create(:release_link, release: release, name: 'linux-amd64 binaries', filepath: '/binaries/linux-amd64', url: url) } let!(:release_link) { create(:release_link, release: release_v1, name: 'linux-amd64 binaries', filepath: '/binaries/linux-amd64', url: url) }
let(:url) { "#{project.web_url}/-/jobs/1/artifacts/download" } let(:url) { "#{project.web_url}/-/jobs/1/artifacts/download" }
it 'sees the link' do it 'sees the link' do
visit project_releases_path(project) page.within("##{release_v1.tag} .js-assets-list") do
page.within('.js-assets-list') do
expect(page).to have_link release_link.name, href: direct_asset_link expect(page).to have_link release_link.name, href: direct_asset_link
expect(page).not_to have_css('[data-testid="external-link-indicator"]') expect(page).not_to have_css('[data-testid="external-link-indicator"]')
end end
...@@ -59,9 +63,7 @@ RSpec.describe 'User views releases', :js do ...@@ -59,9 +63,7 @@ RSpec.describe 'User views releases', :js do
let(:url) { 'http://google.com/download' } let(:url) { 'http://google.com/download' }
it 'sees that the link is external resource' do it 'sees that the link is external resource' do
visit project_releases_path(project) page.within("##{release_v1.tag} .js-assets-list") do
page.within('.js-assets-list') do
expect(page).to have_css('[data-testid="external-link-indicator"]') expect(page).to have_css('[data-testid="external-link-indicator"]')
end end
end end
...@@ -69,23 +71,57 @@ RSpec.describe 'User views releases', :js do ...@@ -69,23 +71,57 @@ RSpec.describe 'User views releases', :js do
end end
context 'with an upcoming release' do context 'with an upcoming release' do
let(:tomorrow) { Time.zone.now + 1.day }
let!(:release) { create(:release, project: project, released_at: tomorrow ) }
it 'sees the upcoming tag' do it 'sees the upcoming tag' do
visit project_releases_path(project) page.within("##{release_v3.tag}") do
expect(page).to have_content('Upcoming Release')
expect(page).to have_content('Upcoming Release') end
end end
end end
context 'with a tag containing a slash' do context 'with a tag containing a slash' do
it 'sees the release' do it 'sees the release' do
release = create :release, project: project, tag: 'debian/2.4.0-1' page.within("##{release_v2.tag.parameterize}") do
visit project_releases_path(project) expect(page).to have_content(release_v2.name)
expect(page).to have_content(release_v2.tag)
end
end
end
context 'sorting' do
def sort_page(by:, direction:)
within '[data-testid="releases-sort"]' do
find('.dropdown-toggle').click
click_button(by, class: 'dropdown-item')
find('.sorting-direction-button').click if direction == :ascending
end
end
shared_examples 'releases sort order' do
it "sorts the releases #{description}" do
card_titles = page.all('.release-block .card-title', minimum: expected_order.count)
card_titles.each_with_index do |title, index|
expect(title).to have_content(expected_order[index].name)
end
end
end
context "when the page is sorted by the default sort order" do
let(:expected_order) { [release_v3, release_v2, release_v1] }
it_behaves_like 'releases sort order'
end
context "when the page is sorted by created_at ascending " do
let(:expected_order) { [release_v2, release_v1, release_v3] }
before do
sort_page by: 'Created date', direction: :ascending
end
expect(page).to have_content(release.name) it_behaves_like 'releases sort order'
expect(page).to have_content(release.tag)
end end
end end
end end
...@@ -98,14 +134,14 @@ RSpec.describe 'User views releases', :js do ...@@ -98,14 +134,14 @@ RSpec.describe 'User views releases', :js do
it 'renders release info except for Git-related data' do it 'renders release info except for Git-related data' do
visit project_releases_path(project) visit project_releases_path(project)
within('.release-block') do within('.release-block', match: :first) do
expect(page).to have_content(release.description) expect(page).to have_content(release_v3.description)
# The following properties (sometimes) include Git info, # The following properties (sometimes) include Git info,
# so they are not rendered for Guest users # so they are not rendered for Guest users
expect(page).not_to have_content(release.name) expect(page).not_to have_content(release_v3.name)
expect(page).not_to have_content(release.tag) expect(page).not_to have_content(release_v3.tag)
expect(page).not_to have_content(release.commit.short_id) expect(page).not_to have_content(release_v3.commit.short_id)
end end
end end
end end
......
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