generated from Luis/nextjs-python-web-template
georgs #23
@@ -1,8 +1,9 @@
|
|||||||
from typing import Generator
|
from typing import Generator
|
||||||
|
|
||||||
from sqlalchemy import create_engine
|
from sqlalchemy import create_engine
|
||||||
#from sqlalchemy.ext.declarative import declarative_base
|
|
||||||
from sqlalchemy.orm import Session, sessionmaker, declarative_base
|
# from sqlalchemy.ext.declarative import declarative_base
|
||||||
|
from sqlalchemy.orm import Session, declarative_base, sessionmaker
|
||||||
|
|
||||||
URL = "sqlite:///./sql_app.db"
|
URL = "sqlite:///./sql_app.db"
|
||||||
|
|
||||||
|
|||||||
@@ -35,7 +35,8 @@ class Entity(Base):
|
|||||||
producers = relationship("Producer", back_populates="entity")
|
producers = relationship("Producer", back_populates="entity")
|
||||||
consumers = relationship("Consumer", back_populates="entity")
|
consumers = relationship("Consumer", back_populates="entity")
|
||||||
repository = relationship("Repository", back_populates="entity")
|
repository = relationship("Repository", back_populates="entity")
|
||||||
#TODO maby refactor to repositories
|
# TODO maby refactor to repositories
|
||||||
|
|
||||||
|
|
||||||
class ProducerAbstract(Base):
|
class ProducerAbstract(Base):
|
||||||
__abstract__ = True
|
__abstract__ = True
|
||||||
|
|||||||
@@ -1,42 +1,52 @@
|
|||||||
import pytest
|
|
||||||
import json
|
import json
|
||||||
from api import TestClient
|
|
||||||
|
|
||||||
|
from api import TestClient
|
||||||
|
|
||||||
default_entity_did_url = "entity_did=did%3Asov%3Atest%3A1234"
|
default_entity_did_url = "entity_did=did%3Asov%3Atest%3A1234"
|
||||||
default_entity_did = "did:sov:test:1234"
|
default_entity_did = "did:sov:test:1234"
|
||||||
|
|
||||||
|
|
||||||
def assert_extra_info(infos, request_body, response) -> None:
|
def assert_extra_info(infos, request_body, response) -> None:
|
||||||
for info in infos:
|
for info in infos:
|
||||||
assert info in response.keys()
|
assert info in response.keys()
|
||||||
#TODO maybe check the content of the extra info ...
|
# TODO maybe check the content of the extra info ...
|
||||||
response.pop(info)
|
response.pop(info)
|
||||||
assert response == request_body
|
assert response == request_body
|
||||||
|
|
||||||
|
|
||||||
def make_test_post_and_get(api, request_body, paramter, get_request=default_entity_did_url, apiversion="v1") -> None:
|
def make_test_post_and_get(
|
||||||
#test post
|
api, request_body, paramter, get_request=default_entity_did_url, apiversion="v1"
|
||||||
response = api.post(f"/api/{apiversion}/create_{paramter}",
|
) -> None:
|
||||||
|
# test post
|
||||||
|
response = api.post(
|
||||||
|
f"/api/{apiversion}/create_{paramter}",
|
||||||
data=json.dumps(request_body),
|
data=json.dumps(request_body),
|
||||||
headers={"Content-Type": "application/json"})
|
headers={"Content-Type": "application/json"},
|
||||||
|
)
|
||||||
assert response.status_code == 200
|
assert response.status_code == 200
|
||||||
if paramter == "repository":
|
if paramter == "repository":
|
||||||
assert_extra_info(["time_created"], request_body, response.json())
|
assert_extra_info(["time_created"], request_body, response.json())
|
||||||
elif paramter == "consumer":
|
elif paramter == "consumer":
|
||||||
assert_extra_info(["id"], request_body, response.json())
|
assert_extra_info(["id"], request_body, response.json())
|
||||||
elif paramter == "entity":
|
elif paramter == "entity":
|
||||||
assert_extra_info(["consumers", "producers", "repository"], request_body, response.json())
|
assert_extra_info(
|
||||||
|
["consumers", "producers", "repository"], request_body, response.json()
|
||||||
|
)
|
||||||
else:
|
else:
|
||||||
assert response.json() == request_body
|
assert response.json() == request_body
|
||||||
#test get
|
# test get
|
||||||
response = api.get(f"api/{apiversion}/get_{paramter}?{get_request}&skip=0&limit=100")
|
response = api.get(
|
||||||
|
f"api/{apiversion}/get_{paramter}?{get_request}&skip=0&limit=100"
|
||||||
|
)
|
||||||
assert response.status_code == 200
|
assert response.status_code == 200
|
||||||
if paramter == "repository":
|
if paramter == "repository":
|
||||||
assert_extra_info(["time_created"], request_body, response.json()[0])
|
assert_extra_info(["time_created"], request_body, response.json()[0])
|
||||||
elif paramter == "consumer":
|
elif paramter == "consumer":
|
||||||
assert_extra_info(["id"], request_body, response.json()[0])
|
assert_extra_info(["id"], request_body, response.json()[0])
|
||||||
elif paramter == "entity":
|
elif paramter == "entity":
|
||||||
assert_extra_info(["consumers", "producers", "repository"], request_body, response.json())
|
assert_extra_info(
|
||||||
|
["consumers", "producers", "repository"], request_body, response.json()
|
||||||
|
)
|
||||||
else:
|
else:
|
||||||
assert response.json() == [request_body]
|
assert response.json() == [request_body]
|
||||||
|
|
||||||
@@ -49,17 +59,15 @@ def make_test_post_and_get(api, request_body, paramter, get_request=default_enti
|
|||||||
def test_producer(api: TestClient) -> None:
|
def test_producer(api: TestClient) -> None:
|
||||||
request_body = {
|
request_body = {
|
||||||
"uuid": "8e285c0c-4e40-430a-a477-26b3b81e30df",
|
"uuid": "8e285c0c-4e40-430a-a477-26b3b81e30df",
|
||||||
"service_name": "Carlo'\''s Printing",
|
"service_name": "Carlo'''s Printing",
|
||||||
"service_type": "3D Printing",
|
"service_type": "3D Printing",
|
||||||
"endpoint_url": "http://127.0.0.1:8000",
|
"endpoint_url": "http://127.0.0.1:8000",
|
||||||
"status": "unknown",
|
"status": "unknown",
|
||||||
"other": {
|
"other": {"test": "test"},
|
||||||
"test": "test"
|
"entity_did": default_entity_did,
|
||||||
},
|
|
||||||
"entity_did": default_entity_did
|
|
||||||
}
|
}
|
||||||
paramter = "producer"
|
paramter = "producer"
|
||||||
#get_request = "entity_did=did%3Asov%3Atest%3A1234"
|
# get_request = "entity_did=did%3Asov%3Atest%3A1234"
|
||||||
make_test_post_and_get(api, request_body, paramter)
|
make_test_post_and_get(api, request_body, paramter)
|
||||||
|
|
||||||
|
|
||||||
@@ -72,12 +80,10 @@ def test_consumer(api: TestClient) -> None:
|
|||||||
request_body = {
|
request_body = {
|
||||||
"entity_did": default_entity_did,
|
"entity_did": default_entity_did,
|
||||||
"producer_uuid": "8e285c0c-4e40-430a-a477-26b3b81e30df",
|
"producer_uuid": "8e285c0c-4e40-430a-a477-26b3b81e30df",
|
||||||
"other": {
|
"other": {"test": "test"},
|
||||||
"test": "test"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
paramter = "consumer"
|
paramter = "consumer"
|
||||||
#get_request = "entity_did=did%3Asov%3Atest%3A1234"
|
# get_request = "entity_did=did%3Asov%3Atest%3A1234"
|
||||||
make_test_post_and_get(api, request_body, paramter)
|
make_test_post_and_get(api, request_body, paramter)
|
||||||
|
|
||||||
|
|
||||||
@@ -89,17 +95,15 @@ def test_consumer(api: TestClient) -> None:
|
|||||||
def test_repository(api: TestClient) -> None:
|
def test_repository(api: TestClient) -> None:
|
||||||
request_body = {
|
request_body = {
|
||||||
"uuid": "8e285c0c-4e40-430a-a477-26b3b81e30df",
|
"uuid": "8e285c0c-4e40-430a-a477-26b3b81e30df",
|
||||||
"service_name": "Carlo'\''s Printing",
|
"service_name": "Carlo'''s Printing",
|
||||||
"service_type": "3D Printing",
|
"service_type": "3D Printing",
|
||||||
"endpoint_url": "http://127.0.0.1:8000",
|
"endpoint_url": "http://127.0.0.1:8000",
|
||||||
"status": "unknown",
|
"status": "unknown",
|
||||||
"other": {
|
"other": {"test": "test"},
|
||||||
"test": "test"
|
"entity_did": default_entity_did,
|
||||||
},
|
|
||||||
"entity_did": default_entity_did
|
|
||||||
}
|
}
|
||||||
paramter = "repository"
|
paramter = "repository"
|
||||||
#get_request = "entity_did=did%3Asov%3Atest%3A1234"
|
# get_request = "entity_did=did%3Asov%3Atest%3A1234"
|
||||||
make_test_post_and_get(api, request_body, paramter)
|
make_test_post_and_get(api, request_body, paramter)
|
||||||
|
|
||||||
|
|
||||||
@@ -114,10 +118,8 @@ def test_entity(api: TestClient) -> None:
|
|||||||
"name": "C1",
|
"name": "C1",
|
||||||
"ip": "127.0.0.1",
|
"ip": "127.0.0.1",
|
||||||
"attached": False,
|
"attached": False,
|
||||||
"other": {
|
"other": {"test": "test"},
|
||||||
"test": "test"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
paramter = "entity"
|
paramter = "entity"
|
||||||
#get_request = "entity_did=did%3Asov%3Atest%3A1234"
|
# get_request = "entity_did=did%3Asov%3Atest%3A1234"
|
||||||
make_test_post_and_get(api, request_body, paramter)
|
make_test_post_and_get(api, request_body, paramter)
|
||||||
|
|||||||
Reference in New Issue
Block a user