概述
我非常简单的示例项目包含:
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’] – 为什么?
如果你想能够运行python -m addtest并运行你的__main__.py代码,你可能想要添加标准’仅当这是真正的主要’保护:
if __name__ == "__main__":
...
(然后,如果你执行python -m代码将运行,但如果文件是通过setup.py test加载的,它将无法运行)
总结
以上是编程之家为你收集整理的python – 为什么运行“setup.py test”运行我的控制台脚本?全部内容,希望文章能够帮你解决python – 为什么运行“setup.py test”运行我的控制台脚本?所遇到的程序开发问题。
如果您也喜欢它,动动您的小指点个赞吧