未验证 提交 14f50d63 编写于 作者: Z zhangchunle 提交者: GitHub

Revert "get apis returned result (#23165)";test=develop;test=document_fix (#23233)

This reverts commit 23baf865.
上级 430b0099
......@@ -22,7 +22,6 @@ import inspect
import paddle
import paddle.fluid
import json
import re
"""
please make sure to run in the tools path
usage: python sample_test.py {arg1}
......@@ -84,32 +83,6 @@ def check_indent(cdline):
return indent
def return_sample(htype, srccom, mode):
"""
this function will return sample code or sample result.
Args:
htype(str): the type of hint banners, def/class/method.
srccom(str): the source comment of some API whose
example codes will be extracted and run.
mode(str): return mode. python/text.
Returns:
r: sample code or sample result.
"""
if htype == 'method':
strings = '^ code-block:: %s\n(.*?)\n [^ ]' % mode
pattern = re.compile(strings, re.MULTILINE | re.DOTALL)
else:
strings = '^ code-block:: %s\n(.*?)\n [^ ]' % mode
pattern = re.compile(strings, re.MULTILINE | re.DOTALL)
if pattern.search(srccom) == None:
r = None
else:
r = pattern.search(srccom).group(1)
return r
# srccom: raw comments in the source,including ''' and original indent
def sampcd_extract_and_run(srccom, name, htype="def", hname=""):
"""
......@@ -148,14 +121,12 @@ def sampcd_extract_and_run(srccom, name, htype="def", hname=""):
print("execution result:")
sampcd_begins = find_all(srccom, " code-block:: python")
sampre_begins = find_all(srccom, " code-block:: text")
if len(sampcd_begins) == 0:
print_header(htype, hname)
'''
detect sample codes using >>> to format
and consider this situation as wrong
'''
print_header(htype, hname)
if srccom.find("Examples:") != -1:
print("----example code check----\n")
if srccom.find(">>>") != -1:
......@@ -167,23 +138,9 @@ def sampcd_extract_and_run(srccom, name, htype="def", hname=""):
else:
print("Error: No sample code!\n")
result = False
if len(sampcd_begins) != len(sampre_begins) and hname not in wlist_return:
print_header(htype, hname)
if len(sampre_begins) == 0:
print("Error: Cannot find the return result of the sample code.")
else:
print("Error: Found %s result but %s python file." %
(len(sampre_begins), len(sampcd_begins)))
print(
"If you think the sample code of this api is not suitable for the return result, please add the white list in FIle: tools/wlist_return.json first. And you must have one TPM(saxon-zh or swtkiwi or Boyan-Liu) approve for the white list."
)
result = False
else:
for y in range(1, len(sampcd_begins) + 1):
sampcd_begin = sampcd_begins[y - 1]
sampcd = srccom[sampcd_begin:]
sampcd = return_sample(htype, sampcd, 'python')
if sampcd == None:
sampcd = srccom[sampcd_begin + len(" code-block:: python") + 1:]
sampcd = sampcd.split("\n")
# remove starting empty lines
......@@ -211,6 +168,7 @@ def sampcd_extract_and_run(srccom, name, htype="def", hname=""):
sampcd = '\nimport os\n' + 'os.environ["CUDA_VISIBLE_DEVICES"] = ""\n' + sampcd
if sys.argv[1] == "gpu":
sampcd = '\nimport os\n' + 'os.environ["CUDA_VISIBLE_DEVICES"] = "0"\n' + sampcd
sampcd += '\nprint(' + '\"' + name + ' sample code is executed successfully!\")'
if len(sampcd_begins) > 1:
tfname = name + "_example_" + str(y) + ".py"
......@@ -227,46 +185,13 @@ def sampcd_extract_and_run(srccom, name, htype="def", hname=""):
print("Error: fail to parse python version!")
result = False
exit(1)
subprc = subprocess.Popen(
cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
output, error = subprc.communicate()
if output == "" and len(sampre_begins) != 0:
print_header(htype, hname)
print(
"Error: Your sample code have returned a result, but execute sample code don't get result!"
)
print(
"If you think the sample code of this api is not suitable for the return result, please add the white list in FIle: tools/wlist_return.json first. And you must have one TPM(saxon-zh or swtkiwi or Boyan-Liu) approve for the white list."
)
result = False
elif len(sampcd_begins) == len(sampre_begins):
sampre_begin = sampre_begins[y - 1]
sampre = return_sample(htype, srccom[sampre_begin:], 'text')
if output != sampre:
print_header(htype, hname)
print(
"Error: Mistake found in the return result of sample code."
)
print("There maybe three reasons for this error:")
print(
"1. The input of the sample code is a random number.Please add the white list in FIle: tools/return_white_list.txt first .And you must have one TPM(saxon-zh or swtkiwi or Boyan-Liu) approve for the white list."
)
print(
"2. The return value of the sample code is incorrect. Please check the code and reset the return value."
)
print(
"3. If you think the sample code of this api is not suitable for the return result, please add the white list in FIle: tools/wlist_return.json first. And you must have one TPM(saxon-zh or swtkiwi or Boyan-Liu) approve for the white list."
)
result = False
else:
if name not in wlist_return:
print_header(htype, hname)
print(
"Error: If you think the sample code of this api is not suitable for the return result, please add the white list in FIle: tools/wlist_return.json first. And you must have one TPM(saxon-zh or swtkiwi or Boyan-Liu) approve for the white list."
)
result = False
msg = "".join(output.decode(encoding='utf-8'))
err = "".join(error.decode(encoding='utf-8'))
if subprc.returncode != 0:
print("\nSample code error found in ", name, ":\n")
sampcd_header_print(name, sampcd, htype, hname)
......@@ -275,6 +200,8 @@ def sampcd_extract_and_run(srccom, name, htype="def", hname=""):
print(err)
print(msg)
result = False
# msg is the returned code execution report
#os.remove("samplecode_temp/" + tfname)
return result
......@@ -351,6 +278,7 @@ def srccoms_extract(srcfile, wlist):
Returns:
result: True or False
"""
process_result = True
srcc = srcfile.read()
# 2. get defs and classes header line number
......@@ -414,7 +342,6 @@ def srccoms_extract(srcfile, wlist):
opname) # ops.py also has normal formatted functions
# use list 'handled' to mark the functions have been handled here
# which will be ignored in the following step
for i in range(0, len(srcls)):
if srcls[i].startswith(
'def '): # a function header is detected in line i
......@@ -430,12 +357,14 @@ def srccoms_extract(srcfile, wlist):
continue
fcombody = single_defcom_extract(i, srcls)
if fcombody == "": # if no comment
print_header("def", fn)
print("WARNING: no comments in function ", fn,
", but it deserves.")
continue
else:
if not sampcd_extract_and_run(fcombody, fn, "def", fn):
process_result = False
if srcls[i].startswith('class '):
c_header = srcls[i].replace(" ", '')
cn = c_header[len('class'):c_header.find('(')] # class name
......@@ -504,6 +433,7 @@ def srccoms_extract(srcfile, wlist):
if not sampcd_extract_and_run(
thismtdcom, name, "method", name):
process_result = False
return process_result
......@@ -582,9 +512,8 @@ def get_incrementapi():
with open(API_spec) as f:
for line in f.readlines():
api = line.split(' ', 1)[0]
if line.find('document') != -1:
md5 = line.split("'document', ")[1].replace(
')', '').replace('\n', '')
md5 = line.split("'document', ")[1].replace(')', '').replace(
'\n', '')
api_md5[api] = md5
return api_md5
......@@ -608,29 +537,24 @@ gpu_not_white = [
]
def get_wlist(file_name):
def get_wlist():
'''
this function will get the white list of API.
Args:
file_name(file): white file name.
Returns:
wlist: a list of API that should not trigger the example check .
'''
wlist = []
with open(file_name, 'r') as load_f:
with open("wlist.json", 'r') as load_f:
load_dict = json.load(load_f)
for key in load_dict:
wlist = wlist + load_dict[key]
return wlist
wlist = get_wlist('wlist.json')
wlist_return = get_wlist('wlist_return.json')
wlist = get_wlist()
if len(sys.argv) < 2:
print("Error: inadequate number of arguments")
......
{
"wlist_return":[
"justfor_example"
]
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册