接口测试完毕

This commit is contained in:
曹前明 2022-05-19 09:59:16 +08:00
parent d68418d23c
commit b5e961bc64
9 changed files with 224 additions and 60 deletions

View File

@ -0,0 +1,19 @@
# Generated by Django 3.0.5 on 2022-05-19 00:11
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
('ability', '0026_qactionitem_qaction'),
]
operations = [
migrations.AlterField(
model_name='qaction',
name='qtask',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='ability.QTask'),
),
]

View File

@ -0,0 +1,28 @@
# Generated by Django 3.0.5 on 2022-05-19 00:32
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('ability', '0027_auto_20220519_0811'),
]
operations = [
migrations.AlterField(
model_name='quali',
name='grade',
field=models.PositiveSmallIntegerField(blank=True, null=True, verbose_name='等级'),
),
migrations.AlterField(
model_name='quali',
name='level',
field=models.CharField(blank=True, max_length=10, null=True, verbose_name='等级'),
),
migrations.AlterField(
model_name='quali',
name='name',
field=models.CharField(blank=True, max_length=20, null=True, verbose_name='资质名称'),
),
]

View File

@ -0,0 +1,19 @@
# Generated by Django 3.0.5 on 2022-05-19 00:33
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('system', '0020_auto_20220513_0926'),
('ability', '0028_auto_20220519_0832'),
]
operations = [
migrations.AlterField(
model_name='quali',
name='citys',
field=models.ManyToManyField(blank=True, null=True, related_name='quali_citys', to='system.City', verbose_name='备案城市'),
),
]

View File

@ -0,0 +1,19 @@
# Generated by Django 3.0.5 on 2022-05-19 00:34
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('system', '0020_auto_20220513_0926'),
('ability', '0029_auto_20220519_0833'),
]
operations = [
migrations.AlterField(
model_name='quali',
name='citys',
field=models.ManyToManyField(blank=True, related_name='quali_citys', to='system.City', verbose_name='备案城市'),
),
]

View File

@ -0,0 +1,28 @@
# Generated by Django 3.0.5 on 2022-05-19 01:03
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('ability', '0030_auto_20220519_0834'),
]
operations = [
migrations.AlterField(
model_name='quali',
name='grade',
field=models.PositiveSmallIntegerField(blank=True, null=True, verbose_name='等级1'),
),
migrations.AlterField(
model_name='quali',
name='level',
field=models.CharField(blank=True, max_length=10, null=True, verbose_name='等级2'),
),
migrations.AlterField(
model_name='quali',
name='type',
field=models.CharField(choices=[('CMA', 'CMA'), ('CNAS', 'CNAS'), ('OTHER', 'OTHER')], max_length=10, verbose_name='资质类型'),
),
]

View File

@ -0,0 +1,19 @@
# Generated by Django 3.0.5 on 2022-05-19 01:24
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('ability', '0031_auto_20220519_0903'),
]
operations = [
migrations.AlterField(
model_name='qactionitem',
name='action',
field=models.CharField(choices=[('update', '更新'), ('citys:add', '新增备案城市'), ('citys:remove', '移除备案城市')], default='update', max_length=20, verbose_name='操作类型'),
preserve_default=False,
),
]

View File

@ -146,14 +146,14 @@ class Quali(CommonAModel):
(30, '市级')
)
org = models.ForeignKey(Organization, on_delete=models.CASCADE, verbose_name='所属单位')
name = models.CharField('资质名称', max_length=20)
type = models.PositiveSmallIntegerField('资质类型', choices=QUALI_TYPE_CHOICES)
grade = models.PositiveSmallIntegerField('等级')
name = models.CharField('资质名称', max_length=20, null=True, blank=True)
type = models.CharField('资质类型', choices=QUALI_TYPE_CHOICES, max_length=10)
grade = models.PositiveSmallIntegerField('等级1', null=True, blank=True)
scope = models.TextField('范围', null=True, blank=True)
level = models.CharField('等级', max_length=10)
level = models.CharField('等级2', max_length=10, null=True, blank=True)
province = models.ForeignKey(Province, on_delete=models.SET_NULL, null=True, blank=True)
city = models.ForeignKey(City, on_delete=models.SET_NULL, null=True, blank=True, related_name='quali_city')
citys = models.ManyToManyField(City, verbose_name='备案城市', related_name='quali_citys')
citys = models.ManyToManyField(City, verbose_name='备案城市', related_name='quali_citys', blank=True)
description = models.TextField('描述', null=True, blank=True)
qualilib = models.ForeignKey(QualiLib, verbose_name='关联资质库',
null=True, blank=True, on_delete=models.SET_NULL)
@ -205,7 +205,7 @@ class QAction(CommonBModel):
afield = models.ForeignKey(Dict, null=True, blank=True, verbose_name='所属领域',
on_delete=models.CASCADE, related_name='quali_afield')
num = models.PositiveIntegerField('新增能力数量', null=True, blank=True)
qtask = models.ForeignKey(QOrg, on_delete=models.CASCADE)
qtask = models.ForeignKey(QTask, on_delete=models.CASCADE)
value1 = JSONField('值1', null=True, blank=True, default=dict)
value2 = JSONField('值2', null=True, blank=True, default=dict)
confirmed = models.BooleanField('是否确认',default=False)
@ -217,7 +217,7 @@ class QActionItem(BaseModel):
('citys:add', '新增备案城市'),
('citys:remove', '移除备案城市'),
)
action = models.PositiveSmallIntegerField('操作类型', null=True, blank=True, choices=QACTIONITEM_CHOICE)
action = models.CharField('操作类型', max_length=20, choices=QACTIONITEM_CHOICE)
field = models.CharField('变动字段', max_length=20)
value1 = JSONField('原值', null=True, blank=True, default=dict)
value2 = JSONField('新值', null=True, blank=True, default=dict)

