Custom Plugin Attachment Support Enforced + Added Testing (#1115)

This commit is contained in:
Chris Caron 2024-04-20 16:05:14 -04:00 committed by GitHub
parent 2316a4b415
commit 1f77254d71
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 121 additions and 3 deletions

View File

@ -55,6 +55,9 @@ class CustomNotifyPlugin(NotifyBase):
# should be treated differently.
category = 'custom'
# Support Attachments
attachment_support = True
# Define object templates
templates = (
'{schema}://',

View File

@ -62,6 +62,16 @@ def test_notify_simple_decoration():
def my_inline_notify_wrapper(
body, title, notify_type, attach, *args, **kwargs):
# Test our body (always present)
assert isinstance(body, str)
# Ensure content is of type utf-8
assert isinstance(body.encode('utf-8'), bytes)
if attach:
# attachment is always of type AppriseAttach
assert isinstance(attach, AppriseAttachment)
# Populate our object we can use to validate
verify_obj.update({
'body': body,
@ -120,6 +130,108 @@ def test_notify_simple_decoration():
# Reset our verify object (so it can be populated again)
verify_obj = {}
# Send unicode
assert aobj.notify("".encode('utf-8')) is True
# Our content was populated after the notify() call
assert len(verify_obj) > 0
assert verify_obj['body'] == "" # content comes back as str (utf-8)
assert verify_obj['title'] == ''
assert verify_obj['notify_type'] == common.NotifyType.INFO
assert verify_obj['attach'] is None
# No format was defined
assert 'body_format' in verify_obj['kwargs']
assert verify_obj['kwargs']['body_format'] is None
# The meta argument allows us to further parse the URL parameters
# specified
assert isinstance(verify_obj['kwargs'], dict)
assert 'meta' in verify_obj['kwargs']
assert isinstance(verify_obj['kwargs']['meta'], dict)
assert len(verify_obj['kwargs']['meta']) == 4
assert 'tag' in verify_obj['kwargs']['meta']
assert 'asset' in verify_obj['kwargs']['meta']
assert isinstance(verify_obj['kwargs']['meta']['asset'], AppriseAsset)
assert verify_obj['kwargs']['meta']['schema'] == 'utiltest'
assert verify_obj['kwargs']['meta']['url'] == 'utiltest://'
# Reset our verify object (so it can be populated again)
verify_obj = {}
# Send utf-8 string
assert aobj.notify("") is True
assert len(verify_obj) > 0
assert verify_obj['body'] == "" # content comes back as str (utf-8)
assert verify_obj['title'] == ''
assert verify_obj['notify_type'] == common.NotifyType.INFO
assert verify_obj['attach'] is None
# No format was defined
assert 'body_format' in verify_obj['kwargs']
assert verify_obj['kwargs']['body_format'] is None
# The meta argument allows us to further parse the URL parameters
# specified
assert isinstance(verify_obj['kwargs'], dict)
assert 'meta' in verify_obj['kwargs']
assert isinstance(verify_obj['kwargs']['meta'], dict)
assert len(verify_obj['kwargs']['meta']) == 4
assert 'tag' in verify_obj['kwargs']['meta']
assert 'asset' in verify_obj['kwargs']['meta']
assert isinstance(verify_obj['kwargs']['meta']['asset'], AppriseAsset)
assert verify_obj['kwargs']['meta']['schema'] == 'utiltest'
assert verify_obj['kwargs']['meta']['url'] == 'utiltest://'
# Some cases that will fail internal validation:
# - No Body
assert aobj.notify('') is False
# - Title only
assert aobj.notify('', title="hello world!") is False
# Reset our verify object (so it can be populated again)
verify_obj = {}
# No Body but has attachment (valid)
assert aobj.notify(
'',
attach=(
join(TEST_VAR_DIR, 'apprise-test.png'),
)) is True
# Our content was populated after the notify() call
assert len(verify_obj) > 0
assert verify_obj['body'] == ""
assert verify_obj['title'] == ""
assert verify_obj['notify_type'] == common.NotifyType.INFO
assert isinstance(verify_obj['attach'], AppriseAttachment)
assert len(verify_obj['attach']) == 1
# No format was defined
assert 'body_format' in verify_obj['kwargs']
assert verify_obj['kwargs']['body_format'] is None
# The meta argument allows us to further parse the URL parameters
# specified
assert isinstance(verify_obj['kwargs'], dict)
assert 'meta' in verify_obj['kwargs']
assert isinstance(verify_obj['kwargs']['meta'], dict)
assert len(verify_obj['kwargs']['meta']) == 4
assert 'tag' in verify_obj['kwargs']['meta']
assert 'asset' in verify_obj['kwargs']['meta']
assert isinstance(verify_obj['kwargs']['meta']['asset'], AppriseAsset)
assert verify_obj['kwargs']['meta']['schema'] == 'utiltest'
assert verify_obj['kwargs']['meta']['url'] == 'utiltest://'
# Reset our verify object (so it can be populated again)
verify_obj = {}
# We'll do another test now
assert aobj.notify(
"Hello Another World", title="My Other Title",
@ -334,6 +446,8 @@ def test_notify_multi_instance_decoration(tmpdir):
def my_inline_notify_wrapper(
body, title, notify_type, attach, meta, *args, **kwargs):
assert isinstance(body, str)
# Track what is added
verify_obj.append({
'body': body,
@ -373,7 +487,8 @@ def test_notify_multi_instance_decoration(tmpdir):
# Nothing stored yet in our object
assert len(verify_obj) == 0
assert aobj.notify("Hello World", title="My Title") is True
# Send utf-8 characters
assert aobj.notify("".encode('utf-8'), title="My Title") is True
assert len(verify_obj) == 2
@ -384,7 +499,7 @@ def test_notify_multi_instance_decoration(tmpdir):
# Our content was populated after the notify() call
obj = verify_obj[0]
assert obj['body'] == "Hello World"
assert obj['body'] == ""
assert obj['title'] == "My Title"
assert obj['notify_type'] == common.NotifyType.INFO
@ -422,7 +537,7 @@ def test_notify_multi_instance_decoration(tmpdir):
# Our content was populated after the notify() call
obj = verify_obj[1]
assert obj['body'] == "Hello World"
assert obj['body'] == ""
assert obj['title'] == "My Title"
assert obj['notify_type'] == common.NotifyType.INFO