Skip to content

Commit

Permalink
Merge branch 'master' into 2048-getapp
Browse files Browse the repository at this point in the history
  • Loading branch information
ahopkins authored Mar 10, 2021
2 parents 6229f32 + ec7e439 commit 78a7402
Show file tree
Hide file tree
Showing 6 changed files with 107 additions and 90 deletions.
13 changes: 5 additions & 8 deletions examples/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,11 +1,8 @@
FROM python:3.5
MAINTAINER Channel Cat <[email protected]>
FROM sanicframework/sanic:LTS

ADD . /code
RUN pip3 install git+https://github.com/channelcat/sanic
RUN mkdir /srv
COPY . /srv

EXPOSE 8000
WORKDIR /srv

WORKDIR /code

CMD ["python", "simple_server.py"]
CMD ["sanic", "simple_server.app"]
91 changes: 40 additions & 51 deletions examples/log_request_id.py
Original file line number Diff line number Diff line change
@@ -1,86 +1,75 @@
'''
Based on example from https://github.com/Skyscanner/aiotask-context
and `examples/{override_logging,run_async}.py`.
Needs https://github.com/Skyscanner/aiotask-context/tree/52efbc21e2e1def2d52abb9a8e951f3ce5e6f690 or newer
$ pip install git+https://github.com/Skyscanner/aiotask-context.git
'''

import asyncio
import uuid
import logging
from signal import signal, SIGINT

from sanic import Sanic
from sanic import response

import uvloop
import aiotask_context as context

from sanic import Sanic, response


log = logging.getLogger(__name__)


class RequestIdFilter(logging.Filter):
def filter(self, record):
record.request_id = context.get('X-Request-ID')
try:
record.request_id = context.get("X-Request-ID")
except ValueError:
record.request_id = "n/a"
return True


