Better error handling for hypothesis
This commit is contained in:
parent
522d3bc5d9
commit
8e6d5fd132
1 changed files with 17 additions and 9 deletions
|
@ -1,8 +1,10 @@
|
||||||
from typing import Dict, List, NamedTuple, Optional, Sequence, Any
|
|
||||||
from pathlib import Path
|
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
|
from pathlib import Path
|
||||||
|
from itertools import tee
|
||||||
|
from typing import Any, Dict, Iterator, List, NamedTuple, Optional, Sequence, Union, Iterable
|
||||||
|
|
||||||
from .common import group_by_key, the, cproperty, PathIsh
|
from .common import PathIsh, cproperty, group_by_key, the
|
||||||
|
from .error import Res
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -85,23 +87,29 @@ class Page(NamedTuple):
|
||||||
return min(h.dt for h in self.highlights)
|
return min(h.dt for h in self.highlights)
|
||||||
|
|
||||||
|
|
||||||
def _iter():
|
Result = Res[Highlight]
|
||||||
|
|
||||||
|
def _iter() -> Iterator[Result]:
|
||||||
yield from get_model().iter_highlights()
|
yield from get_model().iter_highlights()
|
||||||
|
|
||||||
|
|
||||||
def get_pages() -> List[Page]:
|
def get_pages() -> Iterator[Res[Page]]:
|
||||||
grouped = group_by_key(_iter(), key=lambda e: e.page_link)
|
from .error import split_errors
|
||||||
|
values, errors = split_errors(_iter(), Exception)
|
||||||
|
grouped = group_by_key(values, key=lambda e: e.page_link)
|
||||||
pages = []
|
pages = []
|
||||||
for link, group in grouped.items():
|
for link, group in grouped.items():
|
||||||
sgroup = tuple(sorted(group, key=lambda e: e.dt))
|
sgroup = tuple(sorted(group, key=lambda e: e.dt))
|
||||||
pages.append(Page(highlights=sgroup))
|
pages.append(Page(highlights=sgroup))
|
||||||
pages = list(sorted(pages, key=lambda p: p.dt))
|
pages = list(sorted(pages, key=lambda p: p.dt))
|
||||||
|
yield from pages
|
||||||
|
yield from errors
|
||||||
# TODO fixme page tag??
|
# TODO fixme page tag??
|
||||||
return pages
|
|
||||||
|
|
||||||
|
|
||||||
def get_highlights():
|
def get_highlights() -> List[Result]:
|
||||||
return list(sorted(_iter(), key=lambda h: h.dt))
|
from .error import sort_res_by
|
||||||
|
return sort_res_by(_iter(), key=lambda h: h.dt)
|
||||||
|
|
||||||
|
|
||||||
def test():
|
def test():
|
||||||
|
|
Loading…
Add table
Reference in a new issue