mirror of
https://github.com/getpelican/pelican.git
synced 2025-10-15 20:28:56 +02:00
Merge pull request #845 from Rogdham/case-insensitive_caterogy_tag
Make tags and cats case insensitive. Fixes #704.
This commit is contained in:
commit
50505dfd71
2 changed files with 48 additions and 11 deletions
|
|
@ -89,17 +89,29 @@ class TestArticlesGenerator(unittest.TestCase):
|
||||||
['This is an article without category !', 'published',
|
['This is an article without category !', 'published',
|
||||||
'TestCategory', 'article'],
|
'TestCategory', 'article'],
|
||||||
['This is a super article !', 'published', 'yeah', 'article'],
|
['This is a super article !', 'published', 'yeah', 'article'],
|
||||||
['マックOS X 10.8でパイソンとVirtualenvをインストールと設定', 'published', '指導書', 'article']
|
['マックOS X 10.8でパイソンとVirtualenvをインストールと設定',
|
||||||
|
'published', '指導書', 'article']
|
||||||
]
|
]
|
||||||
self.assertEqual(sorted(articles_expected), sorted(articles))
|
self.assertEqual(sorted(articles_expected), sorted(articles))
|
||||||
|
|
||||||
def test_generate_categories(self):
|
def test_generate_categories(self):
|
||||||
|
|
||||||
generator = self.get_populated_generator()
|
generator = self.get_populated_generator()
|
||||||
|
# test for name
|
||||||
|
# categories are grouped by slug; if two categories have the same slug
|
||||||
|
# but different names they will be grouped together, the first one in
|
||||||
|
# terms of process order will define the name for that category
|
||||||
categories = [cat.name for cat, _ in generator.categories]
|
categories = [cat.name for cat, _ in generator.categories]
|
||||||
categories_expected = ['Default', 'TestCategory', 'Yeah', 'test',
|
categories_alternatives = (
|
||||||
'yeah', '指導書']
|
sorted(['Default', 'TestCategory', 'Yeah', 'test', '指導書']),
|
||||||
self.assertEqual(categories, categories_expected)
|
sorted(['Default', 'TestCategory', 'yeah', 'test', '指導書']),
|
||||||
|
)
|
||||||
|
self.assertTrue(sorted(categories) in categories_alternatives)
|
||||||
|
# test for slug
|
||||||
|
categories = [cat.slug for cat, _ in generator.categories]
|
||||||
|
categories_expected = ['default', 'testcategory', 'yeah', 'test',
|
||||||
|
'zhi-dao-shu']
|
||||||
|
self.assertEqual(sorted(categories), sorted(categories_expected))
|
||||||
|
|
||||||
def test_do_not_use_folder_as_category(self):
|
def test_do_not_use_folder_as_category(self):
|
||||||
|
|
||||||
|
|
@ -113,9 +125,20 @@ class TestArticlesGenerator(unittest.TestCase):
|
||||||
CUR_DIR, _DEFAULT_CONFIG['THEME'], None,
|
CUR_DIR, _DEFAULT_CONFIG['THEME'], None,
|
||||||
_DEFAULT_CONFIG['MARKUP'])
|
_DEFAULT_CONFIG['MARKUP'])
|
||||||
generator.generate_context()
|
generator.generate_context()
|
||||||
|
# test for name
|
||||||
|
# categories are grouped by slug; if two categories have the same slug
|
||||||
|
# but different names they will be grouped together, the first one in
|
||||||
|
# terms of process order will define the name for that category
|
||||||
categories = [cat.name for cat, _ in generator.categories]
|
categories = [cat.name for cat, _ in generator.categories]
|
||||||
self.assertEqual(categories, ['Default', 'Yeah', 'test', 'yeah', '指導書'])
|
categories_alternatives = (
|
||||||
|
sorted(['Default', 'Yeah', 'test', '指導書']),
|
||||||
|
sorted(['Default', 'yeah', 'test', '指導書']),
|
||||||
|
)
|
||||||
|
self.assertTrue(sorted(categories) in categories_alternatives)
|
||||||
|
# test for slug
|
||||||
|
categories = [cat.slug for cat, _ in generator.categories]
|
||||||
|
categories_expected = ['default', 'yeah', 'test', 'zhi-dao-shu']
|
||||||
|
self.assertEqual(sorted(categories), sorted(categories_expected))
|
||||||
|
|
||||||
def test_direct_templates_save_as_default(self):
|
def test_direct_templates_save_as_default(self):
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -13,21 +13,35 @@ logger = logging.getLogger(__name__)
|
||||||
@functools.total_ordering
|
@functools.total_ordering
|
||||||
class URLWrapper(object):
|
class URLWrapper(object):
|
||||||
def __init__(self, name, settings):
|
def __init__(self, name, settings):
|
||||||
|
# next 2 lines are redundant with the setter of the name property
|
||||||
|
# but are here for clarity
|
||||||
|
self._name = name
|
||||||
|
self.slug = slugify(name)
|
||||||
self.name = name
|
self.name = name
|
||||||
self.slug = slugify(self.name)
|
|
||||||
self.settings = settings
|
self.settings = settings
|
||||||
|
|
||||||
|
@property
|
||||||
|
def name(self):
|
||||||
|
return self._name
|
||||||
|
|
||||||
|
@name.setter
|
||||||
|
def name(self, name):
|
||||||
|
self._name = name
|
||||||
|
self.slug = slugify(name)
|
||||||
|
|
||||||
def as_dict(self):
|
def as_dict(self):
|
||||||
return self.__dict__
|
d = self.__dict__
|
||||||
|
d['name'] = self.name
|
||||||
|
return d
|
||||||
|
|
||||||
def __hash__(self):
|
def __hash__(self):
|
||||||
return hash(self.name)
|
return hash(self.slug)
|
||||||
|
|
||||||
def _key(self):
|
def _key(self):
|
||||||
return self.name
|
return self.slug
|
||||||
|
|
||||||
def _normalize_key(self, key):
|
def _normalize_key(self, key):
|
||||||
return six.text_type(key)
|
return six.text_type(slugify(key))
|
||||||
|
|
||||||
def __eq__(self, other):
|
def __eq__(self, other):
|
||||||
return self._key() == self._normalize_key(other)
|
return self._key() == self._normalize_key(other)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue