mirror of
https://github.com/progval/irctest.git
synced 2025-04-05 06:49:47 +00:00
patma: Fix inconsistencies between ANYSTR and AnyOptStr
This commit is contained in:
@ -13,18 +13,18 @@ class Operator:
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
class AnyStr(Operator):
|
class _AnyStr(Operator):
|
||||||
"""Wildcard matching any string"""
|
"""Wildcard matching any string"""
|
||||||
|
|
||||||
def __repr__(self) -> str:
|
def __repr__(self) -> str:
|
||||||
return "AnyStr"
|
return "ANYSTR"
|
||||||
|
|
||||||
|
|
||||||
class AnyOptStr(Operator):
|
class _AnyOptStr(Operator):
|
||||||
"""Wildcard matching any string as well as None"""
|
"""Wildcard matching any string as well as None"""
|
||||||
|
|
||||||
def __repr__(self) -> str:
|
def __repr__(self) -> str:
|
||||||
return "AnyOptStr()"
|
return "ANYOPTSTR"
|
||||||
|
|
||||||
|
|
||||||
@dataclasses.dataclass(frozen=True)
|
@dataclasses.dataclass(frozen=True)
|
||||||
@ -62,10 +62,13 @@ class RemainingKeys(Operator):
|
|||||||
return f"RemainingKeys({self.key!r})"
|
return f"RemainingKeys({self.key!r})"
|
||||||
|
|
||||||
|
|
||||||
ANYSTR = AnyStr()
|
ANYSTR = _AnyStr()
|
||||||
"""Singleton, spares two characters"""
|
"""Singleton, spares two characters"""
|
||||||
|
|
||||||
ANYDICT = {RemainingKeys(ANYSTR): AnyOptStr()}
|
ANYOPTSTR = _AnyOptStr()
|
||||||
|
"""Singleton, spares two characters"""
|
||||||
|
|
||||||
|
ANYDICT = {RemainingKeys(ANYSTR): ANYOPTSTR}
|
||||||
"""Matches any dictionary; useful to compare tags dict, eg.
|
"""Matches any dictionary; useful to compare tags dict, eg.
|
||||||
`match_dict(got_tags, {"label": "foo", **ANYDICT})`"""
|
`match_dict(got_tags, {"label": "foo", **ANYDICT})`"""
|
||||||
|
|
||||||
@ -87,9 +90,9 @@ ANYLIST = [ListRemainder(ANYSTR)]
|
|||||||
|
|
||||||
|
|
||||||
def match_string(got: Optional[str], expected: Union[str, Operator, None]) -> bool:
|
def match_string(got: Optional[str], expected: Union[str, Operator, None]) -> bool:
|
||||||
if isinstance(expected, AnyOptStr):
|
if isinstance(expected, _AnyOptStr):
|
||||||
return True
|
return True
|
||||||
elif isinstance(expected, AnyStr) and got is not None:
|
elif isinstance(expected, _AnyStr) and got is not None:
|
||||||
return True
|
return True
|
||||||
elif isinstance(expected, StrRe):
|
elif isinstance(expected, StrRe):
|
||||||
if got is None or not re.match(expected.regexp, got):
|
if got is None or not re.match(expected.regexp, got):
|
||||||
|
@ -7,8 +7,8 @@ from irctest.irc_utils.message_parser import parse_message
|
|||||||
from irctest.patma import (
|
from irctest.patma import (
|
||||||
ANYDICT,
|
ANYDICT,
|
||||||
ANYLIST,
|
ANYLIST,
|
||||||
|
ANYOPTSTR,
|
||||||
ANYSTR,
|
ANYSTR,
|
||||||
AnyOptStr,
|
|
||||||
ListRemainder,
|
ListRemainder,
|
||||||
NotStrRe,
|
NotStrRe,
|
||||||
RemainingKeys,
|
RemainingKeys,
|
||||||
@ -142,9 +142,9 @@ MESSAGE_SPECS: List[Tuple[Dict, List[str], List[str], List[str]]] = [
|
|||||||
],
|
],
|
||||||
# and they each error with:
|
# and they each error with:
|
||||||
[
|
[
|
||||||
"expected tags to match {'tag1': AnyStr}, got {'tag1': 'bar', 'tag2': ''}",
|
"expected tags to match {'tag1': ANYSTR}, got {'tag1': 'bar', 'tag2': ''}",
|
||||||
"expected tags to match {'tag1': AnyStr}, got {}",
|
"expected tags to match {'tag1': ANYSTR}, got {}",
|
||||||
"expected tags to match {'tag1': AnyStr}, got {}",
|
"expected tags to match {'tag1': ANYSTR}, got {}",
|
||||||
]
|
]
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
@ -171,16 +171,16 @@ MESSAGE_SPECS: List[Tuple[Dict, List[str], List[str], List[str]]] = [
|
|||||||
# and they each error with:
|
# and they each error with:
|
||||||
[
|
[
|
||||||
"expected command to be PRIVMSG, got PRIVMG",
|
"expected command to be PRIVMSG, got PRIVMG",
|
||||||
"expected tags to match {'tag1': 'bar', RemainingKeys(AnyStr): AnyOptStr()}, got {'tag1': 'value1'}",
|
"expected tags to match {'tag1': 'bar', RemainingKeys(ANYSTR): ANYOPTSTR}, got {'tag1': 'value1'}",
|
||||||
"expected params to match ['#chan', 'hello'], got ['#chan', 'hello2']",
|
"expected params to match ['#chan', 'hello'], got ['#chan', 'hello2']",
|
||||||
"expected params to match ['#chan', 'hello'], got ['#chan2', 'hello']",
|
"expected params to match ['#chan', 'hello'], got ['#chan2', 'hello']",
|
||||||
"expected tags to match {'tag1': 'bar', RemainingKeys(AnyStr): AnyOptStr()}, got {}",
|
"expected tags to match {'tag1': 'bar', RemainingKeys(ANYSTR): ANYOPTSTR}, got {}",
|
||||||
]
|
]
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
# the specification:
|
# the specification:
|
||||||
dict(
|
dict(
|
||||||
tags={"tag1": "bar", RemainingKeys(NotStrRe("tag2")): AnyOptStr()},
|
tags={"tag1": "bar", RemainingKeys(NotStrRe("tag2")): ANYOPTSTR},
|
||||||
command="PRIVMSG",
|
command="PRIVMSG",
|
||||||
params=["#chan", "hello"],
|
params=["#chan", "hello"],
|
||||||
),
|
),
|
||||||
@ -200,9 +200,9 @@ MESSAGE_SPECS: List[Tuple[Dict, List[str], List[str], List[str]]] = [
|
|||||||
# and they each error with:
|
# and they each error with:
|
||||||
[
|
[
|
||||||
"expected command to be PRIVMSG, got PRIVMG",
|
"expected command to be PRIVMSG, got PRIVMG",
|
||||||
"expected tags to match {'tag1': 'bar', RemainingKeys(NotStrRe(r'tag2')): AnyOptStr()}, got {'tag1': 'value1'}",
|
"expected tags to match {'tag1': 'bar', RemainingKeys(NotStrRe(r'tag2')): ANYOPTSTR}, got {'tag1': 'value1'}",
|
||||||
"expected tags to match {'tag1': 'bar', RemainingKeys(NotStrRe(r'tag2')): AnyOptStr()}, got {'tag1': 'bar', 'tag2': ''}",
|
"expected tags to match {'tag1': 'bar', RemainingKeys(NotStrRe(r'tag2')): ANYOPTSTR}, got {'tag1': 'bar', 'tag2': ''}",
|
||||||
"expected tags to match {'tag1': 'bar', RemainingKeys(NotStrRe(r'tag2')): AnyOptStr()}, got {'tag1': 'bar', 'tag2': 'baz'}",
|
"expected tags to match {'tag1': 'bar', RemainingKeys(NotStrRe(r'tag2')): ANYOPTSTR}, got {'tag1': 'bar', 'tag2': 'baz'}",
|
||||||
]
|
]
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
@ -223,8 +223,8 @@ MESSAGE_SPECS: List[Tuple[Dict, List[str], List[str], List[str]]] = [
|
|||||||
],
|
],
|
||||||
# and they each error with:
|
# and they each error with:
|
||||||
[
|
[
|
||||||
"expected params to match ['nick', 'FOO=1', ListRemainder(AnyStr)], got ['nick']",
|
"expected params to match ['nick', 'FOO=1', ListRemainder(ANYSTR)], got ['nick']",
|
||||||
"expected params to match ['nick', 'FOO=1', ListRemainder(AnyStr)], got ['nick', 'BAR=2']",
|
"expected params to match ['nick', 'FOO=1', ListRemainder(ANYSTR)], got ['nick', 'BAR=2']",
|
||||||
]
|
]
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
@ -245,7 +245,7 @@ MESSAGE_SPECS: List[Tuple[Dict, List[str], List[str], List[str]]] = [
|
|||||||
],
|
],
|
||||||
# and they each error with:
|
# and they each error with:
|
||||||
[
|
[
|
||||||
"expected params to match ['nick', ListRemainder(AnyStr, min_length=1)], got ['nick']",
|
"expected params to match ['nick', ListRemainder(ANYSTR, min_length=1)], got ['nick']",
|
||||||
]
|
]
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
|
@ -11,7 +11,7 @@ import pytest
|
|||||||
|
|
||||||
from irctest import cases
|
from irctest import cases
|
||||||
from irctest.numerics import ERR_UNKNOWNCOMMAND
|
from irctest.numerics import ERR_UNKNOWNCOMMAND
|
||||||
from irctest.patma import ANYDICT, AnyOptStr, NotStrRe, RemainingKeys, StrRe
|
from irctest.patma import ANYDICT, ANYOPTSTR, NotStrRe, RemainingKeys, StrRe
|
||||||
|
|
||||||
|
|
||||||
class LabeledResponsesTestCase(cases.BaseServerTestCase, cases.OptionalityHelper):
|
class LabeledResponsesTestCase(cases.BaseServerTestCase, cases.OptionalityHelper):
|
||||||
@ -299,7 +299,7 @@ class LabeledResponsesTestCase(cases.BaseServerTestCase, cases.OptionalityHelper
|
|||||||
tags={
|
tags={
|
||||||
"+draft/reply": msgid,
|
"+draft/reply": msgid,
|
||||||
"+draft/react": "l😃l",
|
"+draft/react": "l😃l",
|
||||||
RemainingKeys(NotStrRe("label")): AnyOptStr(),
|
RemainingKeys(NotStrRe("label")): ANYOPTSTR,
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
self.assertNotIn(
|
self.assertNotIn(
|
||||||
@ -367,7 +367,7 @@ class LabeledResponsesTestCase(cases.BaseServerTestCase, cases.OptionalityHelper
|
|||||||
tags={
|
tags={
|
||||||
"+draft/reply": msgid,
|
"+draft/reply": msgid,
|
||||||
"+draft/react": "l😃l",
|
"+draft/react": "l😃l",
|
||||||
RemainingKeys(NotStrRe("label")): AnyOptStr(),
|
RemainingKeys(NotStrRe("label")): ANYOPTSTR,
|
||||||
},
|
},
|
||||||
fail_msg="No TAGMSG received by the target after sending one out",
|
fail_msg="No TAGMSG received by the target after sending one out",
|
||||||
)
|
)
|
||||||
|
Reference in New Issue
Block a user