Skip to content

Commit

Permalink
Add test cases for Analysis Mutation
Browse files Browse the repository at this point in the history
  • Loading branch information
sauravsapkota committed Jul 30, 2024
1 parent 067cf25 commit b505c2c
Show file tree
Hide file tree
Showing 3 changed files with 184 additions and 37 deletions.
29 changes: 9 additions & 20 deletions apps/analysis/mutation.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@
generate_input_type_for_serializer,
PsGrapheneMutation,
PsDeleteMutation,
PsBulkGrapheneMutation,
)
from deep.permissions import ProjectPermissions as PP

Expand Down Expand Up @@ -278,15 +277,21 @@ class Arguments:
result = graphene.Field(AnalysisReportUploadType)


class CreateAnalysis(RequiredPermissionMixin, PsGrapheneMutation):
class AnalysisMutationMixin(RequiredPermissionMixin):
@classmethod
def filter_queryset(cls, qs, info):
return qs.filter(project=info.context.active_project)


class CreateAnalysis(AnalysisMutationMixin, PsGrapheneMutation):
class Arguments:
data = AnalysisInputType(required=True)
model = Analysis
serializer_class = AnalysisGqlSerializer
result = graphene.Field(AnalysisType)


class UpdateAnalysis(RequiredPermissionMixin, PsGrapheneMutation):
class UpdateAnalysis(AnalysisMutationMixin, PsGrapheneMutation):
class Arguments:
data = AnalysisInputType(required=True)
id = graphene.ID(required=True)
Expand All @@ -295,28 +300,13 @@ class Arguments:
result = graphene.Field(AnalysisType)


class DeleteAnalysis(RequiredPermissionMixin, PsDeleteMutation):
class DeleteAnalysis(AnalysisMutationMixin, PsDeleteMutation):
class Arguments:
id = graphene.ID(required=True)
model = Analysis
result = graphene.Field(AnalysisType)


class BulkAnalysisInputType(AnalysisInputType):
id = graphene.ID()


class BulkAnalysis(RequiredPermissionMixin, PsBulkGrapheneMutation):
class Arguments:
items = graphene.List(graphene.NonNull(BulkAnalysisInputType))
delete_ids = graphene.List(graphene.NonNull(graphene.ID))

result = graphene.List(AnalysisType)
deleted_result = graphene.List(graphene.NonNull(AnalysisType))
model = Analysis
serializer_class = AnalysisGqlSerializer


class Mutation():
# Analysis Pillar
analysis_pillar_update = UpdateAnalysisPillar.Field()
Expand All @@ -341,4 +331,3 @@ class Mutation():
analysis_create = CreateAnalysis.Field()
analysis_update = UpdateAnalysis.Field()
analysis_delete = DeleteAnalysis.Field()
analysis_bulk = BulkAnalysis.Field()
175 changes: 175 additions & 0 deletions apps/analysis/tests/test_mutations.py
Original file line number Diff line number Diff line change
Expand Up @@ -1326,3 +1326,178 @@ def _query_check(_id, **kwargs):
else:
self.force_login(user)
assert _query_public_snapshot_check(snapshot_slug)['data']['publicAnalysisReportSnapshot'] is not None


class TestAnalysisMutationSchema(GraphQLTestCase):
CREATE_MUTATION = '''
mutation MyMutation($analysisData: AnalysisInputType!, $projectId: ID!) {
project(id: $projectId) {
analysisCreate(
data: $analysisData
) {
errors
ok
result {
id
endDate
title
teamLead {
id
}
}
}
}
}
'''
UPDATE_MUTATION = '''
mutation MyMutation($analysisUpdate: AnalysisInputType!, $analysisID: ID!, $projectId: ID!) {
project(id: $projectId) {
analysisUpdate(data: $analysisUpdate, id: $analysisID) {
errors
ok
result {
id
endDate
title
teamLead {
id
}
}
}
}
}
'''

def setUp(self):
super().setUp()
self.af = AnalysisFrameworkFactory.create()
self.project_with_af = ProjectFactory.create(analysis_framework=self.af)
self.project_without_af = ProjectFactory.create()
# Users with different roles
self.non_member_user = UserFactory.create()
self.member_user = UserFactory.create()
self.project_with_af.add_member(self.member_user, role=self.project_role_member)

def test_create_analysis_by_unauthenticated_user(self):
variables = {
"analysisData": {
"title": "Test Analysis",
"teamLead": self.member_user.id,
"endDate": "2020-01-01"
},
"projectId": self.project_with_af.id
}

resp = self.query_check(self.CREATE_MUTATION, variables=variables, assert_for_error=True)

self.assertEqual(
resp['errors'][0]['extensions']['code'],
str(401)
)

def test_create_analysis_without_pillar(self):
variables = {
"analysisData": {
"title": "Test Analysis",
"teamLead": self.member_user.id,
"endDate": "2020-01-01"
},
"projectId": self.project_with_af.id
}

self.force_login(self.member_user)
resp = self.query_check(self.CREATE_MUTATION, variables=variables)

self.assertEqual(
resp['data']['project']['analysisCreate']['result']['title'],
variables['analysisData']['title']
)
self.assertEqual(
resp['data']['project']['analysisCreate']['result']['teamLead']['id'],
str(self.member_user.id)
)
self.assertEqual(
resp['data']['project']['analysisCreate']['result']['endDate'],
str(variables['analysisData']['endDate'])
)

def test_create_analysis_without_analysis_framework(self):
variables = {
"analysisData": {
"title": "Test Analysis",
"teamLead": self.member_user.id,
"endDate": "2020-01-01"
},
"projectId": self.project_without_af.id
}

self.force_login(self.non_member_user)
resp = self.query_check(self.CREATE_MUTATION, variables=variables, assert_for_error=True)

self.assertEqual(resp['errors'][0]['extensions']['code'], str(403))

def test_create_analysis_with_user_not_project_member(self):
variables = {
"analysisData": {
"title": "Test Analysis",
"teamLead": self.member_user.id,
"endDate": "2020-01-01"
},
"projectId": self.project_without_af.id
}
self.force_login(self.non_member_user)

resp = self.query_check(self.CREATE_MUTATION, variables=variables, assert_for_error=True)

self.assertEqual(resp['errors'][0]['extensions']['code'], str(403))

def test_create_and_update_analysis(self):
variables = {
"analysisData": {
"title": "Test Analysis",
"teamLead": self.member_user.id,
"endDate": "2020-01-01"
},
"projectId": self.project_with_af.id
}

self.force_login(self.member_user)
resp = self.query_check(self.CREATE_MUTATION, variables=variables)

self.assertEqual(
resp['data']['project']['analysisCreate']['result']['title'],
variables['analysisData']['title']
)
self.assertEqual(
resp['data']['project']['analysisCreate']['result']['teamLead']['id'],
str(self.member_user.id)
)
self.assertEqual(
resp['data']['project']['analysisCreate']['result']['endDate'],
str(variables['analysisData']['endDate'])
)

update_variables = {
"analysisUpdate": {
"title": "Updated Analysis",
"id": resp['data']['project']['analysisCreate']['result']['id'],
"teamLead": self.member_user.id,
"endDate": "2022-01-01"
},
"analysisID": resp['data']['project']['analysisCreate']['result']['id'],
"projectId": self.project_with_af.id
}
resp = self.query_check(self.UPDATE_MUTATION, variables=update_variables)

self.assertEqual(
resp['data']['project']['analysisUpdate']['result']['title'],
update_variables['analysisUpdate']['title']
)
self.assertEqual(
resp['data']['project']['analysisUpdate']['result']['teamLead']['id'],
str(self.member_user.id)
)
self.assertEqual(
resp['data']['project']['analysisUpdate']['result']['endDate'],
str(update_variables['analysisUpdate']['endDate'])
)
17 changes: 0 additions & 17 deletions schema.graphql
Original file line number Diff line number Diff line change
Expand Up @@ -3280,29 +3280,13 @@ enum AutomaticSummaryStatusEnum {
SEND_FAILED
}

type BulkAnalysis {
errors: [[GenericScalar!]]
result: [AnalysisType]
deletedResult: [AnalysisType!]
}

input BulkAnalysisFrameworkMembershipInputType {
id: ID
member: ID!
role: ID
clientId: String
}

input BulkAnalysisInputType {
id: ID
title: String!
teamLead: ID!
startDate: Date
endDate: Date!
clonedFrom: ID
analysisPillar: [AnalysisPillarGqlInputType!]
}

type BulkEntry {
errors: [[GenericScalar!]]
result: [EntryType]
Expand Down Expand Up @@ -5474,7 +5458,6 @@ type ProjectMutationType {
analysisCreate(data: AnalysisInputType!): CreateAnalysis
analysisUpdate(data: AnalysisInputType!, id: ID!): UpdateAnalysis
analysisDelete(id: ID!): DeleteAnalysis
analysisBulk(deleteIds: [ID!], items: [BulkAnalysisInputType!]): BulkAnalysis
exportCreate(data: ExportCreateInputType!): CreateUserExport
exportUpdate(data: ExportUpdateInputType!, id: ID!): UpdateUserExport
exportCancel(id: ID!): CancelUserExport
Expand Down

0 comments on commit b505c2c

Please sign in to comment.