mirror of
https://github.com/caronc/apprise.git
synced 2025-01-22 13:59:03 +01:00
Improved text configuration parsing (#768)
This commit is contained in:
parent
1732aaf0e8
commit
3389a3d4c3
@ -548,7 +548,7 @@ class ConfigBase(URLBase):
|
|||||||
# Define what a valid line should look like
|
# Define what a valid line should look like
|
||||||
valid_line_re = re.compile(
|
valid_line_re = re.compile(
|
||||||
r'^\s*(?P<line>([;#]+(?P<comment>.*))|'
|
r'^\s*(?P<line>([;#]+(?P<comment>.*))|'
|
||||||
r'(\s*(?P<tags>[^=]+)=|=)?\s*'
|
r'(\s*(?P<tags>[a-z0-9, \t_-]+)\s*=|=)?\s*'
|
||||||
r'(?P<url>[a-z0-9]{2,9}://.*)|'
|
r'(?P<url>[a-z0-9]{2,9}://.*)|'
|
||||||
r'include\s+(?P<config>.+))?\s*$', re.I)
|
r'include\s+(?P<config>.+))?\s*$', re.I)
|
||||||
|
|
||||||
|
@ -325,7 +325,7 @@ def test_config_base_config_parse_text():
|
|||||||
assert isinstance(result, list)
|
assert isinstance(result, list)
|
||||||
assert len(result) == 0
|
assert len(result) == 0
|
||||||
|
|
||||||
# There was 1 valid entry
|
# There were no include entries defined
|
||||||
assert len(config) == 0
|
assert len(config) == 0
|
||||||
|
|
||||||
# Test case where a comment is on it's own line with nothing else
|
# Test case where a comment is on it's own line with nothing else
|
||||||
@ -337,6 +337,56 @@ def test_config_base_config_parse_text():
|
|||||||
# There were no include entries defined
|
# There were no include entries defined
|
||||||
assert len(config) == 0
|
assert len(config) == 0
|
||||||
|
|
||||||
|
# Verify our tagging works when multiple tags are provided
|
||||||
|
result, config = ConfigBase.config_parse_text("""
|
||||||
|
tag1, tag2, tag3=json://user:pass@localhost
|
||||||
|
""")
|
||||||
|
|
||||||
|
assert isinstance(result, list)
|
||||||
|
assert len(result) == 1
|
||||||
|
assert len(result[0].tags) == 3
|
||||||
|
assert 'tag1' in result[0].tags
|
||||||
|
assert 'tag2' in result[0].tags
|
||||||
|
assert 'tag3' in result[0].tags
|
||||||
|
|
||||||
|
|
||||||
|
def test_config_base_config_parse_text_with_url():
|
||||||
|
"""
|
||||||
|
API: ConfigBase.config_parse_text object_with_url
|
||||||
|
|
||||||
|
"""
|
||||||
|
# Here is a similar result set however this one has an invalid line
|
||||||
|
# in it which invalidates the entire file
|
||||||
|
result, config = ConfigBase.config_parse_text("""
|
||||||
|
# Test a URL that has a URL as an argument
|
||||||
|
json://user:pass@localhost?+arg=http://example.com?arg2=1&arg3=3
|
||||||
|
""")
|
||||||
|
|
||||||
|
# No tag is parsed, but our URL successfully parses as is
|
||||||
|
|
||||||
|
assert isinstance(result, list)
|
||||||
|
assert len(result) == 1
|
||||||
|
assert len(result[0].tags) == 0
|
||||||
|
|
||||||
|
# Verify our URL is correctly captured
|
||||||
|
assert '%2Barg=http%3A%2F%2Fexample.com%3Farg2%3D1' in result[0].url()
|
||||||
|
assert 'json://user:pass@localhost/' in result[0].url()
|
||||||
|
|
||||||
|
# There were no include entries defined
|
||||||
|
assert len(config) == 0
|
||||||
|
|
||||||
|
# Pass in our configuration again
|
||||||
|
result, config = ConfigBase.config_parse_text(result[0].url())
|
||||||
|
|
||||||
|
# Verify that our results repeat themselves
|
||||||
|
assert isinstance(result, list)
|
||||||
|
assert len(result) == 1
|
||||||
|
assert len(result[0].tags) == 0
|
||||||
|
assert '%2Barg=http%3A%2F%2Fexample.com%3Farg2%3D1' in result[0].url()
|
||||||
|
assert 'json://user:pass@localhost/' in result[0].url()
|
||||||
|
|
||||||
|
assert len(config) == 0
|
||||||
|
|
||||||
|
|
||||||
def test_config_base_config_parse_yaml():
|
def test_config_base_config_parse_yaml():
|
||||||
"""
|
"""
|
||||||
|
Loading…
Reference in New Issue
Block a user