Параметр entry_script точки Setuptools не найден с установкой, но найден с помощью

В моем пакете указана точка входа setup.py:

# -*- coding: utf-8 -*-
from setuptools import setup

setup(
    name='fbuildbot',
    version='0.1',
    ...
    entry_points={
        'console_scripts': [
            'create = create:main',
        ],
    },
    install_requires=[
        "cookiecutter",
    ],
)

Thing is. Если я делаю python setup.py develop, я могу выполнить команду просто отлично, но если я ее установлю с помощью python setup.py install, процедура установки будет работать правильно, но консоль script завершится с ошибкой ImportError:

Traceback (most recent call last):
  File "/home/matias/.venvs/fbuild/bin/create", line 8, in <module>
    load_entry_point('fbuildbot==0.1', 'console_scripts', 'create')()
  File "/home/matias/.venvs/fbuild/local/lib/python2.7/site-packages/setuptools-0.6c11-py2.7.egg/pkg_resources.py", line 318, in load_entry_point
  File "/home/matias/.venvs/fbuild/local/lib/python2.7/site-packages/setuptools-0.6c11-py2.7.egg/pkg_resources.py", line 2221, in load_entry_point
  File "/home/matias/.venvs/fbuild/local/lib/python2.7/site-packages/setuptools-0.6c11-py2.7.egg/pkg_resources.py", line 1954, in load
ImportError: No module named create

Очевидно, что он не правильно настроил пакет на pythonpath. Я думал, что это потому, что у меня есть script едва ли на верхнем уровне. Поэтому я попробовал добавить все пакеты в пакет, переместив все важные части во внутренний модуль и соответственно изменив setup.py:

# -*- coding: utf-8 -*-
from setuptools import setup

setup(
    name='fbuildbot',
    version='0.1',
    description="Buildbot configuration generator for fbuild",
    ...
    packages=['fbuildbot', ],
    entry_points={
        'console_scripts': [
            'create = fbuildbot.create:main',
        ],
    },
    install_requires=[
        "cookiecutter",
    ],
)

Но он не работает с тем же сообщением (с обновленным путем, очевидно).

Ясно, что я делаю что-то не так. Что это может быть?

Ответ 1

Проблема заключается в вашем аргументе пакетов. Вы указываете только:

packages=['fbuildbot', ],

not

packages=['fbuildbot', 'fbuildbot.create'],

поэтому ваша установка фактически не устанавливает модуль "create". Имеет смысл, что его невозможно найти.

Я бы порекомендовал утилиту find_packages

from setuptools import setup, find_packages

setup(
    ...
    packages=find_packages(),
    entry_points={
        'console_scripts': [
            'create = fbuildbot.create:main',
        ],
    },
    ...
)

который будет обрабатывать все это для вас.