-
-
Notifications
You must be signed in to change notification settings - Fork 3.9k
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
Hydrate from JSON not hydrating populated virtual objects #14503
Labels
confirmed-bug
We've confirmed this is a bug in Mongoose and will fix it.
Milestone
Comments
ilovepixelart
changed the title
Hygrate from JSON not hydrating populated virtual objects
Hydrate from JSON not hydrating populated virtual objects
Apr 5, 2024
IslandRhythms
added
the
confirmed-bug
We've confirmed this is a bug in Mongoose and will fix it.
label
Apr 9, 2024
import { Schema, model, connect, Types, connection } from 'mongoose'
import * as assert from 'assert';
interface IStory {
_id: Schema.Types.ObjectId,
userId: Schema.Types.ObjectId,
title: string,
createdAt: Date
}
interface IUser {
name: string,
role: string,
age: number,
stories: [IStory]
}
const StorySchema = new Schema<IStory>({
userId: {
type: Schema.Types.ObjectId,
ref: 'User',
required: true,
index: true,
},
title: {
type: String,
required: true,
},
}, { timestamps: true })
const UserSchema = new Schema<IUser>({
name: {
type: String,
required: true,
},
role: {
type: String,
required: true,
},
age: {
type: Number,
},
}, { timestamps: true })
UserSchema.virtual('stories', {
ref: 'Story',
localField: '_id',
foreignField: 'userId',
});
const User = model('User', UserSchema);
const Story = model('Story', StorySchema);
async function run() {
await connect('mongodb://localhost:27017');
await connection.dropDatabase();
const user = await User.create({ name: 'Alex', role: 'user' })
const story1 = await Story.create({ title: 'Ticket 1', userId: user._id })
const story2 = await Story.create({ title: 'Ticket 2', userId: user._id })
const populated = await User.findOne({ name: 'Alex' }).populate('stories').lean();
console.log('what is populated', populated);
assert(populated);
assert(populated?._id instanceof Types.ObjectId)
assert.equal(populated.name, 'Alex');
assert(populated.stories);
assert.equal(populated.stories.length, 2)
const populatedJson = JSON.stringify(populated)
assert(populatedJson)
const hydrated = User.hydrate(JSON.parse(populatedJson))
console.log('what is hydrated', hydrated)
// Will fail here populated stories array is not hydrated _id and createdAt updatedAt are strings
assert.equal(hydrated.stories[0]._id.toString(), story1._id.toString());
console.log(typeof hydrated.stories[0]._id)
assert(typeof hydrated.stories[0]._id == 'object');
assert(hydrated?.stories?.[0]._id instanceof Types.ObjectId)
assert(typeof hydrated?.stories?.[0].createdAt == 'object');
assert(hydrated?.stories?.[0].createdAt instanceof Date)
/*
assert.equal(hydrated?.stories?.[1]._id.toString(), story2._id.toString())
assert(typeof hydrated?.stories?.[1]._id == 'object')
assert(hydrated?.stories?.[1]._id instanceof Types.ObjectId);
assert(typeof hydrated?.stories?.[1].createdAt == 'object')
assert(hydrated?.stories?.[1].createdAt instanceof Date)
*/
}
run(); |
This issue comes down to the fact that |
vkarpov15
added a commit
that referenced
this issue
Apr 23, 2024
#14533 has a fix. You will need to call hydrate with |
vkarpov15
added a commit
that referenced
this issue
Apr 24, 2024
Make `hydrate()` recursively hydrate virtual populate docs if `hydratedPopulatedDocs` is set
This was referenced May 21, 2024
This was referenced May 21, 2024
Merged
This was referenced Jun 7, 2024
This was referenced Jun 9, 2024
This was referenced Jun 12, 2024
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Prerequisites
Mongoose version
8.2.4
Node.js version
20.12.1
MongoDB server version
7.0.7
Typescript version (if applicable)
5.4.3
Description
Consider such example
Story.ts
User.ts
hydrate-populate-from-json.test.ts
Weird thing, when I use:
Then even the root object now is not hydrated (_id and dates will be strings even on root level)
Steps to Reproduce
Check the description models and test provided
Expected Behavior
After hydrating json I expect to receive list of populated virtuals also in hydrated form
The text was updated successfully, but these errors were encountered: