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

Suspend functions to evaluate fhirpath expressions #2678

Open
wants to merge 14 commits into
base: master
Choose a base branch
from

Conversation

LZRS
Copy link
Collaborator

@LZRS LZRS commented Sep 26, 2024

IMPORTANT: All PRs must be linked to an issue (except for extremely trivial and straightforward changes).

Fixes #2677

Description
Clear and concise code change description.

Alternative(s) considered
Have you considered any alternatives? And if so, why have you chosen the approach in this PR?

Type
Choose one: (Bug fix | Feature | Documentation | Testing | Code health | Builds | Releases | Other)

Screenshots (if applicable)

Checklist

  • I have read and acknowledged the Code of conduct.
  • I have read the Contributing page.
  • I have signed the Google Individual CLA, or I am covered by my company's Corporate CLA.
  • I have discussed my proposed solution with code owners in the linked issue(s) and we have agreed upon the general approach.
  • I have run ./gradlew spotlessApply and ./gradlew spotlessCheck to check my code follows the style guide of this project.
  • I have run ./gradlew check and ./gradlew connectedCheck to test my changes locally.
  • I have built and run the demo app(s) to verify my change fixes the issue and/or does not break the demo app(s).

Copy link
Collaborator

@MJ1998 MJ1998 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actually what I notice is that these "non-suspend" functions are being invoked from suspend functions only.

So instead of making each function suspend what if we make the source of flow to run on default dispatcher ? In class QuestionnaireViewModel, we could add flowOn operator to the questionnaireStateFlow

@LZRS
Copy link
Collaborator Author

LZRS commented Oct 7, 2024

Actually what I notice is that these "non-suspend" functions are being invoked from suspend functions only.

So instead of making each function suspend what if we make the source of flow to run on default dispatcher ? In class QuestionnaireViewModel, we could add flowOn operator to the questionnaireStateFlow

Okay, cool. I can try it out, not sure how we will handle passing testDispatcher for tests though. That is, in the QuestionnaireViewModelTest

@LZRS LZRS force-pushed the 2677-suspend-fhirpathengine branch from 5ed5f95 to eb755f9 Compare November 27, 2024 10:03
LZRS added 2 commits December 5, 2024 18:02
for page items to be validated. Previous 'currentPageItems' variable
would get mutated multiple times within `getQuestionnaireAdapterItems` when evaluating
nested questionnaire items
@LZRS
Copy link
Collaborator Author

LZRS commented Dec 5, 2024

Also to fix #2646 (comment)

@LZRS LZRS force-pushed the 2677-suspend-fhirpathengine branch from 68f672b to f369d51 Compare December 6, 2024 11:25
@LZRS LZRS marked this pull request as ready for review December 9, 2024 13:24
@LZRS LZRS requested a review from a team as a code owner December 9, 2024 13:24
@LZRS LZRS requested a review from MJ1998 December 9, 2024 13:24
@LZRS LZRS force-pushed the 2677-suspend-fhirpathengine branch from 393ad27 to f369d51 Compare December 10, 2024 12:39
ndegwamartin added a commit to opensrp/android-fhir that referenced this pull request Dec 11, 2024
FORK
                - With unmerged PR #9
                - WUP  #13

SDK
                - WUP google#2178
                - WUP google#2650
                - WUP google#2645
                - WUP google#2678
                - WUP google#2755
LZRS added 2 commits December 14, 2024 20:57
getting rid of dependecny on `forceValidation` toggle variable and
instead add all current page items to the modifiedQuestionnaireResponseItemSet
@LZRS LZRS force-pushed the 2677-suspend-fhirpathengine branch from 3347ee3 to 7d105ba Compare December 16, 2024 10:03
@LZRS LZRS requested a review from FikriMilano December 17, 2024 07:33
ndegwamartin added a commit to opensrp/android-fhir that referenced this pull request Jan 15, 2025
FORK
    - With unmerged PR #9
    - WUP  #13

SDK
    - WUP google#2178
    - WUP google#2650
    - WUP google#2645
    - WUP google#2678
    - WUP google#2755
ndegwamartin added a commit to opensrp/android-fhir that referenced this pull request Jan 15, 2025
FORK
    - With unmerged PR #9
    - WUP  #13

SDK
    - WUP google#2178
    - WUP google#2650
    - WUP google#2645
    - WUP google#2678
    - WUP google#2755
ndegwamartin added a commit to opensrp/android-fhir that referenced this pull request Jan 17, 2025
    FORK
        - With unmerged PR #9
        - WUP  #13

    SDK
        - WUP google#2178
        - WUP google#2650
        - WUP google#2645
        - WUP google#2678
        - WUP google#2755
        - WUP #17
ndegwamartin added a commit to opensrp/android-fhir that referenced this pull request Jan 22, 2025
FORK
    - With unmerged PR #9
    - WUP  #13
    - WUP #17

SDK
    - WUP google#2178
    - WUP google#2650
    - WUP google#2645
    - WUP google#2678
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: PR under Review
Development

Successfully merging this pull request may close these issues.

Wrap Fhirpath method evaluation calls to run from a different coroutineContext
4 participants