Commit 5c21771e authored by Alex Kalderimis's avatar Alex Kalderimis

Fix handling of variables in `post_graphql`

parent 8a5d5b40
...@@ -53,16 +53,37 @@ RSpec.describe 'getting an issue list for a project' do ...@@ -53,16 +53,37 @@ RSpec.describe 'getting an issue list for a project' do
context 'when limiting the number of results' do context 'when limiting the number of results' do
let(:query) do let(:query) do
graphql_query_for( <<~GQL
'project', query($path: ID!, $n: Int) {
{ 'fullPath' => project.full_path }, project(fullPath: $path) {
"issues(first: 1) { #{fields} }" issues(first: $n) { #{fields} }
) }
}
GQL
end
let(:issue_limit) { 1 }
let(:variables) do
{ path: project.full_path, n: issue_limit }
end end
it_behaves_like 'a working graphql query' do it_behaves_like 'a working graphql query' do
before do before do
post_graphql(query, current_user: current_user) post_graphql(query, current_user: current_user, variables: variables)
end
it 'only returns N issues' do
expect(issues_data.size).to eq(issue_limit)
end
end
context 'no limit is provided' do
let(:issue_limit) { nil }
it 'returns all issues' do
post_graphql(query, current_user: current_user, variables: variables)
expect(issues_data.size).to be > 1
end end
end end
...@@ -71,7 +92,7 @@ RSpec.describe 'getting an issue list for a project' do ...@@ -71,7 +92,7 @@ RSpec.describe 'getting an issue list for a project' do
# Newest first, we only want to see the newest checked # Newest first, we only want to see the newest checked
expect(Ability).not_to receive(:allowed?).with(current_user, :read_issue, issues.first) expect(Ability).not_to receive(:allowed?).with(current_user, :read_issue, issues.first)
post_graphql(query, current_user: current_user) post_graphql(query, current_user: current_user, variables: variables)
end end
end end
......
...@@ -234,7 +234,8 @@ module GraphqlHelpers ...@@ -234,7 +234,8 @@ module GraphqlHelpers
end end
def post_graphql(query, current_user: nil, variables: nil, headers: {}) def post_graphql(query, current_user: nil, variables: nil, headers: {})
post api('/', current_user, version: 'graphql'), params: { query: query, variables: variables }, headers: headers params = { query: query, variables: variables&.to_json }
post api('/', current_user, version: 'graphql'), params: params, headers: headers
end end
def post_graphql_mutation(mutation, current_user: nil) def post_graphql_mutation(mutation, current_user: nil)
......
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