-
Notifications
You must be signed in to change notification settings - Fork 7
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
Fixed the extractSetOfValueSetsFromLibrary function in CodeService.js… #35
Fixed the extractSetOfValueSetsFromLibrary function in CodeService.js… #35
Conversation
… to extract value sets contained in the "valueSets" property and the "valuesets" property
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for finding and fixing this. To be honest, I'm not sure how we've come this far without noticing it. I suspect that maybe when this was originally written, the CQL-to-ELM Translator may have exported ELM using valuesets
, but I don't think that's been the case for a while...
Our CI found that there is a dependency with a known vulnerability. While it's not directly related to your PR, might you be able to run npm audit fix
and update this PR so the CI runs clean? If that's too much trouble, let me know and I will accept as-is and follow up with another PR that fixes the vulnerability.
@cmoesel Thank you for reviewing my PR. I ran |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I apologize. I did not realize before that there is also a prettier code formatting error. To check your code against the lests, linter, and prettier, run:
npm run test:plus
You can automatically fix prettier violations by running:
npm run prettier:fix
This is documented at the bottom of the README.
I apologize for not catching that in my first review.
@cmoesel The style checks pass on my machine, and the workflow run on Github was not specific as to what caused the failure. I reran the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've tried these changes in some existing projects and I'm sorry to report that they introduce problems in some of those projects.
I've investigated and now I understand why it is the way it is. The library
that is passed in is not intended to be the literal JSON ELM library. It is intended to be an instance of the Library
class from cql-execution
. If you look at the source code, that Library
class has a valuesets
property (w/ lowercase s
). So this code is correct to use valuesets
rather than valueSets
.
You can construct a Library
class by passing in the JSON to the constructor (e.g., new Library(myLibraryElmJson)
) -- and then pass that as the library
argument in the ensure functions.
BTW -- the errors I ran into when I tried to run it were because library.valuesets
is sometimes an empty object ({})
, so then Object.values(library.valuesets)[0]
on line 244 results in undefined
, causing a dereference error on line 248.
@cmoesel Thank you for the clarification. I assume that if the Regarding the dereference errors, I see what the problem is. I can fix it, if you want to go through with the merge. |
@sorliog - I apologize for the long delay. I guess I'm not sure why we should support both the Library class and the ELM. When just the ELM is passed in, the second argument ( |
@cmoesel Thank you. I will use |
CQL JSON-ELM standard defines values sets in Libraries to utilize the
valueSets
property, as defined in the schema.The extractSetOfValueSetsFromLibrary in CodeService.js loops through a library formatted in JSON-ELM to find all declared value sets. Previously, it looked the the value sets using
library.valuesets
. This is not the proper property to lookup value sets, as defined in the afomentioned schema.In this pull request, I fixed the
extractSetOfValueSetsFromLibrary
function in CoderService.js to extract value sets contained in thevalueSets
property (usinglibrary.valueSets
). Additionally, for backward compatibility, I also uselibrary.valuesets
property to extract value sets.