mirror of
https://github.com/GSA/notifications-api.git
synced 2026-02-01 07:35:34 -05:00
Support testing commands and add first test
We have a lot of commands and it's important we test the ones that are meant to be used in the future to ensure they work when they're needed. Testing Flask commands is usually easy as written in their docs [1], but I had to make some changes to the way we decorate the command functions so they can work with test DB objects - I couldn't find any example of someone else encountering the same problem. [1]: https://flask.palletsprojects.com/en/2.0.x/testing/#testing-cli-commands
This commit is contained in:
@@ -94,17 +94,25 @@ class notify_command:
|
|||||||
self.name = name
|
self.name = name
|
||||||
|
|
||||||
def __call__(self, func):
|
def __call__(self, func):
|
||||||
# we need to call the flask with_appcontext decorator to ensure the config is loaded, db connected etc etc.
|
decorators = [
|
||||||
# we also need to use functools.wraps to carry through the names and docstrings etc of the functions.
|
click.command(name=self.name), # turn it into a click.Command
|
||||||
# Then we need to turn it into a click.Command - that's what command_group.add_command expects.
|
functools.wraps(func) # carry through function name, docstrings, etc.
|
||||||
@click.command(name=self.name)
|
]
|
||||||
@functools.wraps(func)
|
|
||||||
@flask.cli.with_appcontext
|
# in the test environment the app context is already provided and having
|
||||||
|
# another will lead to the test db connection being closed prematurely
|
||||||
|
if os.getenv('NOTIFY_ENVIRONMENT', '') != 'test':
|
||||||
|
# with_appcontext ensures the config is loaded, db connected, etc.
|
||||||
|
decorators.insert(0, flask.cli.with_appcontext)
|
||||||
|
|
||||||
def wrapper(*args, **kwargs):
|
def wrapper(*args, **kwargs):
|
||||||
return func(*args, **kwargs)
|
return func(*args, **kwargs)
|
||||||
|
|
||||||
command_group.add_command(wrapper)
|
for decorator in decorators:
|
||||||
|
# this syntax is equivalent to e.g. "@flask.cli.with_appcontext"
|
||||||
|
wrapper = decorator(wrapper)
|
||||||
|
|
||||||
|
command_group.add_command(wrapper)
|
||||||
return wrapper
|
return wrapper
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
26
tests/app/test_commands.py
Normal file
26
tests/app/test_commands.py
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
import uuid
|
||||||
|
|
||||||
|
from app.commands import local_dev_broadcast_permissions
|
||||||
|
from app.dao.services_dao import dao_add_user_to_service
|
||||||
|
from tests.app.db import create_user
|
||||||
|
|
||||||
|
|
||||||
|
def test_local_dev_broadcast_permissions(
|
||||||
|
sample_service,
|
||||||
|
sample_broadcast_service,
|
||||||
|
notify_api,
|
||||||
|
):
|
||||||
|
# create_user will pull existing unless email is unique
|
||||||
|
user = create_user(email=f'{uuid.uuid4()}@example.com')
|
||||||
|
dao_add_user_to_service(sample_service, user)
|
||||||
|
dao_add_user_to_service(sample_broadcast_service, user)
|
||||||
|
|
||||||
|
assert len(user.get_permissions(sample_service.id)) == 0
|
||||||
|
assert len(user.get_permissions(sample_broadcast_service.id)) == 0
|
||||||
|
|
||||||
|
notify_api.test_cli_runner().invoke(
|
||||||
|
local_dev_broadcast_permissions, ['-u', user.id]
|
||||||
|
)
|
||||||
|
|
||||||
|
assert len(user.get_permissions(sample_service.id)) == 0
|
||||||
|
assert len(user.get_permissions(sample_broadcast_service.id)) > 0
|
||||||
Reference in New Issue
Block a user