Przeglądaj źródła

CustomLibrary提交

jo 1 rok temu
rodzic
commit
3cc4078c62

+ 7 - 0
CustomLibrary/__init__.py

@@ -0,0 +1,7 @@
+#!/usr/bin/env python3
+# -*- coding: utf-8 -*-
+
+from CustomLibrary.common_utils import CustomUtils
+
+class CustomLibrary(CustomUtils):
+    ROBOT_LIBRARY_SCOPE = 'GLOBAL'

BIN
CustomLibrary/__pycache__/__init__.cpython-37.pyc


BIN
CustomLibrary/__pycache__/common_utils.cpython-37.pyc


+ 146 - 0
CustomLibrary/common_utils.py

@@ -0,0 +1,146 @@
+#!/usr/bin/env python3
+# -*- coding: utf-8 -*-
+import json
+
+
+class CustomUtils():
+    def response_analysis(self, response):
+        """
+        解析接口返回值:返回值分三种情况如下:
+        {"jsonrpc": "2.0","id": 1,"result": true}
+        {"jsonrpc": "2.0","id": 1,"error": {"code": 1002,"message": "Permission validation error"}}
+        {"jsonrpc": "2.0","id": 1,"result": {"LoginState": 0,"Token": "0126f5d7ef044088b075246c65a410ba","LockRemainingTimes":[{}],"PasswordExpired": false,"AccountName": ""}}
+            
+        返回值示例:
+        {'resultTag':'','content':'','message':''}
+        """
+        result = {'resultTag':'','content':'','code':'','message':''}
+        try:
+            if response.status_code == 200:
+                content = str(response.content, encoding = 'UTF-8')
+                # 若传入的数据为str类型需要将它转成dict类型
+                if isinstance(content, str):
+                    content = json.loads(content)
+                # 若包含error则接口返回失败
+                if 'error' in content:
+                    result['resultTag'] = 'false';
+                    result['code'] = content['error']['code'];
+                    result['message'] = content['error']['message'];
+                else :
+                    # 若result为true时情况
+                    if isinstance(content['result'], dict):
+                        result['resultTag'] = 'true';
+                        result['content'] = content['result'];
+                    else :
+                        result['resultTag'] = content['result'];
+            else:
+                raise Exception('Exception:'+str(response.status_code));
+        except Exception as ERROR:
+            print('Exception:'+str(ERROR));
+            raise ERROR;
+        return result;
+
+    def generate_params(self, method, *args):
+
+        """
+        构建body体参数
+        {"jsonrpc": "2.0","method": "CommonSignUpAsync","params": [{"AnyAccount": "fnyml","AnyCode": "3245","Password": "222c33333","HeaderMap":{}}],"id": 1}
+        
+        def loop(request):
+            # 元组遍历方式一:for 
+            intupe_one = ('1', '2', '3', '4')
+            for value in tupe_one:
+                print(value)
+            # 元组遍历方式二:内置函数enumerate()
+            tupe_tow = ('1', '2', '3', '4')
+            for index, value in enumerate(tupe_tow):
+                print("下标:%s   值:%s" % (str(index), value))
+            # 元组遍历方式三:使用range()函数
+            tupe_three = ('1', '2', '3', '4')
+            for index in range(len(tupe_three)):
+                print(tupe_three[index])
+            # 元组遍历方式四: 使用iter()内置函数,返回迭代器对象
+            tupe_four = ('1', '2', '3', '4')for value in iter(tupe_four):
+                print(value)
+            # 列表遍历方式一:for 
+            inlist_one = ('1', '2', '3', '4')
+            for value in list_one
+                :print(value)
+            # 列表遍历方式二:内置函数enumerate()
+            list_tow = ('1', '2', '3', '4')
+            for index, value in enumerate(list_tow):
+                print("下标:%s   值:%s" % (str(index), value))
+            # 列表遍历方式三:使用range()函数
+            list_three = ('1', '2', '3', '4')
+            for index in range(len(list_three)):
+                print(list_three[index])
+            # 列表遍历方式四: 使用iter()内置函数,返回迭代器对象
+            list_four = ('1', '2', '3', '4')
+            for value in iter(list_four):
+                print(value)
+            # 字典遍历方式一:for 
+            indict_one = {"one": 1, "two": 2, "three": 3}
+            for value in dict_one:
+                print("K:%s   Value:%d" % (value, dict_one[value]))
+            # 字典遍历方式二:使用dict的keys()方法
+            dict_two = {"one": 1, "two": 2, "three": 3}
+            for key in dict_two.keys():
+                print("K:%s   Value:%d" % (key, dict_two[key]))
+            # 字典遍历方式三: 使用dict的values()方法
+            dict_three = {"one": 1, "two": 2, "three": 3}
+            for value in dict_three.values():
+                print("value:" + str(value))
+            # 字典遍历方式四: 使用dict的items()方法
+            dict_four = {"one": 1, "two": 2, "three": 3}
+            for item in dict_four.items():
+                print(item)
+            # 字典遍历方式五: 使用dict的items()方法,然后直接解包元组
+            dict_five = {"one": 1, "two": 2, "three": 3}
+                for key, value in dict_five.items():
+                    print(key + ":" + str(value))
+            return response_success(message='列表、字典、元组遍历方式验证')
+        """
+        body = {"jsonrpc": "2.0","method": "","params": [],"id": 1}
+        try:
+            body['method'] = method;
+            for value in args:
+                body['params'].append(value);
+        except Exception as ERROR:
+            print('Exception:'+str(ERROR));
+        return body;
+        
+    def result_analysis(self, result, resultTag, errorCode, message):
+    """
+        resultTag:返回标记:true/false
+        errorCode:错误码
+        message:错误内容
+    """
+        try:
+            tag = result['resultTag']
+            code = result['code']
+            mes = result['message']
+            if not (resultTag is None):
+                if resultTag is tag:
+                    return True;
+                else:
+                    raise Exception('Exception:result tag not eq');
+            elif not (errorCode is None) and not (message is None):
+                if errorCode is code and message is mes:
+                    return True;
+                else:
+                    raise Exception('Exception:errorCode or message not eq');
+            else:
+                raise Exception('Exception:params error');
+        except Exception as ERROR:
+            raise ERROR;
+        
+
+if __name__ == '__main__':
+    utils = CustomUtils()
+    s = {"jsonrpc": "2.0","id": '1',"result": 'true'};
+    ss = {"jsonrpc": "2.0","id": 1,"error": {"code": 1002,"message": "Permission validation error"}}
+    sss = {"jsonrpc": "2.0","id": 1,"result": {"LoginState": 0,"Token": "0126f5d7ef044088b075246c65a410ba","LockRemainingTimes":[{}],"PasswordExpired": 'false',"AccountName": ""}}
+    print(utils.response_analysis(s));
+    print(utils.response_analysis(ss));
+    print(utils.response_analysis(sss));
+    print(utils.generate_params('CommonSignUpAsync',{"AnyAccount": "fnyml","AnyCode": "3245","Password": "222c33333","HeaderMap":{}},{"AnyAccount": "fnyml","AnyCode": "3245","Password": "222c33333","HeaderMap":{}}));