Ejemplo n.º 1
0
def test_extract():
    lines = """
 I've enjoyed [Chandler Carruth's _There Are No Zero-cost Abstractions_](
 https://www.youtube.com/watch?v=rHIkrotSwcc) very much.
""".strip()
    assert set(extract_urls(lines)) == {
        'https://www.youtube.com/watch?v=rHIkrotSwcc'
    }
Ejemplo n.º 2
0
def test_extract_md():
    lines = '''
Hey, I recently implemented a new extension for that [addons.mozilla.org](https://addons.mozilla.org/en-US/firefox/addon/org-grasp-for-org-capture/), [github](https://github.com/karlicoss/grasp), perhaps it could be useful for you!
    '''
    assert set(extract_urls(lines)) == {
        'addons.mozilla.org',
        'https://addons.mozilla.org/en-US/firefox/addon/org-grasp-for-org-capture/',
        'https://github.com/karlicoss/grasp',
    }
Ejemplo n.º 3
0
def test_extract_2():
    text = '''‍♂️ Чтобы снизить вероятность ошибиться, важно знать про когнитивные искажения.
   Если для вас это новое словосочетание, начните с книжки
   "Гарри Поттер и Методы рационального мышления" - http://hpmor.ru/, если вы знакомы с понятием - читайте цепочки на сайтах
   lesswrong.ru и lesswrong.com, книжку Даниэля Канемана "Thinking, fast and slow" и канал Пион https://t.me/ontologics
   '''
    assert set(extract_urls(text)) == {
        'http://hpmor.ru/', 'lesswrong.ru', 'lesswrong.com',
        'https://t.me/ontologics'
    }
Ejemplo n.º 4
0
def test_extract_3() -> None:
    lines = '''
python.org/one.html ?? https://python.org/two.html some extra text

    whatever.org
    '''
    assert set(extract_urls(lines, syntax='org')) == {
        'python.org/one.html',
        'https://python.org/two.html',
        'whatever.org',
    }
Ejemplo n.º 5
0
def index() -> Results:
    from . import hpi
    from my.smscalls import messages

    for m in messages():

        urls = extract_urls(m.message)
        if len(urls) == 0:
            continue

        loc = Loc(title=f"SMS with {m.who} ({m.phone_number})")

        for u in urls:
            yield Visit(
                url=u,
                dt=m.dt,
                context=m.message,
                locator=loc,
            )