View File

@ -23,31 +23,31 @@ class QualiListSerializer(serializers.ModelSerializer):
class QTaskCreateUpdateSerializer(serializers.ModelSerializer):
orgs = serializers.PrimaryKeyRelatedField(label='上报公司ID列表',
queryset = Organization.objects.all(), many=True)
queryset = Organization.objects.all(), many=True, write_only=True)
class Meta:
model = QTask
fields = ['name', 'end_date', 'orgs']
@transaction.atomic
def create(self, validated_data):
orgs = validated_data.pop('orgs')
validated_data['state'] = '待发布'
instance = super().create(validated_data)
for i in orgs:
QOrg.objects.get_or_create(qtask=instance, org=i,
defaults={'qtask': instance, 'org': i})
return instance
with transaction.atomic():
orgs = validated_data.pop('orgs')
validated_data['state'] = '待发布'
instance = super().create(validated_data)
for i in orgs:
QOrg.objects.get_or_create(qtask=instance, org=i,
defaults={'qtask': instance, 'org': i})
return instance
@transaction.atomic
def update(self, instance, validated_data):
if instance.state == '已关闭':
raise ParseError('任务已关闭,不可更改')
orgs = validated_data.pop('orgs')
instance = super().update(instance, validated_data)
for i in orgs:
QOrg.objects.get_or_create(qtask=instance, org=i,
defaults={'qtask': instance, 'org': i})
return instance
with transaction.atomic():
if instance.state == '已关闭':
raise ParseError('任务已关闭,不可更改')
orgs = validated_data.pop('orgs')
instance = super().update(instance, validated_data)
for i in orgs:
QOrg.objects.get_or_create(qtask=instance, org=i,
defaults={'qtask': instance, 'org': i})
return instance
class QTaskListSerializer(serializers.ModelSerializer):
@ -93,16 +93,18 @@ class QActionServiceSerializer(serializers.ModelSerializer):
return super().create(validated_data)
class QualiCreateSerializer(serializers.ModelSerializer):
citys = serializers.PrimaryKeyRelatedField(queryset=City.objects.all(), many=True, label='城市ID列表')
citys = serializers.ListField(child=serializers.IntegerField(), label='城市ID列表')
class Meta:
model = Quali
fields = ['name', 'type', 'grade', 'scope', 'level', 'province', 'city', 'description', 'citys']
class QualiUpdateSerializer(serializers.ModelSerializer):
citys = serializers.PrimaryKeyRelatedField(queryset=City.objects.all(), many=True, label='城市ID列表')
citys = serializers.ListField(child=serializers.IntegerField(), label='城市ID列表')
id = serializers.IntegerField(label='修改资质的ID')
class Meta:
model = Quali
fields = ['name', 'type', 'grade', 'scope', 'level', 'province', 'city', 'description', 'id', 'citys']
fields = ['scope', 'level', 'description', 'id', 'citys']
class QualiSerializer(serializers.ModelSerializer):
class Meta:
@ -114,9 +116,11 @@ class QActionQualiCreateSerializer(serializers.ModelSerializer):
class Meta:
model = QAction
fields = ['qtask', 'value2']
def create(self, validated_data):
validated_data['action'] = 'quali:create'
if validated_data['value2']['type'] in ['CMA', 'CNAS']:
validated_data['value2']['name'] = validated_data['value2']['type']
return super().create(validated_data)
class QActionQualiUpdateSerializer(serializers.ModelSerializer):
@ -126,7 +130,7 @@ class QActionQualiUpdateSerializer(serializers.ModelSerializer):
fields = ['qtask', 'value2']
def create(self, validated_data):
validated_data['action'] = 'quali:create'
validated_data['action'] = 'quali:update'
return super().create(validated_data)
class QActionACreateSerializer(serializers.ModelSerializer):

