mirror of
https://github.com/Rapptz/discord.py.git
synced 2025-06-08 04:38:42 +00:00
Fix and add tests for new autocomplete regression
This commit is contained in:
parent
c735682ac6
commit
99d2ecac54
@ -40,8 +40,7 @@ async def invalid_free_function(self, interaction: discord.Interaction, current:
|
|||||||
|
|
||||||
|
|
||||||
class X(app_commands.Transformer):
|
class X(app_commands.Transformer):
|
||||||
@classmethod
|
async def autocomplete(self, interaction: discord.Interaction, current: str) -> List[app_commands.Choice[str]]:
|
||||||
async def autocomplete(cls, interaction: discord.Interaction, current: str) -> List[app_commands.Choice[str]]:
|
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
|
||||||
@ -66,8 +65,7 @@ def test_free_function_autocomplete():
|
|||||||
|
|
||||||
param = cmd._params['name']
|
param = cmd._params['name']
|
||||||
assert param.autocomplete is not MISSING
|
assert param.autocomplete is not MISSING
|
||||||
assert param.autocomplete.binding is None # type: ignore
|
assert not param.autocomplete.pass_command_binding # type: ignore
|
||||||
assert not param.autocomplete.requires_binding # type: ignore
|
|
||||||
|
|
||||||
|
|
||||||
def test_invalid_free_function_autocomplete():
|
def test_invalid_free_function_autocomplete():
|
||||||
@ -86,8 +84,32 @@ def test_transformer_autocomplete():
|
|||||||
|
|
||||||
param = cmd._params['param']
|
param = cmd._params['param']
|
||||||
assert param.autocomplete is not MISSING
|
assert param.autocomplete is not MISSING
|
||||||
assert param.autocomplete.binding is X # type: ignore
|
assert getattr(param.autocomplete, '__self__', None) is not None
|
||||||
assert param.autocomplete.requires_binding # type: ignore
|
assert not getattr(param.autocomplete, 'pass_command_binding', False)
|
||||||
|
|
||||||
|
|
||||||
|
first_instance = X()
|
||||||
|
second_instance = X()
|
||||||
|
|
||||||
|
|
||||||
|
def test_multiple_transformer_autocomplete():
|
||||||
|
@app_commands.command()
|
||||||
|
async def cmd(
|
||||||
|
interaction: discord.Interaction,
|
||||||
|
param: app_commands.Transform[str, first_instance],
|
||||||
|
second: app_commands.Transform[str, second_instance],
|
||||||
|
):
|
||||||
|
...
|
||||||
|
|
||||||
|
param = cmd._params['param']
|
||||||
|
assert param.autocomplete is not MISSING
|
||||||
|
assert getattr(param.autocomplete, '__self__', None) is first_instance
|
||||||
|
assert not getattr(param.autocomplete, 'pass_command_binding', False)
|
||||||
|
|
||||||
|
param = cmd._params['second']
|
||||||
|
assert param.autocomplete is not MISSING
|
||||||
|
assert getattr(param.autocomplete, '__self__', None) is second_instance
|
||||||
|
assert not getattr(param.autocomplete, 'pass_command_binding', False)
|
||||||
|
|
||||||
|
|
||||||
def test_bound_function_autocomplete():
|
def test_bound_function_autocomplete():
|
||||||
@ -98,8 +120,8 @@ def test_bound_function_autocomplete():
|
|||||||
|
|
||||||
param = cmd._params['name']
|
param = cmd._params['name']
|
||||||
assert param.autocomplete is not MISSING
|
assert param.autocomplete is not MISSING
|
||||||
assert param.autocomplete.binding is lookup # type: ignore
|
assert getattr(param.autocomplete, '__self__', None) is lookup
|
||||||
assert param.autocomplete.requires_binding # type: ignore
|
assert not getattr(param.autocomplete, 'pass_command_binding', False)
|
||||||
|
|
||||||
|
|
||||||
def test_invalid_bound_function_autocomplete():
|
def test_invalid_bound_function_autocomplete():
|
||||||
@ -125,6 +147,5 @@ def test_group_function_autocomplete():
|
|||||||
param = g.foo._params['name']
|
param = g.foo._params['name']
|
||||||
|
|
||||||
assert param.autocomplete is not MISSING
|
assert param.autocomplete is not MISSING
|
||||||
# Note: The binding is filled later when actually invoked
|
assert getattr(param.autocomplete, '__self__', None) is None
|
||||||
assert param.autocomplete.binding is None # type: ignore
|
assert getattr(param.autocomplete, 'pass_command_binding', False)
|
||||||
assert param.autocomplete.requires_binding # type: ignore
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user