Skip to content

Commit 769db0d

Browse files
committed
Add test di container to socketio app
1 parent 598859c commit 769db0d

File tree

2 files changed

+27
-1
lines changed

2 files changed

+27
-1
lines changed

src/socketio_app/__init__.py

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44
from starlette.routing import Mount, Route, Router
55

66
from common import AppConfig, application_init
7+
from common.di_container import Container
78
from common.telemetry import instrument_third_party
89
from socketio_app.namespaces.chat import ChatNamespace
910
from socketio_app.web_routes import docs
@@ -15,9 +16,10 @@
1516

1617
def create_app(
1718
test_config: Union[AppConfig, None] = None,
19+
test_di_container: Union[Container, None] = None,
1820
) -> Router:
1921
_config = test_config or AppConfig()
20-
application_init(_config)
22+
application_init(_config, test_di_container)
2123

2224
# SocketIO App
2325
sio = socketio.AsyncServer(async_mode="asgi")

tests/socketio_app/conftest.py

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
from collections.abc import Iterator
2+
from unittest.mock import patch
3+
4+
import pytest
5+
from dependency_injector.providers import Object
6+
from starlette.routing import Router
7+
8+
from common.di_container import Container
9+
from socketio_app import create_app
10+
11+
12+
@pytest.fixture(scope="session")
13+
def test_di_container(test_config) -> Container:
14+
return Container(
15+
config=Object(test_config),
16+
)
17+
18+
19+
@pytest.fixture(scope="session")
20+
def testapp(test_config, test_di_container) -> Iterator[Router]:
21+
# We don't need the storage to test the HTTP app
22+
with patch("common.bootstrap.init_storage", return_value=None):
23+
app = create_app(test_config=test_config, test_di_container=test_di_container)
24+
yield app

0 commit comments

Comments
 (0)