-
-
Notifications
You must be signed in to change notification settings - Fork 17
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
Nested merge and patch #21
Comments
"/properties/include" is the object "{ "$ref": "#/definitions/settings" }", it is not replaced with the contents of /definitions/settings. The error says that this object doesn't have property "properties/client/items" - it indeed does not. In general, "$ref" is delegation, not inclusion. From this point of view using "$ref" inside "$merge" was a mistake, as inside merge it actually includes the schema. |
Hi, Sorry, I should have been more clear. That's my schema definitions but before I run the merge/patch I resolve all of the references using a library called json-schema-deref. So when I run the merge and patch there are definitely no $ref's in the schema. I just thought that the error message saying
couldn't be found was because the inner merge may not have been applied yet. The tree inside the exception message (my last script block in the first message) gives the indication that the inner transform may not have been applied as it appears to still include the $merge property as the top level element: tree: { '$merge': { source: [Object], with: [Object] } } } I've tried running the merge on its own and the patch without the inner merge but instead with the original schema and both of those work okay. |
A small test case I've come up with const Ajv = require("ajv")
const ajv = new Ajv({allErrors: true, v5: true})
ajv.addMetaSchema(require('ajv/lib/refs/json-schema-draft-06.json'));
require('ajv-merge-patch')(ajv);
const schema = {
$merge: {
source: {
type: "object",
properties: {
hello: { type: "string" }
},
required: ["hello"],
additionalProperties: false
},
with: {
properties: {
goodbye: { type: "string" }
},
required: ["goodbye"]
}
}
}
const justMergeValidator = ajv.compile(schema)
console.log(justMergeValidator({ hello: "", goodbye: "" }) === true)
console.log(justMergeValidator({ hello: "" }) === false)
const schemaPatch = {
$patch: {
source: {
type: "object",
properties: {
hello: { type: "string" }
},
required: ["hello"],
additionalProperties: false
},
with: [{
op: "replace",
path: "/additionalProperties",
value: true
}]
}
}
const justPatchValidator = ajv.compile(schemaPatch)
console.log(justPatchValidator({ hello: "", goodbye: "" }) === true)
const schemaMergePatch = {
$patch: {
source: {
$merge: {
source: {
type: "object",
properties: {
hello: { type: "string" }
},
required: ["hello"],
additionalProperties: false
},
with: {
properties: {
goodbye: { type: "string" }
},
required: ["goodbye"]
}
}
},
with: [{
op: "replace",
path: "/additionalProperties",
value: true
}]
}
}
try {
const mergePatchValidator = ajv.compile(schemaMergePatch)
console.log(mergePatchValidator({ hello: "", goodbye: "" }) === true)
console.log(mergePatchValidator({ hello: "", goodbye: "", addtional: "" }) === true)
console.log(mergePatchValidator({ hello: "", addtional: "" }) === false)
}
catch(e) {
console.error(e)
} It outputs:
|
it doesn't process them from the inside, the outside keywords are processed first. |
Hi,
I'm not sure if this is an issue with my understand of the spec or not. I understand merge a lot better than patch and so I'd like to use it where possible and then patch things I can't fix with merge. However, I'm having difficulty applying a patch to a schema who's source I apply a merge:
deliver.json
and my new schema:
x.json
I get the error message:
Is this expected? I'm not sure if this kind of thing is allowed under the specification but if it were then I think the order the transformations are applied would need to be altered.
Thanks
The text was updated successfully, but these errors were encountered: