meteor-simple-schema icon indicating copy to clipboard operation
meteor-simple-schema copied to clipboard

Using Collection Hook's direct version breaks defaultValue and autoValue on an insert

Open evolross opened this issue 7 months ago • 1 comments

NOTE - Also posted this bug here in aldeed:collection2. Wasn't sure which package it's rooted in. Will close in both once it's resolved.

Describe the bug

Ran into an issue upgrading my project to Meteor 2.16 from 2.7.2 (on my way up to 3.0).

When using aldeed:[email protected] with the included aldeed:[email protected] on a Meteor 2.16 project along with matb33:[email protected] (latest version), using the collection hook's direct versions that bypass a collection's hook will cause the defaultValue and autoValue set in the schema to also not run. The added logic in the defined simple schema gets bypassed and the document gets inserted/updated as if simple schema doesn't exist. I have tested matb33:collection-hooks and it seems the problem is rooted in aldeed:collection2 or aldeed:simple-schema. If you drop back down to aldeed:[email protected] and use meteor npm install [email protected] with any version of matb33:collection-hooks all works as expected.

To Reproduce

I've hotrodded the React Simple Todos demo to display the error in a repo here.

The repo has the following currently added:

aldeed:[email protected]
aldeed:[email protected]
matb33:[email protected]
  1. Click on the Add New Link button.

A link will be inserted in the list without using the direct version in the insert. The insert is performed and the link's description and createdAt are all successfully set using either Simple Schema's defaultValue or autoValue. You'll also notice the link's linkType is set to "video" by the defined and working LinksCollection.before.insert hook.

  1. Click on the Add New Link (Direct) button.

A link will be inserted in the list using the direct version in the insert. The insert is performed but the link will not get any of the Simple Schema logic (e.g. defaultValue or autoValue) however it does get inserted. And the hook is not performed so its linkType is still "website".

Expected behavior

Making use of a matb33:collection-hook direct call should still run the Simple Schema logic (e.g. defaultValue or autoValue) and validation. Using aldeed:[email protected] and meteor npm install [email protected] all works as expected. Feel free to comment out aldeed:collection2 and uncomment aldeed:[email protected] in the packages.js file and then do a meteor npm install [email protected] and then update the import in links.js to see it working correctly on the prior versions.

evolross avatar Jul 09 '24 05:07 evolross