diff --git a/testproject/fabfile.py b/testproject/fabfile.py index 6238405..3bab83d 100644 --- a/testproject/fabfile.py +++ b/testproject/fabfile.py @@ -13,7 +13,7 @@ def setup_redis(): def setup_channels(): sudo("apt-get update && apt-get install -y git python-dev python-setuptools python-pip") sudo("pip install -U pip") - sudo("pip install -U asgi_redis git+https://github.com/andrewgodwin/daphne.git@#egg=daphne") + sudo("pip install -U asgi_redis asgi_ipc git+https://github.com/andrewgodwin/daphne.git@#egg=daphne") sudo("rm -rf /srv/channels") sudo("git clone https://github.com/andrewgodwin/channels.git /srv/channels/") with cd("/srv/channels/"): @@ -43,7 +43,13 @@ def setup_load_tester(src="https://github.com/andrewgodwin/channels.git"): # Run current loadtesting setup # example usage: $ fab run_loadtest:http://127.0.0.1,rps=10 -i "id_rsa" -H ubuntu@example.com @task -def run_loadtest(host, t=90, rps=200): +def run_loadtest(host, t=90): + sudo("loadtest -c 10 -t {t} {h}".format(h=host, t=t)) + +# Run current loadtesting setup +# example usage: $ fab run_loadtest:http://127.0.0.1,rps=10 -i "id_rsa" -H ubuntu@example.com +@task +def run_loadtest_rps(host, t=90, rps=200): sudo("loadtest -c 10 --rps {rps} -t {t} {h}".format(h=host, t=t, rps=rps)) diff --git a/testproject/requirements.txt b/testproject/requirements.txt index 3bb2297..900d067 100644 --- a/testproject/requirements.txt +++ b/testproject/requirements.txt @@ -1,4 +1,5 @@ -asgi-redis==0.13.1 +asgi_redis==0.13.1 +asgi_ipc==1.1.0 asgiref==0.13.3 autobahn==0.14.1 channels==0.14.2 diff --git a/testproject/testproject/asgi.py b/testproject/testproject/asgi.py index ae1640f..73591ef 100644 --- a/testproject/testproject/asgi.py +++ b/testproject/testproject/asgi.py @@ -1,5 +1,5 @@ import os from channels.asgi import get_channel_layer -os.environ.setdefault("DJANGO_SETTINGS_MODULE", "testproject.settings.channels") +os.environ.setdefault("DJANGO_SETTINGS_MODULE", "testproject.settings.channels_redis") channel_layer = get_channel_layer() diff --git a/testproject/testproject/asgi_for_ipc.py b/testproject/testproject/asgi_for_ipc.py new file mode 100644 index 0000000..78421fb --- /dev/null +++ b/testproject/testproject/asgi_for_ipc.py @@ -0,0 +1,6 @@ +import os +from channels.asgi import get_channel_layer +import asgi_ipc + +os.environ.setdefault("DJANGO_SETTINGS_MODULE", "testproject.settings.channels_ipc") +channel_layer = get_channel_layer() diff --git a/testproject/testproject/settings/channels_ipc.py b/testproject/testproject/settings/channels_ipc.py new file mode 100644 index 0000000..6098a12 --- /dev/null +++ b/testproject/testproject/settings/channels_ipc.py @@ -0,0 +1,14 @@ +# Settings for channels specifically +from testproject.settings.base import * + + +INSTALLED_APPS += ( + 'channels', +) + +CHANNEL_LAYERS = { + "default": { + "BACKEND": "asgi_ipc.IPCChannelLayer", + "ROUTING": "testproject.urls.channel_routing", + }, +} diff --git a/testproject/testproject/settings/channels.py b/testproject/testproject/settings/channels_redis.py similarity index 100% rename from testproject/testproject/settings/channels.py rename to testproject/testproject/settings/channels_redis.py diff --git a/testproject/testproject/wsgi.py b/testproject/testproject/wsgi.py index 9dcfd86..91daa15 100644 --- a/testproject/testproject/wsgi.py +++ b/testproject/testproject/wsgi.py @@ -11,6 +11,6 @@ import os from django.core.wsgi import get_wsgi_application -os.environ.setdefault("DJANGO_SETTINGS_MODULE", "testproject.settings.channels") +os.environ.setdefault("DJANGO_SETTINGS_MODULE", "testproject.settings.channels_redis") application = get_wsgi_application()