-
Notifications
You must be signed in to change notification settings - Fork 868
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Ensure lines after heading in loose list are properly detabbed
This is a weird edge case. Normally, detabbing would be handled by the `ListIndentProcessor`. However, in this one case, that class's `get_level` method would need to return a different result than in any other case. As there is no way to easily determine this specific case from that class, we make the adjustment directly in the `HashHeaderProcessor` class. Fixes #1433.
- Loading branch information
Showing
4 changed files
with
144 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -32,6 +32,7 @@ customizable | |
dedent | ||
deliminators | ||
deregister | ||
detabbed | ||
Dmitry | ||
docdata | ||
ElementTree | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,137 @@ | ||
""" | ||
Python Markdown | ||
A Python implementation of John Gruber's Markdown. | ||
Documentation: https://python-markdown.github.io/ | ||
GitHub: https://github.com/Python-Markdown/markdown/ | ||
PyPI: https://pypi.org/project/Markdown/ | ||
Started by Manfred Stienstra (http://www.dwerg.net/). | ||
Maintained for a few years by Yuri Takhteyev (http://www.freewisdom.org). | ||
Currently maintained by Waylan Limberg (https://github.com/waylan), | ||
Dmitry Shachnev (https://github.com/mitya57) and Isaac Muse (https://github.com/facelessuser). | ||
Copyright 2007-2024 The Python Markdown Project (v. 1.7 and later) | ||
Copyright 2004, 2005, 2006 Yuri Takhteyev (v. 0.2-1.6b) | ||
Copyright 2004 Manfred Stienstra (the original version) | ||
License: BSD (see LICENSE.md for details). | ||
""" | ||
|
||
import unittest | ||
from markdown.test_tools import TestCase | ||
|
||
|
||
class TestUnorderedLists(TestCase): | ||
|
||
# TODO: Move legacy tests here | ||
|
||
def test_header_and_paragraph_no_blank_line_loose_list(self): | ||
self.assertMarkdownRenders( | ||
self.dedent( | ||
""" | ||
- ### List 1 | ||
Entry 1.1 | ||
- ### List 2 | ||
Entry 2.1 | ||
""" | ||
), | ||
self.dedent( | ||
""" | ||
<ul> | ||
<li> | ||
<h3>List 1</h3> | ||
<p>Entry 1.1</p> | ||
</li> | ||
<li> | ||
<h3>List 2</h3> | ||
<p>Entry 2.1</p> | ||
</li> | ||
</ul> | ||
""" | ||
) | ||
) | ||
|
||
# Note: This is strange. Any other element on first line of list item would get very | ||
# different behavior. However, as a heading can only ever be one line, this is the | ||
# correct behavior. In fact, `markdown.pl` behaves this way with no indentation. | ||
def test_header_and_paragraph_no_blank_line_loose_list_no_indent(self): | ||
self.assertMarkdownRenders( | ||
self.dedent( | ||
""" | ||
- ### List 1 | ||
Entry 1.1 | ||
- ### List 2 | ||
Entry 2.1 | ||
""" | ||
), | ||
self.dedent( | ||
""" | ||
<ul> | ||
<li> | ||
<h3>List 1</h3> | ||
<p>Entry 1.1</p> | ||
</li> | ||
<li> | ||
<h3>List 2</h3> | ||
<p>Entry 2.1</p> | ||
</li> | ||
</ul> | ||
""" | ||
) | ||
) | ||
|
||
# TODO: Possibly change this behavior. While this test follows the behavior | ||
# of `markdown.pl`, it is likely surprising to most users. In fact, actual | ||
# behavior is to return the same results as for a loose list. | ||
@unittest.skip('This behaves as a loose list in Python-Markdown') | ||
def test_header_and_paragraph_no_blank_line_tight_list(self): | ||
self.assertMarkdownRenders( | ||
self.dedent( | ||
""" | ||
- ### List 1 | ||
Entry 1.1 | ||
- ### List 2 | ||
Entry 2.1 | ||
""" | ||
), | ||
self.dedent( | ||
""" | ||
<ul> | ||
<li>### List 1 | ||
Entry 1.1</li> | ||
<li>### List 2 | ||
Entry 2.1</li> | ||
</ul> | ||
""" | ||
) | ||
) | ||
|
||
# TODO: Possibly change this behavior. While this test follows the behavior | ||
# of `markdown.pl`, it is likely surprising to most users. In fact, actual | ||
# behavior is to return the same results as for a loose list. | ||
@unittest.skip('This behaves as a loose list in Python-Markdown') | ||
def test_header_and_paragraph_no_blank_line_tight_list_no_indent(self): | ||
self.assertMarkdownRenders( | ||
self.dedent( | ||
""" | ||
- ### List 1 | ||
Entry 1.1 | ||
- ### List 2 | ||
Entry 2.1 | ||
""" | ||
), | ||
self.dedent( | ||
""" | ||
<ul> | ||
<li>### List 1 | ||
Entry 1.1</li> | ||
<li>### List 2 | ||
Entry 2.1</li> | ||
</ul> | ||
""" | ||
) | ||
) |