This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

Author smsilb
Recipients docs@python, smsilb
Date 2017-05-10.20:49:48
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1494449389.02.0.790150087603.issue30337@psf.upfronthosting.co.za>
In-reply-to
Content
Hi there! 

This is my first submission to the bug tracker, so I apologize if I'm missing some formatting here.

I've found what's either vague documentation for the 'prefix' parameter of `pgkutil.walk_packages` or a bug. The method implies that it will only import submodules of the provided path, but if the prefix parameter is not filled, this method will import a module with the same name from outside the path -- so long as it exists in `sys.modules`. I'm unsure if this is due to the documentation not specifying that prefix should always be used when path is set, or if this is a bug (I can provide a fix if it's a bug).

Steps to reproduce:

Create a directory with a nested package with the same name as a package outside that directory, e.g.:

|_ test1
  |_ __init__.py
  |_ should_not_be_included.py
|_ test2
  |_ test1
    |_ __init__.py
    |_ test1
      |_ __init__.py
      |_ should_be_included.py

`list(pkgutil.walk_packages('test2'))` will contain 'should_not_be_included.py' instead of 'should_be_included.py'.

Thank you!

Sam Silberstein
History
Date User Action Args
2017-05-10 20:49:49smsilbsetrecipients: + smsilb, docs@python
2017-05-10 20:49:49smsilbsetmessageid: <1494449389.02.0.790150087603.issue30337@psf.upfronthosting.co.za>
2017-05-10 20:49:48smsilblinkissue30337 messages
2017-05-10 20:49:48smsilbcreate