Commit f4e8ab6d authored by Eugenia Grieff's avatar Eugenia Grieff

Refactor epic mutations base

- Move re-used epic field to mutation base
- Move re-used arguments iid & group_path
- Update GraphQL documentation
parent 35cb061f
...@@ -2588,14 +2588,14 @@ input EpicSetSubscriptionInput { ...@@ -2588,14 +2588,14 @@ input EpicSetSubscriptionInput {
clientMutationId: String clientMutationId: String
""" """
The group the epic to (un)subscribe is in The group the epic to mutate is in
""" """
groupPath: ID! groupPath: ID!
""" """
The iid of the epic to (un)subscribe The iid of the epic to mutate
""" """
iid: ID! iid: String!
""" """
The desired state of the subscription The desired state of the subscription
......
...@@ -24409,6 +24409,20 @@ ...@@ -24409,6 +24409,20 @@
"description": "Autogenerated input type of UpdateEpic", "description": "Autogenerated input type of UpdateEpic",
"fields": null, "fields": null,
"inputFields": [ "inputFields": [
{
"name": "iid",
"description": "The iid of the epic to mutate",
"type": {
"kind": "NON_NULL",
"name": null,
"ofType": {
"kind": "SCALAR",
"name": "String",
"ofType": null
}
},
"defaultValue": null
},
{ {
"name": "groupPath", "name": "groupPath",
"description": "The group the epic to mutate is in", "description": "The group the epic to mutate is in",
...@@ -24519,20 +24533,6 @@ ...@@ -24519,20 +24533,6 @@
}, },
"defaultValue": null "defaultValue": null
}, },
{
"name": "iid",
"description": "The iid of the epic to mutate",
"type": {
"kind": "NON_NULL",
"name": null,
"ofType": {
"kind": "SCALAR",
"name": "String",
"ofType": null
}
},
"defaultValue": null
},
{ {
"name": "stateEvent", "name": "stateEvent",
"description": "State event for the epic", "description": "State event for the epic",
...@@ -24863,22 +24863,22 @@ ...@@ -24863,22 +24863,22 @@
"fields": null, "fields": null,
"inputFields": [ "inputFields": [
{ {
"name": "groupPath", "name": "iid",
"description": "The group the epic to (un)subscribe is in", "description": "The iid of the epic to mutate",
"type": { "type": {
"kind": "NON_NULL", "kind": "NON_NULL",
"name": null, "name": null,
"ofType": { "ofType": {
"kind": "SCALAR", "kind": "SCALAR",
"name": "ID", "name": "String",
"ofType": null "ofType": null
} }
}, },
"defaultValue": null "defaultValue": null
}, },
{ {
"name": "iid", "name": "groupPath",
"description": "The iid of the epic to (un)subscribe", "description": "The group the epic to mutate is in",
"type": { "type": {
"kind": "NON_NULL", "kind": "NON_NULL",
"name": null, "name": null,
......
...@@ -5,6 +5,19 @@ module Mutations ...@@ -5,6 +5,19 @@ module Mutations
class Base < ::Mutations::BaseMutation class Base < ::Mutations::BaseMutation
include Mutations::ResolvesGroup include Mutations::ResolvesGroup
argument :iid, GraphQL::STRING_TYPE,
required: true,
description: "The iid of the epic to mutate"
argument :group_path, GraphQL::ID_TYPE,
required: true,
description: 'The group the epic to mutate is in'
field :epic,
Types::EpicType,
null: true,
description: 'The epic after mutation'
private private
def find_object(group_path:, iid:) def find_object(group_path:, iid:)
......
...@@ -7,23 +7,10 @@ module Mutations ...@@ -7,23 +7,10 @@ module Mutations
authorize :read_epic authorize :read_epic
argument :group_path, GraphQL::ID_TYPE,
required: true,
description: 'The group the epic to (un)subscribe is in'
argument :iid, GraphQL::ID_TYPE,
required: true,
description: 'The iid of the epic to (un)subscribe'
argument :subscribed_state, GraphQL::BOOLEAN_TYPE, argument :subscribed_state, GraphQL::BOOLEAN_TYPE,
required: true, required: true,
description: 'The desired state of the subscription' description: 'The desired state of the subscription'
field :epic,
Types::EpicType,
null: true,
description: 'The epic after mutation'
def resolve(args) def resolve(args)
group_path = args.delete(:group_path) group_path = args.delete(:group_path)
epic_iid = args.delete(:iid) epic_iid = args.delete(:iid)
......
...@@ -7,10 +7,6 @@ module Mutations ...@@ -7,10 +7,6 @@ module Mutations
graphql_name 'UpdateEpic' graphql_name 'UpdateEpic'
argument :iid, GraphQL::STRING_TYPE,
required: true,
description: "The iid of the epic to mutate"
argument :state_event, argument :state_event,
Types::EpicStateEventEnum, Types::EpicStateEventEnum,
required: false, required: false,
...@@ -21,11 +17,6 @@ module Mutations ...@@ -21,11 +17,6 @@ module Mutations
required: false, required: false,
description: 'The desired health status' description: 'The desired health status'
field :epic,
Types::EpicType,
null: true,
description: 'The epic after mutation'
authorize :admin_epic authorize :admin_epic
def resolve(args) def resolve(args)
......
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