feat: sflog init_test接口
This commit is contained in:
parent
0f1bb7fd72
commit
93881852d0
|
@ -10,6 +10,8 @@ from apps.utils.viewsets import CustomGenericViewSet, CustomModelViewSet
|
|||
from apps.wpm.models import SfLog, StLog, StSfLog
|
||||
from apps.wpm.serializers import SfLogSerializer, StLogSerializer, StSfLogSerializer
|
||||
from apps.wpm.filters import SfLogFilter
|
||||
from apps.mtm.models import Material
|
||||
from django.utils.timezone import localtime
|
||||
|
||||
# Create your views here.
|
||||
class StLogViewSet(ListModelMixin, CustomGenericViewSet):
|
||||
|
@ -40,23 +42,48 @@ class SfLogViewSet(UpdateModelMixin, ListModelMixin, DestroyModelMixin, CustomGe
|
|||
search_fields = ['note']
|
||||
ordering = ['-start_time']
|
||||
|
||||
@transaction.atomic
|
||||
def perform_create(self, serializer):
|
||||
ins = serializer.save()
|
||||
# 查看并比对停机记录
|
||||
stls = StLog.objects.filter(mroup=ins.mgroup)
|
||||
stls_ = (stls.filter(start_time__gte=ins.start_time, start_time__lt=ins.end_time)|
|
||||
stls.exclude(end_time=None).filter(start_time__lte=ins.start_time, end_time__gt=ins.end_time)|
|
||||
stls.exclude(end_time=None).filter(end_time__gte=ins.start_time, end_time__lt=ins.end_time))
|
||||
for i in stls_:
|
||||
StSfLog.objects.get_or_create(stlog=i, sflog=ins, defaults={'stlog': i, 'sflog': ins})
|
||||
stsflog = StSfLog.objects.filter(stlog=i).order_by('-sflog__start_time').first()
|
||||
if stsflog:
|
||||
stsflog.is_current_down = True
|
||||
stsflog.save()
|
||||
# 计算能耗
|
||||
from apps.enm.tasks import cal_sflog_en_val
|
||||
cal_sflog_en_val.delay(ins.id)
|
||||
# 此处需要进行修改
|
||||
# @transaction.atomic
|
||||
# def perform_create(self, serializer):
|
||||
# ins = serializer.save()
|
||||
# # 查看并比对停机记录
|
||||
# stls = StLog.objects.filter(mroup=ins.mgroup)
|
||||
# stls_ = (stls.filter(start_time__gte=ins.start_time, start_time__lt=ins.end_time)|
|
||||
# stls.exclude(end_time=None).filter(start_time__lte=ins.start_time, end_time__gt=ins.end_time)|
|
||||
# stls.exclude(end_time=None).filter(end_time__gte=ins.start_time, end_time__lt=ins.end_time))
|
||||
# for i in stls_:
|
||||
# StSfLog.objects.get_or_create(stlog=i, sflog=ins, defaults={'stlog': i, 'sflog': ins})
|
||||
# stsflog = StSfLog.objects.filter(stlog=i).order_by('-sflog__start_time').first()
|
||||
# if stsflog:
|
||||
# stsflog.is_current_down = True
|
||||
# stsflog.save()
|
||||
# # 计算能耗
|
||||
# from apps.enm.tasks import cal_sflog_en_val
|
||||
# cal_sflog_en_val.delay(ins.id)
|
||||
|
||||
@action(methods=['get'], detail=True, perms_map={'get': '*'})
|
||||
def init_test(self, request, pk=None):
|
||||
"""
|
||||
初始化检测录入
|
||||
|
||||
初始化检测录入
|
||||
"""
|
||||
from apps.qm.models import QuaStat, TestItem
|
||||
from apps.qm.serializers import QuaStatSerializer
|
||||
obj = self.get_object()
|
||||
test_materials = obj.mgroup.test_materials
|
||||
for mid in test_materials:
|
||||
material = Material.objects.get(id=mid)
|
||||
testitems = material.testitems
|
||||
for tid in testitems:
|
||||
testitem = TestItem.objects.get(id=tid)
|
||||
end_time_local = localtime(obj.end_time)
|
||||
params = {'type': 'sflog', 'material': material, 'testitem': testitem}
|
||||
params_default = params.update({'year_s': end_time_local.year, 'month': end_time_local.month, 'day': end_time_local.day})
|
||||
QuaStat.objects.get_or_create(**params, defaults=params_default)
|
||||
qs = QuaStat.objects.filter(type='sflog', sflog=obj)
|
||||
sr = QuaStatSerializer(instance=qs, many=True)
|
||||
return Response(sr.data)
|
||||
|
||||
class StSfLogViewSet(ListModelMixin, UpdateModelMixin, CustomGenericViewSet):
|
||||
"""
|
||||
|
|
Loading…
Reference in New Issue