Breaking : migrate your tests that use the TestDomain.client method following the instructions here https://github.com/Kludex/bump-testclient Squashed commit of the following: commit0417f27b3f
Author: Maxime Alves LIRMM <maxime.alves@lirmm.fr> Date: Sat Jan 14 11:08:44 2023 +0100 [deps] starlette 0.23 commit552f00a65b
Author: Maxime Alves LIRMM <maxime.alves@lirmm.fr> Date: Sat Jan 14 10:59:42 2023 +0100 [deps] starlette 0.22 commitaefe448717
Author: Maxime Alves LIRMM <maxime.alves@lirmm.fr> Date: Sat Jan 14 10:55:45 2023 +0100 [tests][fix] compares the json interpreted value instead of the string commit01333a200c
Author: Maxime Alves LIRMM <maxime.alves@lirmm.fr> Date: Sat Jan 14 10:55:20 2023 +0100 [testing] changes from requests to httpx for Starlette TestClient (breaks) commitf3784fab7f
Author: Maxime Alves LIRMM <maxime.alves@lirmm.fr> Date: Sat Jan 14 10:54:10 2023 +0100 [deps][breaking] starlette 0.21 commit717d3f8bd6
Author: Maxime Alves LIRMM <maxime.alves@lirmm.fr> Date: Sat Jan 14 10:26:31 2023 +0100 [responses] use a wrapper function for exception handling (fix starlette 0.20) commitd0876e45da
Author: Maxime Alves LIRMM <maxime.alves@lirmm.fr> Date: Sat Jan 14 10:25:21 2023 +0100 [deps][breaking] starlette 0.20 commit6504191c53
Author: Maxime Alves LIRMM <maxime.alves@lirmm.fr> Date: Sat Jan 14 10:12:51 2023 +0100 [deps] starlette 0.19 commit7b639a8dc2
Author: Maxime Alves LIRMM <maxime.alves@lirmm.fr> Date: Sat Jan 14 10:11:14 2023 +0100 [deps] starlette 0.18 commit20bd9077a4
Author: Maxime Alves LIRMM <maxime.alves@lirmm.fr> Date: Sat Jan 14 10:07:48 2023 +0100 pipenv update
110 lines
3.4 KiB
Python
110 lines
3.4 KiB
Python
import os
|
|
import sys
|
|
import importlib
|
|
import subprocess
|
|
import time
|
|
import pytest
|
|
import json
|
|
from pprint import pprint
|
|
from starlette.routing import Route
|
|
from starlette.testclient import TestClient
|
|
|
|
def test_get_config_route(dummy_project, application_domain):
|
|
c = TestClient(application_domain)
|
|
r = c.request('get', '/')
|
|
assert r.status_code == 200
|
|
pprint(r.json())
|
|
r = c.request('get', '/config')
|
|
assert r.status_code == 200
|
|
pprint(r.json())
|
|
assert 'test' in r.json()
|
|
|
|
def test_get_route(dummy_project, application_domain):
|
|
c = TestClient(application_domain)
|
|
path = verb = params = None
|
|
dummy_domain_routes = [
|
|
('config','GET'),
|
|
('config','GET'),
|
|
('async_router/abc/pinnochio','GET'),
|
|
('async_router/config','GET'),
|
|
# ('abc/pinnochio','GET'),
|
|
# ('abc/alphabet','GET'),
|
|
]
|
|
|
|
for route_def in dummy_domain_routes:
|
|
path, verb = route_def[0], route_def[1]
|
|
route_path = '/{}'.format(path)
|
|
print(route_path)
|
|
try:
|
|
if verb.lower() == 'get':
|
|
r = c.request('get', route_path)
|
|
elif verb.lower() == 'post':
|
|
r = c.request('post', route_path)
|
|
elif verb.lower() == 'patch':
|
|
r = c.request('patch', route_path)
|
|
elif verb.lower() == 'put':
|
|
r = c.request('put', route_path)
|
|
elif verb.lower() == 'delete':
|
|
r = c.request('delete', route_path)
|
|
else:
|
|
raise Exception(verb)
|
|
try:
|
|
assert r.status_code in [200, 501]
|
|
except AssertionError as exc:
|
|
print('{} [{}] {}'.format(str(r.status_code), verb, route_path))
|
|
raise exc from exc
|
|
|
|
except NotImplementedError:
|
|
pass
|
|
|
|
dummy_domain_path_routes = [
|
|
('abc/alphabet/{test}','GET'),
|
|
]
|
|
|
|
#for route_def in dummy_domain_path_routes:
|
|
for route_def in []:#dummy_domain_routes:
|
|
from uuid import uuid4
|
|
test_uuid = uuid4()
|
|
for route_def in dummy_domain_path_routes:
|
|
path, verb = route_def[0], route_def[1]
|
|
path = path.format(test=str(test_uuid))
|
|
route_path = f'/{path}'
|
|
if verb.lower() == 'get':
|
|
r = c.request('get', f'{route_path}')
|
|
|
|
assert r.status_code == 200
|
|
|
|
|
|
def test_delete_route(dummy_project, application_domain):
|
|
c = TestClient(application_domain)
|
|
from uuid import uuid4
|
|
arg = str(uuid4())
|
|
r = c.request('delete', f'/abc/alphabet/{arg}')
|
|
assert r.status_code == 200
|
|
assert isinstance(r.json(), str)
|
|
|
|
def test_arguments_route(dummy_project, application_domain):
|
|
c = TestClient(application_domain)
|
|
|
|
path = '/arguments'
|
|
r = c.request('get', path)
|
|
assert r.status_code == 400
|
|
r = c.request('get', path, params={'foo':True})
|
|
assert r.status_code == 400
|
|
arg = {'foo':True, 'bar':True}
|
|
r = c.request('get', path, params=arg)
|
|
assert r.status_code == 200
|
|
for key, val in arg.items():
|
|
assert json.loads(r.json()[key]) == val
|
|
path = '/async_router/arguments'
|
|
r = c.request('get', path)
|
|
assert r.status_code == 400
|
|
r = c.request('get', path, params={'foo':True})
|
|
assert r.status_code == 400
|
|
arg = {'foo':True, 'bar':True}
|
|
r = c.request('get', path, params=arg)
|
|
assert r.status_code == 200
|
|
for key, val in arg.items():
|
|
assert json.loads(r.json()[key]) == val
|
|
|