2011-06-01 10 views
9

che sto cercando di limitare nosetests in una directory specifica, tuttavia durante la prova di funzionamento è compreso le directory principali del dir sto rivolte e così facendo getta errori.Nosetest tra cui directory superiori indesiderati

Ecco gli elementi chiave di uscita dalla pista di prova:

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 

sto usando buildout con pbp.recipe.noserunner. Ecco il relativo /projects/myproject/buildout.cfg sezione:

[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 

Ho anche provato a installare where=myproject/specs come uno dei parametri defaults per contribuire a limitare l'importazione, ma ancora nessuna gioia.

Tutti i suggerimenti su dove sto andando male?

Edit:

ho cercato di --exclude le directory superiori, ma nessuna gioia.

risposta

5

Suppongo che vi aspettate il seguente comportamento.

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

perché non provare una o un modello --match--exclude per limitare i test stabiliti?

Prova:

--exclude myproject/myproject 

posso controllare il codice sorgente di nose.importer: naso recursivly add_path i pacchetti genitori di specifiche. Penso che non si può ignorare questo a meno che non si crea un importatore specifica ... io non non so se questo è possibile questa API il naso.

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

Grazie; Avrei dovuto capire che il modo migliore per investigare è leggere la fonte! –

+1

Quindi, assicurati di non avere un '__init __. Py' (o' __init __. Pyc') dove non è richiesto, giusto? – Danimal

Problemi correlati