LOG_SETTINGS = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'console': {
'class': 'logging.StreamHandler',
'level': 'DEBUG',
'formatter': 'default',
'filters': ['requestid'],
"version": 1,
"disable_existing_loggers": False,
"handlers": {
"console": {
"class": "logging.StreamHandler",
"level": "DEBUG",
"formatter": "default",
"filters": ["requestid"],
},
},
'filters': {
'requestid': {
'()': RequestIdFilter,
"filters": {
"requestid": {
"()": RequestIdFilter,
},
},
'formatters': {
'default': {
'format': '%(asctime)s %(levelname)s %(name)s:%(lineno)d %(request_id)s | %(message)s',
"formatters": {
"default": {
"format": "%(asctime)s %(levelname)s %(name)s:%(lineno)d %(request_id)s | %(message)s",
},
},
'loggers': {
'': {
'level': 'DEBUG',
'handlers': ['console'],
'propagate': True
},
}
"loggers": {
"": {"level": "DEBUG", "handlers": ["console"], "propagate": True},
},
}


app = Sanic(__name__, log_config=LOG_SETTINGS)


@app.middleware('request')
@app.on_request
async def set_request_id(request):
request_id = request.headers.get('X-Request-ID') or str(uuid.uuid4())
request_id = request.id
context.set("X-Request-ID", request_id)
log.info(f"Setting {request.id=}")


@app.on_response
async def set_request_header(request, response):
response.headers["X-Request-ID"] = request.id


@app.route("/")
async def test(request):
log.debug('X-Request-ID: %s', context.get('X-Request-ID'))
log.info('Hello from test!')
log.debug("X-Request-ID: %s", context.get("X-Request-ID"))
log.info("Hello from test!")
return response.json({"test": True})


if __name__ == '__main__':
asyncio.set_event_loop(uvloop.new_event_loop())
server = app.create_server(host="0.0.0.0", port=8000, return_asyncio_server=True)
loop = asyncio.get_event_loop()
@app.before_server_start
def setup(app, loop):
loop.set_task_factory(context.task_factory)
task = asyncio.ensure_future(server)
try:
loop.run_forever()
except:
loop.stop()


if __name__ == "__main__":
app.run(port=9999, debug=True)
19 changes: 9 additions & 10 deletions examples/override_logging.py
Original file line number Diff line number Diff line change
@@ -1,24 +1,23 @@
from sanic import Sanic
from sanic import response
import logging

from sanic import Sanic, text


logging_format = "[%(asctime)s] %(process)d-%(levelname)s "
logging_format += "%(module)s::%(funcName)s():l%(lineno)d: "
logging_format += "%(message)s"

logging.basicConfig(
format=logging_format,
level=logging.DEBUG
)
logging.basicConfig(format=logging_format, level=logging.DEBUG)
log = logging.getLogger()

# Set logger to override default basicConfig
sanic = Sanic()
app = Sanic("app")


@sanic.route("/")
@app.route("/")
def test(request):
log.info("received request; responding with 'hey'")
return response.text("hey")
return text("hey")


sanic.run(host="0.0.0.0", port=8000)
app.run(host="0.0.0.0", port=8000)
20 changes: 12 additions & 8 deletions examples/pytest_xdist.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,15 +9,19 @@
$ pytest examples/pytest_xdist.py -n 8 # 8 workers
"""
import re

import pytest

from sanic_testing import SanicTestClient
from sanic_testing.testing import PORT as PORT_BASE

from sanic import Sanic
from sanic.response import text
from sanic.testing import PORT as PORT_BASE, SanicTestClient
import pytest


@pytest.fixture(scope="session")
def test_port(worker_id):
m = re.search(r'[0-9]+', worker_id)
m = re.search(r"[0-9]+", worker_id)
if m:
num_id = m.group(0)
else:
Expand All @@ -30,9 +34,9 @@ def test_port(worker_id):
def app():
app = Sanic()

@app.route('/')
@app.route("/")
async def index(request):
return text('OK')
return text("OK")

return app

Expand All @@ -42,8 +46,8 @@ def client(app, test_port):
return SanicTestClient(app, test_port)


@pytest.mark.parametrize('run_id', range(100))
@pytest.mark.parametrize("run_id", range(100))
def test_index(client, run_id):
request, response = client._sanic_endpoint_test('get', '/')
request, response = client._sanic_endpoint_test("get", "/")
assert response.status == 200
assert response.text == 'OK'
assert response.text == "OK"
32 changes: 19 additions & 13 deletions examples/vhosts.py
Original file line number Diff line number Diff line change
@@ -1,39 +1,45 @@
from sanic import response
from sanic import Sanic
from sanic import Sanic, response
from sanic.blueprints import Blueprint


# Usage
# curl -H "Host: example.com" localhost:8000
# curl -H "Host: sub.example.com" localhost:8000
# curl -H "Host: bp.example.com" localhost:8000/question
# curl -H "Host: bp.example.com" localhost:8000/answer

app = Sanic()
app = Sanic(__name__)
bp = Blueprint("bp", host="bp.example.com")


@app.route('/', host=["example.com",
"somethingelse.com",
"therestofyourdomains.com"])
async def hello(request):
@app.route(
"/", host=["example.com", "somethingelse.com", "therestofyourdomains.com"]
)
async def hello_0(request):
return response.text("Some defaults")


@app.route('/', host="sub.example.com")
async def hello(request):
@app.route("/", host="sub.example.com")
async def hello_1(request):
return response.text("42")


@bp.route("/question")
async def hello(request):
async def hello_2(request):
return response.text("What is the meaning of life?")


@bp.route("/answer")
async def hello(request):
async def hello_3(request):
return response.text("42")


@app.get("/name")
def name(request):
return response.text(request.app.url_for("name", _external=True))


app.blueprint(bp)

if __name__ == '__main__':
app.run(host="0.0.0.0", port=8000)
if __name__ == "__main__":
app.run(host="0.0.0.0", port=8000)
22 changes: 22 additions & 0 deletions sanic/app.py
Original file line number Diff line number Diff line change
Expand Up @@ -358,6 +358,28 @@ def url_for(self, view_name: str, **kwargs):
Keyword arguments that are not request parameters will be included in
the output URL's query string.
There are several _special_ keyword arguments that will alter how the
URL will be returned:
1. **_anchor**: ``str`` - Adds an ``#anchor`` to the end
2. **_scheme**: ``str`` - Should be either ``"http"`` or ``"https"``,
default is ``"http"``
3. **_external**: ``bool`` - Whether to return the path or a full URL
with scheme and host
4. **_host**: ``str`` - Used when one or more hosts are defined for a
route to tell Sanic which to use
(only applies with ``_external=True``)
5. **_server**: ``str`` - If not using ``_host``, this will be used
for defining the hostname of the URL
(only applies with ``_external=True``),
defaults to ``app.config.SERVER_NAME``
If you want the PORT to appear in your URL, you should set it in:
.. code-block::
app.config.SERVER_NAME = "myserver:7777"
`See user guide
<https://sanicframework.org/guide/basics/routing.html#generating-a-url>`__
Expand Down

0 comments on commit 78a7402

Please sign in to comment.