wip
This commit is contained in:
@@ -2,8 +2,14 @@ import base64
|
||||
import json
|
||||
from dataclasses import dataclass
|
||||
from http import HTTPMethod
|
||||
from typing import Generator
|
||||
|
||||
import boto3
|
||||
import pytest
|
||||
from layercake.dynamodb import DynamoDBPersistenceLayer
|
||||
|
||||
table_name = 'pytest'
|
||||
dynamodb_endpoint_url = 'http://127.0.0.1:8000'
|
||||
|
||||
|
||||
@dataclass
|
||||
@@ -86,6 +92,36 @@ def http_api_proxy():
|
||||
return HttpApiProxy()
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
def dynamodb_client():
|
||||
return boto3.client('dynamodb', endpoint_url=dynamodb_endpoint_url)
|
||||
|
||||
|
||||
@pytest.fixture()
|
||||
def dynamodb_persistence_layer(
|
||||
dynamodb_client,
|
||||
) -> Generator[DynamoDBPersistenceLayer, None, None]:
|
||||
dynamodb_client.create_table(
|
||||
AttributeDefinitions=[
|
||||
{'AttributeName': 'id', 'AttributeType': 'S'},
|
||||
{'AttributeName': 'sk', 'AttributeType': 'S'},
|
||||
],
|
||||
TableName=table_name,
|
||||
KeySchema=[
|
||||
{'AttributeName': 'id', 'KeyType': 'HASH'},
|
||||
{'AttributeName': 'sk', 'KeyType': 'RANGE'},
|
||||
],
|
||||
ProvisionedThroughput={
|
||||
'ReadCapacityUnits': 123,
|
||||
'WriteCapacityUnits': 123,
|
||||
},
|
||||
)
|
||||
|
||||
yield DynamoDBPersistenceLayer(table_name, dynamodb_client)
|
||||
|
||||
dynamodb_client.delete_table(TableName=table_name)
|
||||
|
||||
|
||||
@pytest.fixture
|
||||
def mock_app(monkeypatch):
|
||||
monkeypatch.setattr('settings.ELASTIC_CONN', {'hosts': 'http://127.0.0.1:9200'})
|
||||
|
||||
@@ -3,7 +3,11 @@ from http import HTTPMethod, HTTPStatus
|
||||
from ..conftest import HttpApiProxy, LambdaContext
|
||||
|
||||
|
||||
def test_courses(mock_app, http_api_proxy: HttpApiProxy, lambda_context: LambdaContext):
|
||||
def test_post_course(
|
||||
mock_app,
|
||||
http_api_proxy: HttpApiProxy,
|
||||
lambda_context: LambdaContext,
|
||||
):
|
||||
r = mock_app.lambda_handler(
|
||||
http_api_proxy(
|
||||
raw_path='/courses',
|
||||
|
||||
24
http-api/tests/routes/test_users.py
Normal file
24
http-api/tests/routes/test_users.py
Normal file
@@ -0,0 +1,24 @@
|
||||
from http import HTTPMethod, HTTPStatus
|
||||
|
||||
from ..conftest import HttpApiProxy, LambdaContext
|
||||
|
||||
|
||||
def test_post_user(
|
||||
mock_app,
|
||||
http_api_proxy: HttpApiProxy,
|
||||
lambda_context: LambdaContext,
|
||||
):
|
||||
r = mock_app.lambda_handler(
|
||||
http_api_proxy(
|
||||
raw_path='/users',
|
||||
method=HTTPMethod.POST,
|
||||
body={
|
||||
'name': 'Sérgio R Siqueira',
|
||||
'email': 'sergio@somosbeta.com.br',
|
||||
'cpf': '07879819908',
|
||||
},
|
||||
),
|
||||
lambda_context,
|
||||
)
|
||||
|
||||
assert r['statusCode'] == HTTPStatus.CREATED
|
||||
Reference in New Issue
Block a user