Esempio n. 1
0
def delete_ready(req, mock_pro_id):
    print "开始调用delete_ready", req, req.GET
    mock_pro_id = mock_pro_id
    prc = Request.objects.get(id=mock_pro_id)
    temp = Request_Data.objects.filter(f_key=mock_pro_id)
    temp = toolbox.requestDict(temp)
    print 'temp', temp, prc.url
    data_src, header_src = toolbox.reqGETDict(req.GET)
    # prc.url=toolbox.delete_url(data_src,prc.url)
    text = ""
    url = ""
    try:
        text, url = xxd_request_delete(req, mock_pro_id, prc.type)

    except:
        print "GET SOLO"
    context = {
        'url': prc.url,
        'data': temp,
        'name': prc.name,
        'text': str(text),
        'data_src': 'data_src'
    }
    print '开始调用get_ready的context', context
    return render(req, 'mock_pro/post_sub.html', context)
Esempio n. 2
0
def get_batch_ok(req, mock_pro_id):
    data_src = toolbox.reqGETDict(
        req.GET, "no normal")[0]  #页面内容转为字典,直接DICT会造成u''的问题 后面的参数是为了暂缓进行加签
    TimesOfRepetition = req.GET['TimesOfRepetition']  #获取次数
    VUserNum = req.GET['VUserNum']
    ok = error = sum_res = 0
    start = time.time()
    for i in range(int(TimesOfRepetition)):
        data = toolbox.requestDict(data_src, "dict")  #进行数据整理 !.!类型数据生成
        data = toolbox.signCreater(data, {'sign': req.GET['sign']})  #进行加签操作
        data = urllib.urlencode(data)  #GET拼接
        url = req.GET['url'] + "?" + data
        try:
            req_temp = urllib2.Request(url)
            res_data = urllib2.urlopen(req_temp)
            res = res_data.read()
            sum_res += len(res)
            ok += 1
            #这里要做个结果判断的
        except:
            error += 1
    end = time.time() - start
    toolbox.logInsert(req.GET['url'], str(TimesOfRepetition), 'GET',
                      Request.objects.get(id=mock_pro_id).name, str(sum_res),
                      Request.objects.get(id=mock_pro_id), str(end),
                      str("pass:"******" error:" + str(error)))
    return HttpResponse("pass:"******" error:" + str(error))
Esempio n. 3
0
def get_ready(req, mock_pro_id):
    print "开始调用get_ready", req
    mock_pro_id = mock_pro_id
    prc = Request.objects.get(id=mock_pro_id)
    print 'prc.url', prc.url, type(prc.url)
    temp = Request_Data.objects.filter(f_key=mock_pro_id)
    temp = toolbox.requestDict(temp)
    prc.url = toolbox.get_url_pro(prc.url, temp)
    # data = temp[0]
    # header = temp[1]
    text = ""
    data_src = ""
    try:
        text, data_src = xxd_request2(req, mock_pro_id, prc.type)
    except:
        print "GET SOLO"
    context = {
        'url': prc.url,
        'data': temp,
        'name': prc.name,
        'text': str(text),
        'data_src': str(data_src)
    }
    print '开始调用get_ready的context', context
    return render(req, 'mock_pro/post_sub.html', context)
Esempio n. 4
0
def xxd_request_ready(req, mock_pro_id):
    prc = Request.objects.get(id=mock_pro_id)
    temp = Request_Data.objects.filter(f_key=mock_pro_id)
    unite = Request_Unite.objects.filter(f_key=mock_pro_id)
    data = toolbox.requestDict(temp)
    context = {'url': prc.url, 'data': data, 'name': prc.name}
    return render(req, 'mock_pro/post_sub_new.html', context)
def get_ready(req,test1_id):
    prc = Request.objects.get(id=test1_id)
    temp = Request_Data.objects.filter(f_key=test1_id)
    temp = toolbox.requestDict(temp)
    data = temp[0]
    header = temp[1]
    context = {'url':prc.url,'data':data,'name':prc.name}   
    return render(req,'test1/post_sub.html',context)
Esempio n. 6
0
def post_ready(req, mock_pro_id):
    # print "开始调用post_ready接口req:",req,"mock_pro_id",mock_pro_id
    prc = Request.objects.get(id=mock_pro_id)
    temp = Request_Data.objects.filter(f_key=mock_pro_id)
    unite = Request_Unite.objects.filter(f_key=mock_pro_id)
    unite = toolbox.uniteDict(toolbox.requestDict(unite))
    print "_____________"

    data = toolbox.requestDict(temp)
    print "_____________"
    #判断是否有透传的字段
    try:
        backup = req.GET['backup']
        response = req.GET['text']
        print 'backup', backup
        data = toolbox.data_trans(data, backup, response)
    except:
        print "不是联调方式"
    print "请求数据data:::::", req, mock_pro_id, prc.type
    text = ""
    data_src = ""
    try:
        text, data_src = xxd_request(req, mock_pro_id, prc.type)
        print "接口请求数据:::::::::".data_src, "接口返回内容text:::::::", text
    except:
        print "接口请求 solo"
    print "_____________"

    context = {
        'url': prc.url,
        'data': data,
        'name': prc.name,
        'unite': unite,
        "text": str(text),
        "data_src": str(data_src)
    }
    #return render(req,'mock_pro/post_sub.html',context)
    print "调用post_ready结束req:", req, "context:", context
    return render(req, 'mock_pro/post_sub_new.html', context)
Esempio n. 7
0
def post_batch_ok(req, mock_pro_id):
    data_src = toolbox.reqGETDict(
        req.GET, "no normal")[0]  #页面内容转为字典,直接DICT会造成u''的问题 后面的参数是为了暂缓进行加签
    TimesOfRepetition = int(req.GET['TimesOfRepetition'])  #获取次数
    VUserNum = int(req.GET['VUserNum'])
    start = time.time()
    data_list = []
    res_list = [0, 0, 0, threading.Lock()]
    for i in range(TimesOfRepetition):
        data = toolbox.requestDict(data_src, "dict")  #进行数据整理 !.!类型数据生成
        # data = toolbox.signCreater(data,{'sign':req.GET['sign']}) #进行加签操作
        data = urllib.urlencode(data)  #GET拼接
        data_list.append(data)
    threads = []
    if VUserNum == 1:  #单一用户就发一组
        toolbox.post_more(req.GET['url'], data_list, 1, res_list)
    else:  #发N组
        for i in range(VUserNum):
            exec "t%d = threading.Thread(target=toolbox.post_more,args=(req.GET['url'],data_list,1,res_list))" % i
            exec "threads.append(t%d)" % i
        for t in threads:
            t.setDaemon(True)
            t.start()
            t.join()
        time.sleep(1)  #有可能丢包,再说
    end = time.time() - start
    #以下内容是通过pylab生成image后,再显示到页面
    #绘图
    # nowtime = datetime.datetime.now().strftime("%Y-%m-%d%H%M%S")
    # res = toolbox.drawDateReady(res_list[4:])
    # toolbox.drawChart_Xs(res[0],res[2],res[3],'static/png/'+nowtime+'Result')
    # toolbox.drawChart_X(res[1],res[2],res[4],'static/png/'+nowtime+'Amountofdata')
    #
    #记LOG
    # toolbox.logInsert(req.GET['url'],res_list[4:],'POST', #URL,DATA,TYPE
    #                   Request.objects.get(id=mock_pro_id).name,str(res_list[2]), #NAME
    #                   Request.objects.get(id=mock_pro_id),str(end),str("pass:"******" error:"+str(res_list[1])))#RESPONSE,LEN,TIME
    # #return HttpResponse("pass:"******" error:"+str(res_list[1]),'1')#"pass:"******" error:"+str(error)
    # context={'res':"pass:"******" error:"+str(res_list[1]),'imgs':['/static/png/'+nowtime+'Result.png','/static/png/'+nowtime+'Amountofdata.png']}
    # return render(req,'mock_pro/showBatchRes.html',context)
    #这里是通过highchar生成动态图表
    Requset_list = toolbox.drawDateReady(res_list[4:])
    Requset_list = toolbox.hcharDateReady(Requset_list)
    context = {
        'pass_list': Requset_list[0],
        'error_list': Requset_list[1],
        'data_list': Requset_list[2],
        'rang_1': Requset_list[3],
        'rang_2': Requset_list[4]
    }
    return render(req, 'mock_pro/showBatchRes.html', context)
Esempio n. 8
0
def get_batch_ready(req, mock_pro_id):
    prc = Request.objects.get(id=mock_pro_id)
    temp = Request_Data.objects.filter(f_key=mock_pro_id)
    data = toolbox.requestDict(temp, "batch")  #不进行数据预处理
    context = {'url': prc.url, 'data': data, 'name': prc.name}
    return render(req, 'mock_pro/get_batch_sub.html', context)