View File

@ -2,11 +2,12 @@ from rest_framework.viewsets import GenericViewSet
from rest_framework.mixins import ListModelMixin, CreateModelMixin, UpdateModelMixin, DestroyModelMixin, RetrieveModelMixin
from rest_framework.decorators import action
from apps.ability.models import QAction, QActionItem, QOrg, QTask, Quali, QualiLib
from apps.ability.serializers_qtask import QActionDetailSerializer, QActionListSerializer, QActionQualiCreateSerializer, QActionQualiUpdateSerializer, QActionServiceSerializer, QOrgListSerializer, QTaskCreateUpdateSerializer, QTaskListSerializer, QualiCreateSerializer, QualiLibListSerializer, QualiListSerializer, QualiSerializer, QualiUpdateSerializer
from apps.ability.serializers_qtask import QActionACreateSerializer, QActionDetailSerializer, QActionListSerializer, QActionQualiCreateSerializer, QActionQualiUpdateSerializer, QActionServiceSerializer, QOrgListSerializer, QTaskCreateUpdateSerializer, QTaskListSerializer, QualiCreateSerializer, QualiLibListSerializer, QualiListSerializer, QualiSerializer, QualiUpdateSerializer
from django.db import transaction
from rest_framework.response import Response
from rest_framework import status
from apps.system.mixins import CreateUpdateCustomMixin
from apps.system.models import City
from utils.pagination import PageOrNot
from rest_framework.exceptions import ParseError
from rest_framework import serializers
@ -26,8 +27,24 @@ class QualiViewSet(ListModelMixin, GenericViewSet):
search_fields = ['name', 'type', 'grade']
ordering = ['org__sort']
@action(methods=['get'], detail=False, perms_map = {'get':'*'})
def my(self, request, *args, **kwargs):
"""
我的资质
"""
user = self.request.user
queryset = self.filter_queryset(self.get_queryset().filter(org=user.dept))
page = self.paginate_queryset(queryset)
if page is not None:
serializer = self.get_serializer(page, many=True)
return self.get_paginated_response(serializer.data)
serializer = self.get_serializer(queryset, many=True)
return Response(serializer.data)
class QTaskViewSet(CreateUpdateCustomMixin, CreateModelMixin, ListModelMixin, UpdateModelMixin, GenericViewSet):
perms_map = {'get': 'qtask_view', 'post': 'qtask_create'}
perms_map = {'get': 'qtask_view', 'post': 'qtask_create', 'put': 'qtask_update'}
queryset = QTask.objects.all()
serializer_class = QTaskListSerializer
ordering = ['-create_time']
@ -37,7 +54,7 @@ class QTaskViewSet(CreateUpdateCustomMixin, CreateModelMixin, ListModelMixin, Up
return QTaskCreateUpdateSerializer
return super().get_serializer_class()
@action(methods=['put'], detail=True, perms_map = {'put':'qtask_start'})
@action(methods=['put'], detail=True, perms_map = {'put':'qtask_start'}, serializer_class=serializers.Serializer)
@transaction.atomic
def start(self, request, *args, **kwargs):
"""
@ -47,7 +64,6 @@ class QTaskViewSet(CreateUpdateCustomMixin, CreateModelMixin, ListModelMixin, Up
if obj.state == '待发布':
obj.state = '进行中'
obj.save()
QOrg.objects.filter(qtask=obj).update(state='待报送')
return Response()
return Response('任务状态错误', status=status.HTTP_400_BAD_REQUEST)
@ -58,13 +74,13 @@ class QOrgViewSet(ListModelMixin, GenericViewSet):
serializer_class = QOrgListSerializer
ordering = ['-create_time']
@action(methods=['get'], detail=False, perms_map = {'post':'qtask_my'})
@action(methods=['get'], detail=False, perms_map = {'get':'qtask_my'})
def my(self, request, *args, **kwargs):
"""
我的报送任务
"""
user = self.request.user
queryset = self.filter_queryset(self.get_queryset().filter(org=user.dept))
queryset = self.filter_queryset(self.get_queryset().filter(org=user.dept).exclude(qtask__state='待发布'))
page = self.paginate_queryset(queryset)
if page is not None:
@ -81,7 +97,6 @@ def cal_count(qtask, org):
qorg.count_confirmed = qs.filter(confirmed=True).count()
qorg.save()
class QActionViewSet(PageOrNot, ListModelMixin, DestroyModelMixin, RetrieveModelMixin,GenericViewSet):
perms_map = {'get': 'qtask_view'}
queryset = QAction.objects.select_related('file', 'atype', 'afield', 'qtask', 'belong_dept')
@ -95,7 +110,7 @@ class QActionViewSet(PageOrNot, ListModelMixin, DestroyModelMixin, RetrieveModel
return QActionDetailSerializer
return super().get_serializer_class()
@action(methods=['get'], detail=False, perms_map = {'post':'qaction_my'})
@action(methods=['get'], detail=False, perms_map = {'get':'qaction_my'})
def my(self, request, *args, **kwargs):
"""
我的报送操作
@ -144,7 +159,6 @@ class QActionViewSet(PageOrNot, ListModelMixin, DestroyModelMixin, RetrieveModel
serializer.save(create_by=user, belong_dept=user.dept)
vdata = serializer.validated_data
cal_count(vdata['qtask'], user.dept)
# 更新资质库
return Response()
@action(methods=['post'], detail=False,
@ -157,13 +171,30 @@ class QActionViewSet(PageOrNot, ListModelMixin, DestroyModelMixin, RetrieveModel
user = request.user
serializer = self.get_serializer(data=request.data)
serializer.is_valid(raise_exception=True)
serializer.save(create_by=user, belong_dept=user.dept)
obj = serializer.save(create_by=user, belong_dept=user.dept)
vdata = serializer.validated_data
# 比较差别
quali = Quali.objects.get(id=obj.value2.get('id'))
old_data = QualiSerializer(instance=quali).data
obj.value1 = old_data
for k, v in obj.value2.items():
if v != old_data[k]:
QActionItem.objects.create(action='update', field=k, value1=old_data[k], value2=v, qaction=obj)
if k == 'citys':
old_citys = set(old_data['citys'])
new_citys = set(v)
removes = old_citys.difference(new_citys)
adds = new_citys.difference(old_citys)
for i in removes:
QActionItem.objects.create(action='city:remove', field='citys', city=City.objects.get(id=i), qaction=obj)
for i in adds:
QActionItem.objects.create(action='city:add', field='citys', city=City.objects.get(id=i), qaction=obj)
cal_count(vdata['qtask'], user.dept)
return Response()
@action(methods=['post'], detail=False,
perms_map = {'post':'ability_create'}, serializer_class=QActionQualiCreateSerializer)
perms_map = {'post':'ability_create'}, serializer_class=QActionACreateSerializer)
@transaction.atomic
def ability_create(self, request, *args, **kwargs):
"""
@ -187,36 +218,33 @@ class QActionViewSet(PageOrNot, ListModelMixin, DestroyModelMixin, RetrieveModel
obj = self.get_object()
if obj.confirmed:
raise ParseError('该动作已确认')
if obj.action == 'service.update':
org = obj.org
org.service = obj.service
if obj.action == 'service:update':
org = obj.belong_dept
org.service = obj.value2
org.save()
elif obj.action == 'quali:create':
serializer = QualiCreateSerializer(data=obj.value2)
serializer.save(org=obj.belong_dept, create_by=obj.create_by)
serializer.is_valid(raise_exception=True)
instance = serializer.save(org=obj.belong_dept, create_by=obj.create_by)
if instance.type == 'OTHER':
qualiLib, _ = QualiLib.objects.get_or_create(name=instance.name)
levels = qualiLib.levels
levels.append(instance.level)
le = list(set(levels))
qualiLib.levels = le
qualiLib.save()
instance.qualilib = qualiLib
instance.save()
elif obj.action == 'quali:update':
quali = Quali.objects.get(id=obj.value2.get('id'))
old_data = QualiSerializer(instance=quali).data
obj.value1 = old_data
s = QualiUpdateSerializer(instance=quali, data=obj.value2)
s.is_valid(raise_exception=True)
s.save(update_by=obj.create_by)
# 比较差别
for k, v in obj.value2.items():
if v != old_data[k]:
QActionItem.objects.create(action='update', field=k, vaule1=old_data[k], value2=v, qaction=obj)
if k == 'citys':
old_citys = set(old_data['citys'])
new_citys = set(v)
removes = old_citys.difference(new_citys)
adds = new_citys.difference(old_citys)
for i in removes:
QAction.objects.create(action='city:remove', field='citys', city=i, qaction=obj)
for i in adds:
QAction.objects.create(action='city:add', field='citys', city=i, qaction=obj)
elif obj.action == 'ability:create':
pass
obj.confirmed = True
obj.save()
cal_count(obj.qtask, obj.belong_dept)
return Response(status=status.HTTP_200_OK)