python – 为什么运行“setup.py test”运行我的控制台脚本?

我非常简单的示例项目包含:

addtest/
  setup.py
  addtest/
    __init__.py
    __main__.py
    app.py

我的app.py只是:

def main():
    raise SystemExit("Command line entry point called.")

我的__main__.py只是:

from addtest.app import main
main()

我的setup.py包含:

from setuptools import setup,find_packages

setup(
    name='AddTest',version='1.0',packages=find_packages(),entry_points={
        'console_scripts': ['addtest = addtest.app:main']
    },)

我希望运行python setup.py测试不会做任何事情,因为没有编写单元测试.但是,在一个干净的virtualenv(Ubuntu 18.04.1上的Python 3.6.6)中运行它给了我:

$python setup.py test
running test
running egg_info
writing AddTest.egg-info/PKG-INFO
writing dependency_links to AddTest.egg-info/dependency_links.txt
writing entry points to AddTest.egg-info/entry_points.txt
writing top-level names to AddTest.egg-info/top_level.txt
reading manifest file 'AddTest.egg-info/SOURCES.txt'
writing manifest file 'AddTest.egg-info/SOURCES.txt'
running build_ext
Command line entry point called.

请注意调用的命令行入口点.这意味着它正在调用它从我的__main__.py生成的控制台脚本(或者可能只是调用python -m addtest).

为什么setup.py在我希望它运行测试时调用控制台脚本?进一步检查脚本的执行情况表明sys.argv是[‘setup.py’,’test’] – 为什么?

最佳答案
setuptools中的测试扫描程序将在子目录中找到的任何* .py文件中查找测试,但__init__.py除外.是的,这包括__main__.py,它将在其上调用__import __(),导致其主套件被执行.

如果你想能够运行python -m addtest并运行你的__main__.py代码,你可能想要添加标准’仅当这是真正的主要’保护:

if __name__ == "__main__":
   ...

(然后,如果你执行python -m代码将运行,但如果文件是通过setup.py test加载的,它将无法运行)

相关文章

Python中的函数(二) 在上一篇文章中提到了Python中函数的定...
Python中的字符串 可能大多数人在学习C语言的时候,最先接触...
Python 面向对象编程(一) 虽然Python是解释性语言,但是它...
Python面向对象编程(二) 在前面一篇文章中谈到了类的基本定...
Python中的函数(一) 接触过C语言的朋友对函数这个词肯定非...
在windows下如何快速搭建web.py开发框架 用Python进行web开发...