mirror of
https://github.com/lnbits/lnbits-legend.git
synced 2025-01-19 05:33:47 +01:00
CI: Test core/views/generic.py
enabling and disabling extensions (#774)
This commit is contained in:
parent
bf2a3e9df2
commit
32a8736f32
@ -23,6 +23,7 @@ from lnbits.settings import (
|
|||||||
SERVICE_FEE,
|
SERVICE_FEE,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
from ...helpers import get_valid_extensions
|
||||||
from ..crud import (
|
from ..crud import (
|
||||||
create_account,
|
create_account,
|
||||||
create_wallet,
|
create_wallet,
|
||||||
@ -66,6 +67,14 @@ async def extensions(
|
|||||||
HTTPStatus.BAD_REQUEST, "You can either `enable` or `disable` an extension."
|
HTTPStatus.BAD_REQUEST, "You can either `enable` or `disable` an extension."
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# check if extension exists
|
||||||
|
if extension_to_enable or extension_to_disable:
|
||||||
|
ext = extension_to_enable or extension_to_disable
|
||||||
|
if ext not in [e.code for e in get_valid_extensions()]:
|
||||||
|
raise HTTPException(
|
||||||
|
HTTPStatus.BAD_REQUEST, f"Extension '{ext}' doesn't exist."
|
||||||
|
)
|
||||||
|
|
||||||
if extension_to_enable:
|
if extension_to_enable:
|
||||||
logger.info(f"Enabling extension: {extension_to_enable} for user {user.id}")
|
logger.info(f"Enabling extension: {extension_to_enable} for user {user.id}")
|
||||||
await update_user_extension(
|
await update_user_extension(
|
||||||
|
@ -92,8 +92,69 @@ async def test_get_wallet_with_user_and_wallet(client, to_user, to_wallet):
|
|||||||
|
|
||||||
# check GET /wallet: wrong wallet and user, expect 204
|
# check GET /wallet: wrong wallet and user, expect 204
|
||||||
@pytest.mark.asyncio
|
@pytest.mark.asyncio
|
||||||
async def test_get_wallet_with_user_and_wrong_wallet(client, to_user, to_wallet):
|
async def test_get_wallet_with_user_and_wrong_wallet(client, to_user):
|
||||||
response = await client.get("wallet", params={"usr": to_user.id, "wal": "1"})
|
response = await client.get("wallet", params={"usr": to_user.id, "wal": "1"})
|
||||||
assert response.status_code == 204, (
|
assert response.status_code == 204, (
|
||||||
str(response.url) + " " + str(response.status_code)
|
str(response.url) + " " + str(response.status_code)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
# check GET /extensions: extensions list
|
||||||
|
@pytest.mark.asyncio
|
||||||
|
async def test_get_extensions(client, to_user):
|
||||||
|
response = await client.get("extensions", params={"usr": to_user.id})
|
||||||
|
assert response.status_code == 200, (
|
||||||
|
str(response.url) + " " + str(response.status_code)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
# check GET /extensions: extensions list wrong user, expect 204
|
||||||
|
@pytest.mark.asyncio
|
||||||
|
async def test_get_extensions_wrong_user(client, to_user):
|
||||||
|
response = await client.get("extensions", params={"usr": "1"})
|
||||||
|
assert response.status_code == 204, (
|
||||||
|
str(response.url) + " " + str(response.status_code)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
# check GET /extensions: no user given, expect code 204 no content
|
||||||
|
@pytest.mark.asyncio
|
||||||
|
async def test_get_extensions_no_user(client):
|
||||||
|
response = await client.get("extensions")
|
||||||
|
assert response.status_code == 204, ( # no content
|
||||||
|
str(response.url) + " " + str(response.status_code)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
# check GET /extensions: enable extension
|
||||||
|
@pytest.mark.asyncio
|
||||||
|
async def test_get_extensions_enable(client, to_user):
|
||||||
|
response = await client.get(
|
||||||
|
"extensions", params={"usr": to_user.id, "enable": "lnurlp"}
|
||||||
|
)
|
||||||
|
assert response.status_code == 200, (
|
||||||
|
str(response.url) + " " + str(response.status_code)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
# check GET /extensions: enable nonexistent extension, expect code 400 bad request
|
||||||
|
@pytest.mark.asyncio
|
||||||
|
async def test_get_extensions_enable_nonexistent_extension(client, to_user):
|
||||||
|
response = await client.get(
|
||||||
|
"extensions", params={"usr": to_user.id, "enable": "12341234"}
|
||||||
|
)
|
||||||
|
assert response.status_code == 400, (
|
||||||
|
str(response.url) + " " + str(response.status_code)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
# check GET /extensions: enable and disable extensions, expect code 400 bad request
|
||||||
|
@pytest.mark.asyncio
|
||||||
|
async def test_get_extensions_enable_and_disable(client, to_user):
|
||||||
|
response = await client.get(
|
||||||
|
"extensions",
|
||||||
|
params={"usr": to_user.id, "enable": "lnurlp", "disable": "lnurlp"},
|
||||||
|
)
|
||||||
|
assert response.status_code == 400, (
|
||||||
|
str(response.url) + " " + str(response.status_code)
|
||||||
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user