Commit d23a7197 authored by Alex Kalderimis's avatar Alex Kalderimis

Add MergeRequest.diffStatsSummary.fileCount to graphql API

This allows the number of files changed in a MR to be counted, using
queries such as:

```graphql
query {
  project(fullPath: "group/project") {
    mergeRequest(iid: "1") {
      diffStatsSummary { fileCount }
    }
  }
}
```
parent 9d4f0de8
...@@ -14,6 +14,8 @@ module Types ...@@ -14,6 +14,8 @@ module Types
description: 'Number of lines deleted' description: 'Number of lines deleted'
field :changes, GraphQL::INT_TYPE, null: false, field :changes, GraphQL::INT_TYPE, null: false,
description: 'Number of lines changed' description: 'Number of lines changed'
field :file_count, GraphQL::INT_TYPE, null: false,
description: 'Number of files changed'
def changes def changes
object[:additions] + object[:deletions] object[:additions] + object[:deletions]
......
...@@ -153,11 +153,11 @@ module Types ...@@ -153,11 +153,11 @@ module Types
end end
def diff_stats_summary def diff_stats_summary
nil_stats = { additions: 0, deletions: 0 } nil_stats = { additions: 0, deletions: 0, file_count: 0 }
return nil_stats unless object.diff_stats.present? return nil_stats unless object.diff_stats.present?
object.diff_stats.each_with_object(nil_stats) do |status, hash| object.diff_stats.each_with_object(nil_stats) do |status, hash|
hash.merge!(additions: status.additions, deletions: status.deletions) { |_, x, y| x + y } hash.merge!(additions: status.additions, deletions: status.deletions, file_count: 1) { |_, x, y| x + y }
end end
end end
end end
......
---
title: Add MergeRequest.diffStatsSummary.fileCount to graphql API
merge_request: 35685
author:
type: added
...@@ -3164,6 +3164,11 @@ type DiffStatsSummary { ...@@ -3164,6 +3164,11 @@ type DiffStatsSummary {
Number of lines deleted Number of lines deleted
""" """
deletions: Int! deletions: Int!
"""
Number of files changed
"""
fileCount: Int!
} }
type Discussion implements ResolvableInterface { type Discussion implements ResolvableInterface {
......
...@@ -8778,6 +8778,24 @@ ...@@ -8778,6 +8778,24 @@
"description": "Number of lines deleted", "description": "Number of lines deleted",
"args": [ "args": [
],
"type": {
"kind": "NON_NULL",
"name": null,
"ofType": {
"kind": "SCALAR",
"name": "Int",
"ofType": null
}
},
"isDeprecated": false,
"deprecationReason": null
},
{
"name": "fileCount",
"description": "Number of files changed",
"args": [
], ],
"type": { "type": {
"kind": "NON_NULL", "kind": "NON_NULL",
...@@ -545,6 +545,7 @@ Aggregated summary of changes ...@@ -545,6 +545,7 @@ Aggregated summary of changes
| `additions` | Int! | Number of lines added | | `additions` | Int! | Number of lines added |
| `changes` | Int! | Number of lines changed | | `changes` | Int! | Number of lines changed |
| `deletions` | Int! | Number of lines deleted | | `deletions` | Int! | Number of lines deleted |
| `fileCount` | Int! | Number of files changed |
## Discussion ## Discussion
......
...@@ -55,7 +55,12 @@ RSpec.describe 'getting merge request information nested in a project' do ...@@ -55,7 +55,12 @@ RSpec.describe 'getting merge request information nested in a project' do
expect(merge_request_graphql_data).to include( expect(merge_request_graphql_data).to include(
'diffStats' => all(a_hash_including('path' => String, 'additions' => be_natural, 'deletions' => be_natural)), 'diffStats' => all(a_hash_including('path' => String, 'additions' => be_natural, 'deletions' => be_natural)),
'diffStatsSummary' => a_hash_including('additions' => be_natural, 'deletions' => be_natural, 'changes' => be_natural) 'diffStatsSummary' => a_hash_including(
'fileCount' => merge_request.diff_stats.count,
'additions' => be_natural,
'deletions' => be_natural,
'changes' => be_natural
)
) )
# diff_stats is consistent with summary # diff_stats is consistent with summary
......
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