2011-06-01 2 views
9

Я пытаюсь ограничить nosetests в определенном каталоге, однако во время тестового запуска он включает в себя родительские каталоги каталога, который я нацелен, и при этом выдает ошибки.Nosetest, в том числе нежелательные родительские каталоги

Вот ключевые элементы выхода из тестового прогона:

nose.importer: DEBUG: Add path /projects/myproject/myproject/specs 
nose.importer: DEBUG: Add path /projects/myproject/myproject 
nose.importer: DEBUG: Add path /projects/myproject 
nose.importer: DEBUG: insert /projects/myproject into sys.path 

Я использую buildout с pbp.recipe.noserunner. Вот соответствующий /projects/myproject/buildout.cfg раздел:

[specs] 
recipe = pbp.recipe.noserunner 
eggs = 
    pbp.recipe.noserunner 
    ${buildout:eggs} 
    figleaf 
    pinocchio 
working-directory = 
    myproject/specs 
defaults = 
    -vvv 
    --exe 
    --include ^(it|ensure|must|should|specs?|examples?) 
    --include (specs?(.py)?|examples?(.py)?)$ 
    --with-spec 
    --spec-color 

Я также попытался установить where=myproject/specs в качестве одного из параметров defaults, чтобы помочь ограничить импорт, но до сих пор нет радости.

Любые предложения о том, куда я иду не так?

Edit:

Я пытался --exclude родительские каталоги, но не радость.

ответ

5

Я полагаю, что вы ожидаете следующего поведения.

nose.importer: DEBUG: Add path /projects/myproject 
nose.importer: DEBUG: insert /projects/myproject into sys.path 

Почему бы не попробовать --match или --exclude шаблон для ограничения испытаний, установленные?

Try:

--exclude myproject/myproject 

проверить исходный код nose.importer: нос recursivly add_path родителей пакеты спецификации. Я думаю, что вы не можете обойти это, если не создаете конкретного импортера ... Я не знаю, возможно ли это это API-интерфейс носа.

def add_path(path, config=None): 
    """Ensure that the path, or the root of the current package (if 
    path is in a package), is in sys.path. 
    """ 

    # FIXME add any src-looking dirs seen too... need to get config for that 

    log.debug('Add path %s' % path)  
    if not path: 
     return [] 
    added = [] 
    parent = os.path.dirname(path) 
    if (parent 
     and os.path.exists(os.path.join(path, '__init__.py'))): 
     added.extend(add_path(parent, config)) 
    elif not path in sys.path: 
     log.debug("insert %s into sys.path", path) 
     sys.path.insert(0, path) 
     added.append(path) 
    if config and config.srcDirs: 
     for dirname in config.srcDirs: 
      dirpath = os.path.join(path, dirname) 
      if os.path.isdir(dirpath): 
       sys.path.insert(0, dirpath) 
       added.append(dirpath) 
    return added 


def remove_path(path): 
    log.debug('Remove path %s' % path) 
    if path in sys.path: 
     sys.path.remove(path) 
+0

Thanks; Я должен был понять, что лучший способ исследовать - это прочитать источник! –

+1

Итак, убедитесь, что у вас нет '__init __. Py' (или' __init __. Pyc'), где это не требуется, не так ли? – Danimal

Смежные вопросы