diff options
Diffstat (limited to 'spec/graphql/resolvers/releases_resolver_spec.rb')
-rw-r--r-- | spec/graphql/resolvers/releases_resolver_spec.rb | 49 |
1 files changed, 45 insertions, 4 deletions
diff --git a/spec/graphql/resolvers/releases_resolver_spec.rb b/spec/graphql/resolvers/releases_resolver_spec.rb index ee8b33fc748..b9b90686aa7 100644 --- a/spec/graphql/resolvers/releases_resolver_spec.rb +++ b/spec/graphql/resolvers/releases_resolver_spec.rb @@ -5,12 +5,19 @@ require 'spec_helper' RSpec.describe Resolvers::ReleasesResolver do include GraphqlHelpers + 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, :private) } - let_it_be(:release_v1) { create(:release, project: project, tag: 'v1.0.0') } - let_it_be(:release_v2) { create(:release, project: project, tag: 'v2.0.0') } + let_it_be(:release_v1) { create(:release, project: project, tag: 'v1.0.0', released_at: yesterday, created_at: tomorrow) } + let_it_be(:release_v2) { create(:release, project: project, tag: 'v2.0.0', released_at: today, created_at: yesterday) } + let_it_be(:release_v3) { create(:release, project: project, tag: 'v3.0.0', released_at: tomorrow, created_at: today) } let_it_be(:developer) { create(:user) } let_it_be(:public_user) { create(:user) } + let(:args) { { sort: :released_at_desc } } + before do project.add_developer(developer) end @@ -28,7 +35,41 @@ RSpec.describe Resolvers::ReleasesResolver do let(:current_user) { developer } it 'returns all releases associated to the project' do - expect(resolve_releases).to eq([release_v1, release_v2]) + expect(resolve_releases).to eq([release_v3, release_v2, release_v1]) + end + + describe 'sorting behavior' do + context 'with sort: :released_at_desc' do + let(:args) { { sort: :released_at_desc } } + + it 'returns the releases ordered by released_at in descending order' do + expect(resolve_releases).to eq([release_v3, release_v2, release_v1]) + end + end + + context 'with sort: :released_at_asc' do + let(:args) { { sort: :released_at_asc } } + + it 'returns the releases ordered by released_at in ascending order' do + expect(resolve_releases).to eq([release_v1, release_v2, release_v3]) + end + end + + context 'with sort: :created_desc' do + let(:args) { { sort: :created_desc } } + + it 'returns the releases ordered by created_at in descending order' do + expect(resolve_releases).to eq([release_v1, release_v3, release_v2]) + end + end + + context 'with sort: :created_asc' do + let(:args) { { sort: :created_asc } } + + it 'returns the releases ordered by created_at in ascending order' do + expect(resolve_releases).to eq([release_v2, release_v3, release_v1]) + end + end end end end @@ -37,6 +78,6 @@ RSpec.describe Resolvers::ReleasesResolver do def resolve_releases context = { current_user: current_user } - resolve(described_class, obj: project, args: {}, ctx: context) + resolve(described_class, obj: project, args: args, ctx: context) end end |