mirror of
https://github.com/khoaliber/khoj.git
synced 2026-03-02 13:18:18 +00:00
Track ancestor headings for each org-mode entry in org-node parser
This commit is contained in:
@@ -161,6 +161,8 @@ Body Line 1"""
|
||||
assert len(entries) == 1
|
||||
# parsed heading from entry
|
||||
assert entries[0].heading == "Heading[1]"
|
||||
# track ancestors of entry
|
||||
assert entries[0].ancestors == [f"{orgfile}"]
|
||||
# ensure SOURCE link has square brackets in filename, heading escaped in rendered entries
|
||||
escaped_orgfile = f"{orgfile}".replace("[1]", "\\[1\\]")
|
||||
assert f":SOURCE: [[file:{escaped_orgfile}::*Heading\\[1\\]" in f"{entries[0]}"
|
||||
@@ -260,6 +262,7 @@ Body Line 1"""
|
||||
assert entries[0].closed == ""
|
||||
assert entries[0].scheduled == ""
|
||||
assert entries[0].deadline == ""
|
||||
assert entries[0].ancestors == []
|
||||
|
||||
|
||||
# ----------------------------------------------------------------------------------------------------
|
||||
@@ -284,6 +287,7 @@ Body Line 1
|
||||
assert entries[0].closed == ""
|
||||
assert entries[0].scheduled == ""
|
||||
assert entries[0].deadline == ""
|
||||
assert entries[0].ancestors == []
|
||||
|
||||
|
||||
# ----------------------------------------------------------------------------------------------------
|
||||
@@ -304,8 +308,10 @@ entry body
|
||||
assert len(entries) == 2
|
||||
assert entries[0].heading == "Title"
|
||||
assert entries[0].body == "intro body\n"
|
||||
assert entries[0].ancestors == []
|
||||
assert entries[1].heading == "Entry Heading"
|
||||
assert entries[1].body == "entry body\n\n"
|
||||
assert entries[1].ancestors == [f"{orgfile}"]
|
||||
|
||||
|
||||
# ----------------------------------------------------------------------------------------------------
|
||||
@@ -326,8 +332,93 @@ entry body
|
||||
assert len(entries) == 2
|
||||
assert entries[0].heading == "Title1 Title2"
|
||||
assert entries[0].body == "intro body\n"
|
||||
assert entries[0].ancestors == []
|
||||
assert entries[1].heading == "Entry Heading"
|
||||
assert entries[1].body == "entry body\n\n"
|
||||
assert entries[1].ancestors == [f"{orgfile}"]
|
||||
|
||||
|
||||
# ----------------------------------------------------------------------------------------------------
|
||||
def test_parse_org_with_single_ancestor_heading(tmp_path):
|
||||
"Parse org entries with parent headings context"
|
||||
# Arrange
|
||||
body = f"""
|
||||
* Heading 1
|
||||
body 1
|
||||
** Sub Heading 1
|
||||
"""
|
||||
orgfile = create_file(tmp_path, body)
|
||||
|
||||
# Act
|
||||
entries = orgnode.makelist_with_filepath(orgfile)
|
||||
|
||||
# Assert
|
||||
assert len(entries) == 2
|
||||
assert entries[0].heading == "Heading 1"
|
||||
assert entries[0].ancestors == [f"{orgfile}"]
|
||||
assert entries[1].heading == "Sub Heading 1"
|
||||
assert entries[1].ancestors == [f"{orgfile}", "Heading 1"]
|
||||
|
||||
|
||||
# ----------------------------------------------------------------------------------------------------
|
||||
def test_parse_org_with_multiple_ancestor_headings(tmp_path):
|
||||
"Parse org entries with parent headings context"
|
||||
# Arrange
|
||||
body = f"""
|
||||
* Heading 1
|
||||
body 1
|
||||
** Sub Heading 1
|
||||
*** Sub Sub Heading 1
|
||||
sub sub body 1
|
||||
"""
|
||||
orgfile = create_file(tmp_path, body)
|
||||
|
||||
# Act
|
||||
entries = orgnode.makelist_with_filepath(orgfile)
|
||||
|
||||
# Assert
|
||||
assert len(entries) == 3
|
||||
assert entries[0].heading == "Heading 1"
|
||||
assert entries[0].ancestors == [f"{orgfile}"]
|
||||
assert entries[1].heading == "Sub Heading 1"
|
||||
assert entries[1].ancestors == [f"{orgfile}", "Heading 1"]
|
||||
assert entries[2].heading == "Sub Sub Heading 1"
|
||||
assert entries[2].ancestors == [f"{orgfile}", "Heading 1", "Sub Heading 1"]
|
||||
|
||||
|
||||
# ----------------------------------------------------------------------------------------------------
|
||||
def test_parse_org_with_multiple_ancestor_headings_of_siblings(tmp_path):
|
||||
"Parse org entries with parent headings context"
|
||||
# Arrange
|
||||
body = f"""
|
||||
* Heading 1
|
||||
body 1
|
||||
** Sub Heading 1
|
||||
*** Sub Sub Heading 1
|
||||
sub sub body 1
|
||||
*** Sub Sub Heading 2
|
||||
** Sub Heading 2
|
||||
*** Sub Sub Heading 3
|
||||
"""
|
||||
orgfile = create_file(tmp_path, body)
|
||||
|
||||
# Act
|
||||
entries = orgnode.makelist_with_filepath(orgfile)
|
||||
|
||||
# Assert
|
||||
assert len(entries) == 6
|
||||
assert entries[0].heading == "Heading 1"
|
||||
assert entries[0].ancestors == [f"{orgfile}"]
|
||||
assert entries[1].heading == "Sub Heading 1"
|
||||
assert entries[1].ancestors == [f"{orgfile}", "Heading 1"]
|
||||
assert entries[2].heading == "Sub Sub Heading 1"
|
||||
assert entries[2].ancestors == [f"{orgfile}", "Heading 1", "Sub Heading 1"]
|
||||
assert entries[3].heading == "Sub Sub Heading 2"
|
||||
assert entries[3].ancestors == [f"{orgfile}", "Heading 1", "Sub Heading 1"]
|
||||
assert entries[4].heading == "Sub Heading 2"
|
||||
assert entries[4].ancestors == [f"{orgfile}", "Heading 1"]
|
||||
assert entries[5].heading == "Sub Sub Heading 3"
|
||||
assert entries[5].ancestors == [f"{orgfile}", "Heading 1", "Sub Heading 2"]
|
||||
|
||||
|
||||
# Helper Functions
|
||||
|
||||
Reference in New Issue
Block a user