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 31, 2024
1 parent 067cf25 commit 682f97e
Show file tree
Hide file tree
Showing 4 changed files with 210 additions and 42 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()
3 changes: 0 additions & 3 deletions apps/analysis/serializers.py
Original file line number Diff line number Diff line change
Expand Up @@ -410,19 +410,16 @@ def validate(self, data):


class AnalysisGqlSerializer(UserResourceSerializer, ProjectPropertySerializerMixin):
id = IntegerIDField(required=False)
analysis_pillar = AnalysisPillarGqlSerializer(many=True, source='analysispillar_set', required=False)
start_date = serializers.DateField(required=False, allow_null=True)

class Meta:
model = Analysis
fields = (
'id',
'title',
'team_lead',
'start_date',
'end_date',
'cloned_from',
'analysis_pillar',
)

Expand Down
201 changes: 201 additions & 0 deletions apps/analysis/tests/test_mutations.py
Original file line number Diff line number Diff line change
Expand Up @@ -1326,3 +1326,204 @@ 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
}
}
}
}
}
'''
DELETE_MUTATION = '''
mutation MyMutation($projectId: ID!, $deleteId: ID!) {
project(id: $projectId) {
analysisDelete(id: $deleteId) {
errors
result {
id
title
}
}
}
}
'''

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.readonly_member_user = UserFactory.create()
self.member_user = UserFactory.create()
self.project_with_af.add_member(self.readonly_member_user, role=self.project_role_reader_non_confidential)
self.project_with_af.add_member(self.member_user, role=self.project_role_member)

def test_create_analysis_without_pillar(self):
minput = dict(
analysisData=dict(
title='Test Analysis', teamLead=self.member_user.id, endDate='2020-01-01'
),
projectId=self.project_with_af.id,
)
# -- Without login
self.query_check(self.CREATE_MUTATION, variables=minput, assert_for_error=True)

# -- With login (non-member)
self.force_login(self.non_member_user)
self.query_check(self.CREATE_MUTATION, variables=minput, assert_for_error=True)

# --- member user (read-only)
self.force_login(self.readonly_member_user)
self.query_check(self.CREATE_MUTATION, variables=minput, assert_for_error=True)

# --- member user
self.force_login(self.member_user)
content = self.query_check(self.CREATE_MUTATION, variables=minput)

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

def test_create_analysis_without_analysis_framework(self):
minput = dict(
analysisData=dict(
title='Test Analysis', teamLead=self.member_user.id, endDate='2020-01-01'
),
projectId=self.project_without_af.id,
)

self.force_login(self.member_user)
self.query_check(self.CREATE_MUTATION, variables=minput, assert_for_error=True)

def test_create_and_update_analysis(self):
minput = dict(
analysisData=dict(
title='Test Analysis', teamLead=self.member_user.id, endDate='2020-01-01'
),
projectId=self.project_with_af.id,
)

self.force_login(self.member_user)
content = self.query_check(self.CREATE_MUTATION, variables=minput)
self.assertIsNotNone(content['data']['project']['analysisCreate']['result']['id'])

update_minput = dict(
analysisUpdate=dict(
title='Updated Analysis',
teamLead=self.member_user.id,
endDate='2022-01-01',
),
analysisID=content['data']['project']['analysisCreate']['result']['id'],
projectId=self.project_with_af.id,
)
# -- Without login
self.logout()
self.query_check(self.UPDATE_MUTATION, variables=update_minput, assert_for_error=True)

# -- With login (non-member)
self.force_login(self.non_member_user)
self.query_check(self.UPDATE_MUTATION, variables=update_minput, assert_for_error=True)

# --- member user (read-only)
self.force_login(self.readonly_member_user)
self.query_check(self.UPDATE_MUTATION, variables=update_minput, assert_for_error=True)

# --- member user
self.force_login(self.member_user)
content = self.query_check(self.UPDATE_MUTATION, variables=update_minput)
self.assertEqual(
content['data']['project']['analysisUpdate']['result']['title'],
update_minput['analysisUpdate']['title']
)
self.assertEqual(
content['data']['project']['analysisUpdate']['result']['teamLead']['id'],
str(self.member_user.id)
)
self.assertEqual(
content['data']['project']['analysisUpdate']['result']['endDate'],
str(update_minput['analysisUpdate']['endDate'])
)

def test_create_and_delete_analysis(self):
minput = dict(
analysisData=dict(
title='Test Analysis', teamLead=self.member_user.id, endDate='2020-01-01'
),
projectId=self.project_with_af.id,
)

self.force_login(self.member_user)
content = self.query_check(self.CREATE_MUTATION, variables=minput)
self.assertIsNotNone(content['data']['project']['analysisCreate']['result']['id'])

delete_minput = dict(
projectId=self.project_with_af.id,
deleteId=content['data']['project']['analysisCreate']['result']['id'],
)
# -- Without login
self.logout()
self.query_check(self.DELETE_MUTATION, variables=delete_minput, assert_for_error=True)

# -- With login (non-member)
self.force_login(self.non_member_user)
self.query_check(self.DELETE_MUTATION, variables=delete_minput, assert_for_error=True)

# --- member user (read-only)
self.force_login(self.readonly_member_user)
self.query_check(self.DELETE_MUTATION, variables=delete_minput, assert_for_error=True)

# --- member user
self.force_login(self.member_user)
content = self.query_check(self.DELETE_MUTATION, variables=delete_minput)
self.assertEqual(
content['data']['project']['analysisDelete']['result']['title'],
minput['analysisData']['title']
)
self.assertEqual(
content['data']['project']['analysisDelete']['result']['id'],
delete_minput['deleteId']
)
19 changes: 0 additions & 19 deletions schema.graphql
Original file line number Diff line number Diff line change
Expand Up @@ -261,12 +261,10 @@ type AnalysisFrameworkVisibleProjectType {
}

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

Expand Down Expand Up @@ -3280,29 +3278,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 +5456,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 682f97e

Please sign in to comment.