mirror of
https://github.com/caronc/apprise.git
synced 2024-11-22 16:13:12 +01:00
Removed formatting of title when not blended with body (#914)
This commit is contained in:
parent
01f757d6a1
commit
768b38434b
@ -498,25 +498,29 @@ class Apprise:
|
|||||||
# If our code reaches here, we either did not define a tag (it
|
# If our code reaches here, we either did not define a tag (it
|
||||||
# was set to None), or we did define a tag and the logic above
|
# was set to None), or we did define a tag and the logic above
|
||||||
# determined we need to notify the service it's associated with
|
# determined we need to notify the service it's associated with
|
||||||
if server.notify_format not in conversion_body_map:
|
|
||||||
# Perform Conversion
|
# First we need to generate a key we will use to determine if we
|
||||||
conversion_body_map[server.notify_format] = \
|
# need to build our data out. Entries without are merged with
|
||||||
convert_between(
|
# the body at this stage.
|
||||||
body_format, server.notify_format, content=body)
|
key = server.notify_format if server.title_maxlen > 0\
|
||||||
|
else f'_{server.notify_format}'
|
||||||
|
|
||||||
|
if key not in conversion_title_map:
|
||||||
|
|
||||||
# Prepare our title
|
# Prepare our title
|
||||||
conversion_title_map[server.notify_format] = \
|
conversion_title_map[key] = '' if not title else title
|
||||||
'' if not title else title
|
|
||||||
|
|
||||||
# Tidy Title IF required (hence it will become part of the
|
# Conversion of title only occurs for services where the title
|
||||||
# body)
|
# is blended with the body (title_maxlen <= 0)
|
||||||
if server.title_maxlen <= 0 and \
|
if conversion_title_map[key] and server.title_maxlen <= 0:
|
||||||
conversion_title_map[server.notify_format]:
|
conversion_title_map[key] = convert_between(
|
||||||
|
body_format, server.notify_format,
|
||||||
|
content=conversion_title_map[key])
|
||||||
|
|
||||||
conversion_title_map[server.notify_format] = \
|
# Our body is always converted no matter what
|
||||||
convert_between(
|
conversion_body_map[key] = \
|
||||||
body_format, server.notify_format,
|
convert_between(
|
||||||
content=conversion_title_map[server.notify_format])
|
body_format, server.notify_format, content=body)
|
||||||
|
|
||||||
if interpret_escapes:
|
if interpret_escapes:
|
||||||
#
|
#
|
||||||
@ -526,13 +530,13 @@ class Apprise:
|
|||||||
try:
|
try:
|
||||||
# Added overhead required due to Python 3 Encoding Bug
|
# Added overhead required due to Python 3 Encoding Bug
|
||||||
# identified here: https://bugs.python.org/issue21331
|
# identified here: https://bugs.python.org/issue21331
|
||||||
conversion_body_map[server.notify_format] = \
|
conversion_body_map[key] = \
|
||||||
conversion_body_map[server.notify_format]\
|
conversion_body_map[key]\
|
||||||
.encode('ascii', 'backslashreplace')\
|
.encode('ascii', 'backslashreplace')\
|
||||||
.decode('unicode-escape')
|
.decode('unicode-escape')
|
||||||
|
|
||||||
conversion_title_map[server.notify_format] = \
|
conversion_title_map[key] = \
|
||||||
conversion_title_map[server.notify_format]\
|
conversion_title_map[key]\
|
||||||
.encode('ascii', 'backslashreplace')\
|
.encode('ascii', 'backslashreplace')\
|
||||||
.decode('unicode-escape')
|
.decode('unicode-escape')
|
||||||
|
|
||||||
@ -543,8 +547,8 @@ class Apprise:
|
|||||||
raise TypeError(msg)
|
raise TypeError(msg)
|
||||||
|
|
||||||
kwargs = dict(
|
kwargs = dict(
|
||||||
body=conversion_body_map[server.notify_format],
|
body=conversion_body_map[key],
|
||||||
title=conversion_title_map[server.notify_format],
|
title=conversion_title_map[key],
|
||||||
notify_type=notify_type,
|
notify_type=notify_type,
|
||||||
attach=attach,
|
attach=attach,
|
||||||
body_format=body_format
|
body_format=body_format
|
||||||
|
150
test/test_plugin_title_maxlen.py
Normal file
150
test/test_plugin_title_maxlen.py
Normal file
@ -0,0 +1,150 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# BSD 3-Clause License
|
||||||
|
#
|
||||||
|
# Apprise - Push Notification Library.
|
||||||
|
# Copyright (c) 2023, Chris Caron <lead2gold@gmail.com>
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without
|
||||||
|
# modification, are permitted provided that the following conditions are met:
|
||||||
|
#
|
||||||
|
# 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
# this list of conditions and the following disclaimer.
|
||||||
|
#
|
||||||
|
# 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
# this list of conditions and the following disclaimer in the documentation
|
||||||
|
# and/or other materials provided with the distribution.
|
||||||
|
#
|
||||||
|
# 3. Neither the name of the copyright holder nor the names of its
|
||||||
|
# contributors may be used to endorse or promote products derived from
|
||||||
|
# this software without specific prior written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
# POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
import os
|
||||||
|
from json import loads
|
||||||
|
from inspect import cleandoc
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
import requests
|
||||||
|
from apprise import Apprise
|
||||||
|
from apprise.config.ConfigBase import ConfigBase
|
||||||
|
|
||||||
|
# Disable logging for a cleaner testing output
|
||||||
|
import logging
|
||||||
|
logging.disable(logging.CRITICAL)
|
||||||
|
|
||||||
|
# Attachment Directory
|
||||||
|
TEST_VAR_DIR = os.path.join(os.path.dirname(__file__), 'var')
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def request_mock(mocker):
|
||||||
|
"""
|
||||||
|
Prepare requests mock.
|
||||||
|
"""
|
||||||
|
mock_post = mocker.patch("requests.post")
|
||||||
|
mock_post.return_value = requests.Request()
|
||||||
|
mock_post.return_value.status_code = requests.codes.ok
|
||||||
|
mock_post.return_value.content = ""
|
||||||
|
return mock_post
|
||||||
|
|
||||||
|
|
||||||
|
def test_plugin_title_maxlen(request_mock):
|
||||||
|
"""
|
||||||
|
plugin title maxlen blending support
|
||||||
|
|
||||||
|
"""
|
||||||
|
# Load our configuration
|
||||||
|
result, config = ConfigBase.config_parse_yaml(cleandoc("""
|
||||||
|
urls:
|
||||||
|
|
||||||
|
# Our JSON plugin allows for a title definition; we enforce a html format
|
||||||
|
- json://user:pass@example.ca?format=html
|
||||||
|
# Telegram has a title_maxlen of 0
|
||||||
|
- tgram://123456789:AABCeFGhIJKLmnOPqrStUvWxYZ12345678U/987654321
|
||||||
|
"""))
|
||||||
|
|
||||||
|
# Verify we loaded correctly
|
||||||
|
assert isinstance(result, list)
|
||||||
|
assert len(result) == 2
|
||||||
|
assert len(result[0].tags) == 0
|
||||||
|
|
||||||
|
aobj = Apprise()
|
||||||
|
aobj.add(result)
|
||||||
|
assert len(aobj) == 2
|
||||||
|
|
||||||
|
title = "Hello World"
|
||||||
|
body = "Foo Bar"
|
||||||
|
assert aobj.notify(title=title, body=body)
|
||||||
|
|
||||||
|
# If a batch, there is only 1 post
|
||||||
|
assert request_mock.call_count == 2
|
||||||
|
|
||||||
|
details = request_mock.call_args_list[0]
|
||||||
|
assert details[0][0] == 'http://example.ca'
|
||||||
|
payload = loads(details[1]['data'])
|
||||||
|
assert payload['message'] == body
|
||||||
|
assert payload['title'] == "Hello World"
|
||||||
|
|
||||||
|
details = request_mock.call_args_list[1]
|
||||||
|
assert details[0][0] == \
|
||||||
|
'https://api.telegram.org/bot123456789:' \
|
||||||
|
'AABCeFGhIJKLmnOPqrStUvWxYZ12345678U/sendMessage'
|
||||||
|
payload = loads(details[1]['data'])
|
||||||
|
# HTML in Title is escaped
|
||||||
|
assert payload['text'] == "<b>Hello World</b>\r\nFoo Bar"
|
||||||
|
|
||||||
|
# Reset our mock object
|
||||||
|
request_mock.reset_mock()
|
||||||
|
#
|
||||||
|
# Reverse the configuration file and expect the same results
|
||||||
|
#
|
||||||
|
result, config = ConfigBase.config_parse_yaml(cleandoc("""
|
||||||
|
urls:
|
||||||
|
|
||||||
|
# Telegram has a title_maxlen of 0
|
||||||
|
- tgram://123456789:AABCeFGhIJKLmnOPqrStUvWxYZ12345678U/987654321
|
||||||
|
# Our JSON plugin allows for a title definition; we enforce a html format
|
||||||
|
- json://user:pass@example.ca?format=html
|
||||||
|
"""))
|
||||||
|
|
||||||
|
# Verify we loaded correctly
|
||||||
|
assert isinstance(result, list)
|
||||||
|
assert len(result) == 2
|
||||||
|
assert len(result[0].tags) == 0
|
||||||
|
|
||||||
|
aobj = Apprise()
|
||||||
|
aobj.add(result)
|
||||||
|
assert len(aobj) == 2
|
||||||
|
|
||||||
|
title = "Hello World"
|
||||||
|
body = "Foo Bar"
|
||||||
|
assert aobj.notify(title=title, body=body)
|
||||||
|
|
||||||
|
# If a batch, there is only 1 post
|
||||||
|
assert request_mock.call_count == 2
|
||||||
|
|
||||||
|
details = request_mock.call_args_list[0]
|
||||||
|
assert details[0][0] == \
|
||||||
|
'https://api.telegram.org/bot123456789:' \
|
||||||
|
'AABCeFGhIJKLmnOPqrStUvWxYZ12345678U/sendMessage'
|
||||||
|
payload = loads(details[1]['data'])
|
||||||
|
|
||||||
|
# HTML in Title is escaped
|
||||||
|
assert payload['text'] == "<b>Hello World</b>\r\nFoo Bar"
|
||||||
|
|
||||||
|
details = request_mock.call_args_list[1]
|
||||||
|
assert details[0][0] == 'http://example.ca'
|
||||||
|
payload = loads(details[1]['data'])
|
||||||
|
assert payload['message'] == body
|
||||||
|
assert payload['title'] == "Hello World"
|
Loading…
Reference in New Issue
Block a user