2020-04-22 22:29:27 +00:00
|
|
|
#!/usr/bin/env python3.8
|
|
|
|
|
|
|
|
import argparse
|
|
|
|
import os
|
|
|
|
import glob
|
|
|
|
import tarfile
|
|
|
|
import zipfile
|
|
|
|
import shutil
|
2020-05-02 04:23:06 +00:00
|
|
|
import pathlib
|
2020-04-22 22:29:27 +00:00
|
|
|
import sys
|
|
|
|
|
|
|
|
from typing import Generator, Any
|
|
|
|
|
|
|
|
sys.path.insert(0, ".")
|
2020-05-02 04:23:06 +00:00
|
|
|
|
2020-04-22 22:29:27 +00:00
|
|
|
from pegen import build
|
|
|
|
from scripts import test_parse_directory
|
|
|
|
|
2020-05-02 04:23:06 +00:00
|
|
|
HERE = pathlib.Path(__file__).resolve().parent
|
|
|
|
|
2020-04-22 22:29:27 +00:00
|
|
|
argparser = argparse.ArgumentParser(
|
2021-08-12 16:37:30 +00:00
|
|
|
prog="test_pypi_packages",
|
|
|
|
description="Helper program to test parsing PyPI packages",
|
2020-04-22 22:29:27 +00:00
|
|
|
)
|
|
|
|
argparser.add_argument(
|
|
|
|
"-t", "--tree", action="count", help="Compare parse tree to official AST", default=0
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def get_packages() -> Generator[str, None, None]:
|
|
|
|
all_packages = (
|
|
|
|
glob.glob("./data/pypi/*.tar.gz")
|
|
|
|
+ glob.glob("./data/pypi/*.zip")
|
|
|
|
+ glob.glob("./data/pypi/*.tgz")
|
|
|
|
)
|
|
|
|
for package in all_packages:
|
|
|
|
yield package
|
|
|
|
|
|
|
|
|
|
|
|
def extract_files(filename: str) -> None:
|
|
|
|
savedir = os.path.join("data", "pypi")
|
|
|
|
if tarfile.is_tarfile(filename):
|
|
|
|
tarfile.open(filename).extractall(savedir)
|
|
|
|
elif zipfile.is_zipfile(filename):
|
|
|
|
zipfile.ZipFile(filename).extractall(savedir)
|
|
|
|
else:
|
|
|
|
raise ValueError(f"Could not identify type of compressed file {filename}")
|
|
|
|
|
|
|
|
|
|
|
|
def find_dirname(package_name: str) -> str:
|
|
|
|
for name in os.listdir(os.path.join("data", "pypi")):
|
|
|
|
full_path = os.path.join("data", "pypi", name)
|
|
|
|
if os.path.isdir(full_path) and name in package_name:
|
|
|
|
return full_path
|
|
|
|
assert False # This is to fix mypy, should never be reached
|
|
|
|
|
|
|
|
|
2020-05-25 19:51:58 +00:00
|
|
|
def run_tests(dirname: str, tree: int) -> int:
|
2020-04-22 22:29:27 +00:00
|
|
|
return test_parse_directory.parse_directory(
|
|
|
|
dirname,
|
|
|
|
verbose=False,
|
2020-06-06 04:21:40 +00:00
|
|
|
excluded_files=[],
|
2020-04-22 22:29:27 +00:00
|
|
|
tree_arg=tree,
|
|
|
|
short=True,
|
2020-06-06 04:21:40 +00:00
|
|
|
mode=1 if tree else 0,
|
2020-05-02 04:23:06 +00:00
|
|
|
parser="pegen",
|
2020-04-22 22:29:27 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def main() -> None:
|
|
|
|
args = argparser.parse_args()
|
|
|
|
tree = args.tree
|
|
|
|
|
|
|
|
for package in get_packages():
|
|
|
|
print(f"Extracting files from {package}... ", end="")
|
|
|
|
try:
|
|
|
|
extract_files(package)
|
|
|
|
print("Done")
|
|
|
|
except ValueError as e:
|
|
|
|
print(e)
|
|
|
|
continue
|
|
|
|
|
|
|
|
print(f"Trying to parse all python files ... ")
|
|
|
|
dirname = find_dirname(package)
|
2020-05-25 19:51:58 +00:00
|
|
|
status = run_tests(dirname, tree)
|
2020-04-22 22:29:27 +00:00
|
|
|
if status == 0:
|
|
|
|
shutil.rmtree(dirname)
|
|
|
|
else:
|
|
|
|
print(f"Failed to parse {dirname}")
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|