pyinfra/test/server.py
2022-05-03 17:52:13 +02:00

59 lines
1.4 KiB
Python

import logging
import traceback
from itertools import chain
from flask import Flask, jsonify, request
from funcy import flatten
logger = logging.getLogger()
class Nothing:
pass
def has_next(peekable_iter):
return peekable_iter.peek(Nothing) == Nothing
def set_up_processing_server(process_fn):
app = Flask(__name__)
response_payload_iter = []
@app.route("/ready", methods=["GET"])
def ready():
resp = jsonify("OK")
resp.status_code = 200
return resp
@app.route("/process", methods=["POST", "PATCH"])
def process():
response_payload = process_fn(request, final=request.method == "POST")
return jsonify(response_payload)
@app.route("/submit", methods=["POST"])
def submit():
nonlocal response_payload_iter
response_payload_iter = chain(response_payload_iter, process_fn(request, final=True))
return jsonify({"pickup_endpoint": "pickup"})
@app.route("/pickup", methods=["GET"])
def pickup():
try:
response_payload = next(response_payload_iter)
print("response_payload", response_payload)
resp = jsonify(response_payload)
resp.status_code = 206
except StopIteration:
resp = jsonify("No more items left")
resp.status_code = 204
except Exception as err:
logger.error(traceback.format_exc())
return resp
return app