Coder Social home page Coder Social logo

convenient-immutability's Issues

Form integration test failure

Don't understand why CI does not fail. This is TransformationFailedException in form because of integer values in choices.

There was 1 failure:

  1. ConvenientImmutability\Test\FormIntegrationTest::it_works_with_a_standard_use_case_for_command_objects
    Failed asserting that two objects are equal.
    --- Expected
    +++ Actual
    @@ @@
    ConvenientImmutability\Test\Resources\OrderSeats Object (
    '_defaultValues' => Array (...)
    '_userDefinedValues' => Array (
    'id' => Ramsey\Uuid\Uuid Object (...)
    'userId' => 1
  •    'seatNumbers' => Array (...)
    
    )
    '_userDefinedProperties' => Array (...)
    )

/home/dzubchik/tmp/dz-c/test/FormIntegrationTest.php:30

FAILURES!
Tests: 8, Assertions: 11, Failures: 1.

Deserialization behaviour

First of all thank you for this useful package. We began to use it in out project but faced with a problem during object deserialization. Did you think about using this package in cases with serialization?

Not compatible with typed properties in PHP 7.4

e.g.
class MyEvent:

{
    use Immutable;
    public int $number;
}

Calling
new MyEvent();

will throw an Exception:

Typed property MyEvent::$number must not be accessed before initialization
in vendor/matthiasnoback/convenient-immutability/src/Immutable.php (line 28) 
    $this->_defaultValues[$propertyName] = $property->getValue($this);

Can be easily fixed by changing the line to:

            if ($property->isInitialized($this)) {
                $this->_defaultValues[$propertyName] = $property->getValue($this);
            }

Return type of the factory doesn't match passed in object type

As it currently stands, the factory will wrap the passed in object in an Immutable wrapper. While that is efficient for simplified scenarios, it will break pretty much anywhere the type system is involved.

In addition to that, no guarantees are provided for the internal state when calling any method on the object: can probably improve that too, later on.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.