Skip to main content

A simple library to create Value Objects

Project description

Value Object

Version number License MIT Python Version

Based on Ruby Gem by NoFlopSquad

A value object is a small object that represents a simple entity whose equality isn't based on identity: i.e. two value objects are equal when they have the same value, not necessarily being the same object.

Wikipedia

New version 3.x

This new version is a complete rewrite of the library, now it uses data classes to define the value objects. With this change we can use type hints to define the fields and the library will take care of the rest. Now you have autocomplete and type checking in your IDE. With the previous version, you did no autocomplete or type-checking. You should be able to use this library with any version of Python 3.7 or higher.

Installation

pip install simple-value-object

Usage

Constructor and field readers

from simple_value_object import ValueObject

class Point(ValueObject):
    x: int
    y: int

point = Point(1, 2)

point.x
# 1

point.y
# 2

point.x = 5
# CannotBeChanged: You cannot change values from a Value Object, create a new one

class Date(ValueObject):
    day: int
    month: int
    year: int

date = Date(1, 10, 2015)

date.day
# 1

date.month
# 10

date.year
# 2015

date.month = 5
# CannotBeChanged: You cannot change values from a Value Object, create a new one

Equality based on field values

from simple_value_object import ValueObject

class Point(ValueObject):
    x: int
    y: int


a_point = Point(5, 3)

same_point = Point(5, 3)

a_point == same_point
# True

a_different_point = Point(6, 3)

a_point == a_different_point
# False

Hash code based on field values

from simple_value_object import ValueObject

class Point(ValueObject):
    x: int
    y: int

a_point = Point(5, 3)

same_point = Point(5, 3)

a_point.hash == same_point.hash
# True

a_different_point = Point.new(6, 3)

a_point.hash == a_different_point.hash
# False

Invariants

Invariants must return a boolean value.

from simple_value_object import ValueObject, invariant

class Point(ValueObject):
    x: int
    y: int

    @invariant
    def inside_first_quadrant(self):
        return self.x > 0 and self.y > 0

    @invariant
    def x_lower_than_y(self):
        return self.x < self.y

Point(-5, 3)
#InvariantViolation: inside_first_cuadrant

Point(6, 3)
#InvariantViolation: x_lower_than_y

Point(1,3)
#<__main__.Point at 0x7f2bd043c780>

Custom exceptions for invariants

You can throw custom exceptions when an invariant is violated and also return the message of the exception that will be raised.

from simple_value_object import ValueObject, invariant

class MyException(Exception):
    pass


class Point(ValueObject):
    x: int
    y: int

    @invariant(exception_type=MyException)
    def inside_first_quadrant(self):
        return self.x > 0 and self.y > 0, "You must be inside the first quadrant"

    @invariant(MyException)
    def x_lower_than_y(self):
        return self.x < self.y, "X must be lower than Y"

Point(-5, 3)
#MyException: "You must be inside the first quadrant"

ValueObject within ValueObject

from simple_value_object import ValueObject, invariant

class Currency(ValueObject):
    symbol: str

class Money(ValueObject):
    amount: Decimal
    currency: Currency

Money(amount=Decimal("100"), currency=Currency(symbol="€"))

Tests

docker/test

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

simple-value-object-3.3.tar.gz (5.1 kB view details)

Uploaded Source

File details

Details for the file simple-value-object-3.3.tar.gz.

File metadata

  • Download URL: simple-value-object-3.3.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 colorama/0.4.4 importlib-metadata/4.6.4 keyring/23.5.0 pkginfo/1.8.2 readme-renderer/34.0 requests-toolbelt/0.9.1 requests/2.25.1 rfc3986/1.5.0 tqdm/4.57.0 urllib3/1.26.5 CPython/3.10.12

File hashes

Hashes for simple-value-object-3.3.tar.gz
Algorithm Hash digest
SHA256 85ba342a8cf2487ff671258bb6421e0e4a736c2b83df047ea365b3e45a1a01c2
MD5 bc5702937630469700b9972c0b588a26
BLAKE2b-256 24cca7ccdf37e58df0fc9e51ecf436cede982b073756e2281bd6f6ef0404b171

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page