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

Fixed the extractSetOfValueSetsFromLibrary function in CodeService.js… #35

Closed

Conversation

sorliog
Copy link

@sorliog sorliog commented Sep 23, 2024

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 the valueSets property (using library.valueSets). Additionally, for backward compatibility, I also use library.valuesets property to extract value sets.

… to extract value sets contained in the "valueSets" property and the "valuesets" property
Copy link
Member

@cmoesel cmoesel left a 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.

@sorliog
Copy link
Author

sorliog commented Sep 24, 2024

@cmoesel Thank you for reviewing my PR. I ran npm audit fix and committed the code in package-lock.json. Please rerun the CI workflow.

Copy link
Member

@cmoesel cmoesel left a 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.

@sorliog
Copy link
Author

sorliog commented Sep 24, 2024

@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 prettier script and committed the code. Hopefully, that solves it.

Copy link
Member

@cmoesel cmoesel left a 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.

@sorliog
Copy link
Author

sorliog commented Sep 26, 2024

@cmoesel Thank you for the clarification. I assume that if the valuesets property of the Library class was simply renamed to valueSets, it would solve the issue of using both a ELM library or the Library class. But that would require all references in all repos that depend on it to be refactored.
What I don't understand is why reading both library.valuesets and library.valueSets would introduce problems in other projects. After all, if other project use library.valuesets, and my code also reads and processes library.valuesets, it should be compatible?

Regarding the dereference errors, I see what the problem is. I can fix it, if you want to go through with the merge.

@cmoesel
Copy link
Member

cmoesel commented Oct 21, 2024

@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 (extractFromIncluded) is meaningless since there is no way to traverse included libraries from the ELM alone. Given that cql-execution is already a peer dependency, and you can create a library class from ELM pretty easily via new Library(myELM) (w/ optional 2nd argument for managing included libraries), it seems better to me if we avoid the confusion of trying to support both. Do you have a use case in which wrapping the ELM in a Library constructor is not feasible?

@sorliog
Copy link
Author

sorliog commented Oct 29, 2024

@cmoesel Thank you. I will use Library from cql-execution.

@sorliog sorliog closed this Oct 29, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants