polyapi-python 0.2.7.dev0__tar.gz → 0.2.7.dev2__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {polyapi_python-0.2.7.dev0/polyapi_python.egg-info → polyapi_python-0.2.7.dev2}/PKG-INFO +1 -1
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/cli.py +5 -2
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/function_cli.py +9 -1
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2/polyapi_python.egg-info}/PKG-INFO +1 -1
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/pyproject.toml +1 -1
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/tests/test_rendered_spec.py +2 -2
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/tests/test_utils.py +0 -7
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/LICENSE +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/README.md +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/__init__.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/__main__.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/api.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/auth.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/client.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/config.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/constants.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/error_handler.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/exceptions.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/execute.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/generate.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/py.typed +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/rendered_spec.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/schema.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/server.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/typedefs.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/utils.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/variables.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi/webhook.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi_python.egg-info/SOURCES.txt +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi_python.egg-info/dependency_links.txt +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi_python.egg-info/requires.txt +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi_python.egg-info/top_level.txt +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/setup.cfg +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/tests/test_api.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/tests/test_auth.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/tests/test_function_cli.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/tests/test_schema.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/tests/test_server.py +0 -0
- {polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/tests/test_variables.py +0 -0
|
@@ -4,7 +4,7 @@ from polyapi.utils import print_green
|
|
|
4
4
|
|
|
5
5
|
from .config import clear_config, set_api_key_and_url
|
|
6
6
|
from .generate import generate, clear
|
|
7
|
-
from .function_cli import function_add_or_update
|
|
7
|
+
from .function_cli import function_add_or_update, function_execute
|
|
8
8
|
from .rendered_spec import get_and_update_rendered_spec
|
|
9
9
|
|
|
10
10
|
|
|
@@ -56,4 +56,7 @@ def execute_from_cli() -> None:
|
|
|
56
56
|
print("Clearing the generated library...")
|
|
57
57
|
clear()
|
|
58
58
|
elif command == "function":
|
|
59
|
-
|
|
59
|
+
if args.subcommands[0] == "execute":
|
|
60
|
+
print(function_execute(args.context, args.subcommands))
|
|
61
|
+
else:
|
|
62
|
+
function_add_or_update(args.context, args.description, args.client, args.server, args.logs, args.subcommands, not args.skip_generate)
|
|
@@ -3,7 +3,7 @@ import argparse
|
|
|
3
3
|
import json
|
|
4
4
|
import types
|
|
5
5
|
import sys
|
|
6
|
-
from typing import Dict, List, Mapping, Optional, Tuple
|
|
6
|
+
from typing import Any, Dict, List, Mapping, Optional, Tuple
|
|
7
7
|
from typing import _TypedDictMeta as BaseTypedDict # type: ignore
|
|
8
8
|
from typing_extensions import _TypedDictMeta # type: ignore
|
|
9
9
|
import requests
|
|
@@ -279,3 +279,11 @@ def function_add_or_update(
|
|
|
279
279
|
print(resp.status_code)
|
|
280
280
|
print(resp.content)
|
|
281
281
|
sys.exit(1)
|
|
282
|
+
|
|
283
|
+
|
|
284
|
+
def function_execute(context: str, subcommands: List) -> Any:
|
|
285
|
+
assert subcommands[0] == "execute"
|
|
286
|
+
context_code = importlib.import_module(f"polyapi.poly.{context}")
|
|
287
|
+
print(f"Executing poly.{context}.{subcommands[1]}... ")
|
|
288
|
+
fn = getattr(context_code, subcommands[1])
|
|
289
|
+
return fn(*subcommands[2:])
|
|
@@ -3,7 +3,7 @@ requires = ["setuptools>=61.2", "wheel"]
|
|
|
3
3
|
|
|
4
4
|
[project]
|
|
5
5
|
name = "polyapi-python"
|
|
6
|
-
version = "0.2.7.
|
|
6
|
+
version = "0.2.7.dev2"
|
|
7
7
|
description = "The Python Client for PolyAPI, the IPaaS by Developers for Developers"
|
|
8
8
|
authors = [{ name = "Dan Fellin", email = "dan@polyapi.io" }]
|
|
9
9
|
dependencies = [
|
|
@@ -36,7 +36,7 @@ class T(unittest.TestCase):
|
|
|
36
36
|
""" pass in a bad id to update and make sure it returns False
|
|
37
37
|
"""
|
|
38
38
|
_get_spec.return_value = None
|
|
39
|
-
updated = get_and_update_rendered_spec("
|
|
39
|
+
updated = get_and_update_rendered_spec("123")
|
|
40
40
|
self.assertEqual(_get_spec.call_count, 1)
|
|
41
41
|
self.assertFalse(updated)
|
|
42
42
|
|
|
@@ -47,6 +47,6 @@ class T(unittest.TestCase):
|
|
|
47
47
|
"""
|
|
48
48
|
_get_spec.return_value = GET_PRODUCTS_COUNT
|
|
49
49
|
post.return_value = Mock(status_code=201, text="Created")
|
|
50
|
-
updated = get_and_update_rendered_spec("
|
|
50
|
+
updated = get_and_update_rendered_spec("123")
|
|
51
51
|
self.assertEqual(_get_spec.call_count, 1)
|
|
52
52
|
self.assertTrue(updated)
|
|
@@ -1,17 +1,10 @@
|
|
|
1
1
|
import unittest
|
|
2
|
-
from polyapi.schema import _fix_title
|
|
3
2
|
from polyapi.utils import get_type_and_def
|
|
4
3
|
|
|
5
4
|
OPENAPI_FUNCTION = {'kind': 'function', 'spec': {'arguments': [{'name': 'event', 'required': False, 'type': {'kind': 'object', 'schema': {'$schema': 'http://json-schema.org/draft-06/schema#', 'type': 'array', 'items': {'$ref': '#/definitions/WebhookEventTypeElement'}, 'definitions': {'WebhookEventTypeElement': {'type': 'object', 'additionalProperties': False, 'properties': {'title': {'type': 'string'}, 'manufacturerName': {'type': 'string'}, 'carType': {'type': 'string'}, 'id': {'type': 'integer'}}, 'required': ['carType', 'id', 'manufacturerName', 'title'], 'title': 'WebhookEventTypeElement'}}}}}, {'name': 'headers', 'required': False, 'type': {'kind': 'object', 'typeName': 'Record<string, any>'}}, {'name': 'params', 'required': False, 'type': {'kind': 'object', 'typeName': 'Record<string, any>'}}, {'name': 'polyCustom', 'required': False, 'type': {'kind': 'object', 'properties': [{'name': 'responseStatusCode', 'type': {'type': 'number', 'kind': 'primitive'}, 'required': True}, {'name': 'responseContentType', 'type': {'type': 'string', 'kind': 'primitive'}, 'required': True, 'nullable': True}]}}], 'returnType': {'kind': 'void'}, 'synchronous': True}}
|
|
6
5
|
|
|
7
6
|
|
|
8
7
|
class T(unittest.TestCase):
|
|
9
|
-
def test_fix_titles(self):
|
|
10
|
-
input_data = {'properties': {'requestNumber': {'title': 'Requestnumber', 'type': 'integer'}}, 'required': ['requestNumber'], 'title': 'numOfCars', 'type': 'object', 'metadata': {'pydantic.internal.needs_apply_discriminated_union': False}}
|
|
11
|
-
output = 'from typing import TypedDict\nfrom typing_extensions import Required\n\n\nclass Numofcars(TypedDict, total=False):\n """ numOfCars. """\n\n requestNumber: Required[int]\n """\n Requestnumber.\n\n Required property\n """\n\n'
|
|
12
|
-
fixed = _fix_title(input_data, output)
|
|
13
|
-
self.assertIn("class numOfCars", fixed)
|
|
14
|
-
|
|
15
8
|
def test_get_type_and_def(self):
|
|
16
9
|
arg_type, arg_def = get_type_and_def(OPENAPI_FUNCTION)
|
|
17
10
|
self.assertEqual(arg_type, "Callable[[List[WebhookEventTypeElement], Dict, Dict, Dict], None]")
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi_python.egg-info/dependency_links.txt
RENAMED
|
File without changes
|
{polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi_python.egg-info/requires.txt
RENAMED
|
File without changes
|
{polyapi_python-0.2.7.dev0 → polyapi_python-0.2.7.dev2}/polyapi_python.egg-info/top_level.txt
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|