-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Bugfix: deserialize Union of generics (#11)
Fixes `deserialize to properly handle `Union` types that consist of generic types. Crucially, this covers the use of container types (e.g. `List`, `Dict`, `Sequence`, `Tuple`, `Mapping`, etc.) in `Union`s. New tests have been added to explicitly cover this case. Version `0.3.2`
- Loading branch information
1 parent
53259ef
commit 5d0f77d
Showing
8 changed files
with
160 additions
and
55 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,65 @@ | ||
# Use the latest 2.1 version of CircleCI pipeline process engine. | ||
# See: https://circleci.com/docs/2.0/configuration-reference | ||
version: 2.1 | ||
|
||
# # Orbs are reusable packages of CircleCI configuration that you may share across projects, enabling you to create encapsulated, parameterized commands, jobs, and executors that can be used across multiple projects. | ||
# # See: https://circleci.com/docs/2.0/orb-intro/ | ||
# orbs: | ||
# # The python orb contains a set of prepackaged CircleCI configuration you can use repeatedly in your configuration files | ||
# # Orb commands and jobs help you with common scripting around a language/tool | ||
# # so you dont have to copy and paste it everywhere. | ||
# # See the orb documentation here: https://circleci.com/developer/orbs/orb/circleci/python | ||
# python: circleci/[email protected] | ||
|
||
# Define a job to be invoked later in a workflow. | ||
# See: https://circleci.com/docs/2.0/configuration-reference/#jobs | ||
jobs: | ||
build-and-test: # This is the name of the job, feel free to change it to better match what you're trying to do! | ||
# These next lines defines a Docker executors: https://circleci.com/docs/2.0/executor-types/ | ||
# You can specify an image from Dockerhub or use one of the convenience images from CircleCI's Developer Hub | ||
# A list of available CircleCI Docker convenience images are available here: https://circleci.com/developer/images/image/cimg/python | ||
# The executor is the environment in which the steps below will be executed - below will use a python 3.8 container | ||
# Change the version below to your required version of python | ||
docker: | ||
- image: cimg/python:3.8 | ||
# Checkout the code as the first step. This is a dedicated CircleCI step. | ||
# The python orb's install-packages step will install the dependencies from a Pipfile via Pipenv by default. | ||
# Here we're making sure we use just use the system-wide pip. By default it uses the project root's requirements.txt. | ||
# Then run your tests! | ||
# CircleCI will report the results back to your VCS provider. | ||
steps: | ||
- checkout | ||
- run: | ||
command: | | ||
rm .python-version | ||
pip install poetry | ||
poetry install | ||
poetry build | ||
poetry run black --check | ||
poetry run flake8 --max-line-length=100 --ignore=E501,W293,E303,W291,W503,E203,E731,E231,E721,E722,E741 . | ||
poetry run mypy --ignore-missing-imports --follow-imports=silent --show-column-numbers --warn-unreachable . | ||
poetry run pytest -v --cov core_utils | ||
poetry run coverage html | ||
poetry run coveralls | ||
# - python/install-packages: | ||
# pkg-manager: poetry | ||
# # app-dir: ~/project/package-directory/ # If you're requirements.txt isn't in the root directory. | ||
# # pip-dependency-file: test-requirements.txt # if you have a different name for your requirements file, maybe one that combines your runtime and test requirements. | ||
# - run: | ||
# name: Run tests | ||
# # This assumes pytest is installed via the install-package step above | ||
# command: | | ||
# poetry run black --check | ||
# poetry run flake8 --max-line-length=100 --ignore=E501,W293,E303,W291,W503,E203,E731,E231,E721,E722,E741 . | ||
# poetry run mypy --ignore-missing-imports --follow-imports=silent --show-column-numbers --warn-unreachable . | ||
# poetry run pytest -v --cov core_utils | ||
# poetry run coverage html | ||
# poetry run coveralls | ||
|
||
# Invoke jobs via workflows | ||
# See: https://circleci.com/docs/2.0/configuration-reference/#workflows | ||
workflows: | ||
ci: # This is the name of the workflow, feel free to change it to better match your workflow. | ||
# Inside the workflow, you define the jobs you want to run. | ||
jobs: | ||
- build-and-test |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
[tool.poetry] | ||
name = "pywise" | ||
version = "0.3.1" | ||
version = "0.3.2" | ||
description = "Robust serialization support for NamedTuple & @dataclass data types." | ||
authors = ["Malcolm Greaves <[email protected]>"] | ||
homepage = "https://github.com/malcolmgreaves/pywise" | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
import pytest | ||
|
||
from core_utils.serialization import serialize, deserialize | ||
from dataclasses import dataclass | ||
from typing import Union, Sequence, Mapping | ||
|
||
|
||
@dataclass(frozen=True) | ||
class A: | ||
a: int | ||
|
||
|
||
@dataclass(frozen=True) | ||
class B: | ||
b: str | ||
|
||
|
||
@dataclass(frozen=True) | ||
class C: | ||
c: Union[A, B, Sequence[A], Sequence[B], Mapping[int, str]] | ||
|
||
|
||
@pytest.mark.parametrize( | ||
"c_input", | ||
[ | ||
# "simple" dataclass cases | ||
C(A(1)), | ||
C(B("hello world")), | ||
# list cases | ||
C([A(1)]), | ||
C([B("hello world")]), | ||
C([A(1), A(2), A(4)]), | ||
C([B("a"), B("b"), B("c")]), | ||
C([]), | ||
# dict cases | ||
C({0: "hello", 1: "world", 2: "how", 3: "are", 4: "you"}), | ||
C(dict()), | ||
], | ||
) | ||
def test_deserialize_dataclass_with_union_of_collections(c_input: C) -> None: | ||
assert deserialize(C, serialize(c_input)) == c_input |