Commit 0b99bde8 authored by Jason R. Coombs's avatar Jason R. Coombs

Created PEP420PackageFinder, whose .find method can be used to find any suitable directory.

parent d3969808
...@@ -79,10 +79,7 @@ class PackageFinder(object): ...@@ -79,10 +79,7 @@ class PackageFinder(object):
@staticmethod @staticmethod
def _looks_like_package(path): def _looks_like_package(path):
return ( return os.path.isfile(os.path.join(path, '__init__.py'))
os.path.isfile(os.path.join(path, '__init__.py'))
or sys.version_info[:2] >= (3, 3) # PEP 420
)
@staticmethod @staticmethod
def _build_filter(*patterns): def _build_filter(*patterns):
...@@ -92,6 +89,11 @@ class PackageFinder(object): ...@@ -92,6 +89,11 @@ class PackageFinder(object):
""" """
return lambda name: any(fnmatchcase(name, pat=pat) for pat in patterns) return lambda name: any(fnmatchcase(name, pat=pat) for pat in patterns)
class PEP420PackageFinder(PackageFinder):
@staticmethod
def _looks_like_package(path):
return True
find_packages = PackageFinder.find find_packages = PackageFinder.find
setup = distutils.core.setup setup = distutils.core.setup
......
"""Tests for setuptools.find_packages().""" """Tests for setuptools.find_packages()."""
import os import os
import shutil import shutil
import sys
import tempfile import tempfile
import unittest import unittest
import setuptools
from setuptools import find_packages from setuptools import find_packages
from setuptools.tests.py26compat import skipIf
PEP420 = sys.version_info[:2] >= (3, 3)
find_420_packages = setuptools.PEP420PackageFinder.find
class TestFindPackages(unittest.TestCase): class TestFindPackages(unittest.TestCase):
...@@ -63,7 +60,6 @@ class TestFindPackages(unittest.TestCase): ...@@ -63,7 +60,6 @@ class TestFindPackages(unittest.TestCase):
fp.close() fp.close()
return path return path
@skipIf(PEP420, 'Not a PEP 420 env')
def test_regular_package(self): def test_regular_package(self):
self._touch('__init__.py', self.pkg_dir) self._touch('__init__.py', self.pkg_dir)
packages = find_packages(self.dist_dir) packages = find_packages(self.dist_dir)
...@@ -90,35 +86,30 @@ class TestFindPackages(unittest.TestCase): ...@@ -90,35 +86,30 @@ class TestFindPackages(unittest.TestCase):
def _assert_packages(self, actual, expected): def _assert_packages(self, actual, expected):
self.assertEqual(set(actual), set(expected)) self.assertEqual(set(actual), set(expected))
@skipIf(not PEP420, 'PEP 420 only')
def test_pep420_ns_package(self): def test_pep420_ns_package(self):
packages = find_packages( packages = find_420_packages(
self.dist_dir, include=['pkg*'], exclude=['pkg.subpkg.assets']) self.dist_dir, include=['pkg*'], exclude=['pkg.subpkg.assets'])
self._assert_packages(packages, ['pkg', 'pkg.nspkg', 'pkg.subpkg']) self._assert_packages(packages, ['pkg', 'pkg.nspkg', 'pkg.subpkg'])
@skipIf(not PEP420, 'PEP 420 only')
def test_pep420_ns_package_no_includes(self): def test_pep420_ns_package_no_includes(self):
packages = find_packages( packages = find_420_packages(
self.dist_dir, exclude=['pkg.subpkg.assets']) self.dist_dir, exclude=['pkg.subpkg.assets'])
self._assert_packages(packages, ['docs', 'pkg', 'pkg.nspkg', 'pkg.subpkg']) self._assert_packages(packages, ['docs', 'pkg', 'pkg.nspkg', 'pkg.subpkg'])
@skipIf(not PEP420, 'PEP 420 only')
def test_pep420_ns_package_no_includes_or_excludes(self): def test_pep420_ns_package_no_includes_or_excludes(self):
packages = find_packages(self.dist_dir) packages = find_420_packages(self.dist_dir)
expected = [ expected = [
'docs', 'pkg', 'pkg.nspkg', 'pkg.subpkg', 'pkg.subpkg.assets'] 'docs', 'pkg', 'pkg.nspkg', 'pkg.subpkg', 'pkg.subpkg.assets']
self._assert_packages(packages, expected) self._assert_packages(packages, expected)
@skipIf(not PEP420, 'PEP 420 only')
def test_regular_package_with_nested_pep420_ns_packages(self): def test_regular_package_with_nested_pep420_ns_packages(self):
self._touch('__init__.py', self.pkg_dir) self._touch('__init__.py', self.pkg_dir)
packages = find_packages( packages = find_420_packages(
self.dist_dir, exclude=['docs', 'pkg.subpkg.assets']) self.dist_dir, exclude=['docs', 'pkg.subpkg.assets'])
self._assert_packages(packages, ['pkg', 'pkg.nspkg', 'pkg.subpkg']) self._assert_packages(packages, ['pkg', 'pkg.nspkg', 'pkg.subpkg'])
@skipIf(not PEP420, 'PEP 420 only')
def test_pep420_ns_package_no_non_package_dirs(self): def test_pep420_ns_package_no_non_package_dirs(self):
shutil.rmtree(self.docs_dir) shutil.rmtree(self.docs_dir)
shutil.rmtree(os.path.join(self.dist_dir, 'pkg/subpkg/assets')) shutil.rmtree(os.path.join(self.dist_dir, 'pkg/subpkg/assets'))
packages = find_packages(self.dist_dir) packages = find_420_packages(self.dist_dir)
self._assert_packages(packages, ['pkg', 'pkg.nspkg', 'pkg.subpkg']) self._assert_packages(packages, ['pkg', 'pkg.nspkg', 'pkg.subpkg'])
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment