Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Snapshot changes is wrong when object has proxy attributes #102

Open
urbany opened this issue Feb 3, 2021 · 6 comments
Open

Snapshot changes is wrong when object has proxy attributes #102

urbany opened this issue Feb 3, 2021 · 6 comments
Labels
bug Something isn't working

Comments

@urbany
Copy link

urbany commented Feb 3, 2021

Hi, changeset of ED Models with async belongsTo relationships show incorrect changes on snapshot:
Screenshot 2021-02-03 at 16 15 37

change and changes are correct, but snapshot().changes shows all my async belongsTo as changed attributes incorrectly.

I think this is because of this unrwrap https://github.com/validated-changeset/validated-changeset/blob/da68651a41028ab827872cf10960920779c2a09f/src/index.ts#L975

Which adds all the unwrapped relationships to this[CHANGES]. When i get change and changes these incorrect changes are filtered out, but not on snapshot.

Does my explanation make sense? Thanks in advance!

EDIT:
If anyone else comes here looking for a solution I'm currently creating snapshots like this until it is fixed

function createSnapshot(cs) {
  const changes = {};
  cs.changes.forEach(({ key, value }) => { changes[key] = value; });
  return {
    changes,
    errors: { ...cs.error },
  };
}
@urbany
Copy link
Author

urbany commented Feb 3, 2021

Screenshot 2021-02-03 at 17 40 44

Actually after some more tests changeset.change is also broken, changeset.changesis the only one showing correct changes. changeset.change becomes wrong only if there is a real change in the changeset (in the example above it is the attr state)

@snewcomer snewcomer added the bug Something isn't working label Feb 4, 2021
@snewcomer
Copy link
Collaborator

@urbany Thx for the issue! Do you have an example test we could add here? It would be good to know how you get to this state!

@DLiblik
Copy link

DLiblik commented Feb 14, 2021

We also see this inconsistency. The fastest way to get there is to start with a POJO model that has a sub-key with an attribute set and then create a changeset off of it. Then call set on the changeset to add another key to the same sub-key. Calling snapshot will render an output in changes that includes the sub-key, but it is an empty object. My understanding of changes is that it lists paths on a top-level object, not nested objects - i.e. that a change to a path on the changeset of student.firstName should show on changes as changes['student.firstName']: 'Bob' not changes.student: { firstName: 'Bob' } which is what I would expect in change (not changes).

... you can also hit it quickly by simply having a change on a subkey, then snapshotting and restoring the changeset - that should effectively be a no-op, but actually it clears out the changes on all the nested paths.

@DLiblik
Copy link

DLiblik commented Feb 14, 2021

...I should add that we just upgraded to v3 from v2 of ember-changeset and hit this there as v3 picks up this version. This has had some catastrophic consequences as we did not initially discover it (our bad) in our testing and now we can't go back due to other dependencies. This is not an obvious condition to detect - it comes out as odd behaviour in user-side support complaints. I say all of this because once resolved, you may wish to mark the tags with this issue as deprecated to help others move past it.

@snewcomer
Copy link
Collaborator

If someone has a failing test they would like to contribute that would be phenomenal! I can continue the work if that is something you didn't want to take on.

@DLiblik
Copy link

DLiblik commented Feb 15, 2021

Just run this - I would expect by contract of the changeset that the console entries would match.

const cs = new Changeset({ person: { firstName: 'Shep' } });
cs.set('person.firstName', 'Moe');
console.log(cs.change);
cs.restore(cs.snapshot());
console.log(cs.change);

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants