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

Fix: Date search doesn't match ranges properly #4762

Draft
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

PTaladay
Copy link
Collaborator

@PTaladay PTaladay commented Dec 31, 2024

Description

Updates the logic to check if the date time is within the range on a given resource and if so will return that resource.

Related issues

Addresses [issue AB#131564].

Testing

Added additional unit test for validation and ran existing test to verify no new issues introduced.

FHIR Team Checklist

  • Update the title of the PR to be succinct and less than 65 characters
  • Add a milestone to the PR for the sprint that it is merged (i.e. add S47)
  • Tag the PR with the type of update: Bug, Build, Dependencies, Enhancement, New-Feature or Documentation
  • Tag the PR with Open source, Azure API for FHIR (CosmosDB or common code) or Azure Healthcare APIs (SQL or common code) to specify where this change is intended to be released.
  • Tag the PR with Schema Version backward compatible or Schema Version backward incompatible or Schema Version unchanged if this adds or updates Sql script which is/is not backward compatible with the code.
  • CI is green before merge Build Status
  • Review squash-merge requirements

Semver Change (docs)

Patch|Skip|Feature|Breaking (reason)

…and if included in the span that resource will be returned.
@PTaladay PTaladay added Bug Bug bug bug. Azure API for FHIR Label denotes that the issue or PR is relevant to the Azure API for FHIR Azure Healthcare APIs Label denotes that the issue or PR is relevant to the FHIR service in the Azure Healthcare APIs Open source This change is only relevant to the OSS code or release. labels Dec 31, 2024
@PTaladay PTaladay added this to the 2Wk07 milestone Dec 31, 2024
@PTaladay PTaladay requested a review from a team as a code owner December 31, 2024 19:54
@PTaladay PTaladay marked this pull request as draft December 31, 2024 20:00
@@ -65,7 +69,7 @@ public override Expression VisitMultiary(MultiaryExpression expression, object c
newExpressions.Add(expression.Expressions[^1]);
}

return newExpressions == null ? expression : Expression.And(newExpressions);
return newExpressions == null ? expression : checkDateTimeAgainstPeriod ? Expression.Or(Expression.And(newExpressions), Expression.And(dateInPeriodExpression)) : Expression.And(newExpressions);
Copy link
Member

Choose a reason for hiding this comment

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

nit: For clarity, I think we shouldn't nest ternary operators :)

@@ -214,5 +214,27 @@ public async Task GivenAnOutOfRangeDateTimeSearchParam_WhenSearched_ThenExceptio
fce.StatusCode == HttpStatusCode.BadRequest,
$"A '{nameof(FhirClientException)}' with '{HttpStatusCode.BadRequest}' status code was expected, but instead a '{nameof(FhirClientException)}' with '{fce.StatusCode}' status code was raised. Url: {Client.HttpClient.BaseAddress}. Activity Id: {fce.Response.GetRequestId()}. Error: {fce.Message}");
}

[Theory]
[InlineData("1981-05-16T16:32:15.500", 7)] // This should include the observation containing a period since the date is in that effective period.
Copy link
Collaborator

Choose a reason for hiding this comment

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

This test shouldn't pass. The search is for 1981 but the data is in 1980.


checkDateTimeAgainstPeriod = true;
dateInPeriodExpression.Add(new BinaryExpression(high.BinaryOperator, low.FieldName, low.ComponentIndex, low.Value));
dateInPeriodExpression.Add(new BinaryExpression(low.BinaryOperator, high.FieldName, high.ComponentIndex, high.Value));
Copy link
Collaborator

Choose a reason for hiding this comment

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

I think this could be simplified by having it be:

newExpressions.Add(new BinaryExpression(high.BinaryOperator, low.FieldName, low.ComponentIndex, high.Value));
newExpressions.Add(new BinaryExpression(low.BinaryOperator, high.FieldName, high.ComponentIndex, low.Value));

You could then remove the dateInPeriodExpression variable, the old newExpressions assignments on lines 52-54, and the Or Expression on line 72.

The current generated SQL is

(StartDateTime >= '2022-05-01T00:00:00.0000000Z' AND StartDateTime <= '2022-05-01T23:59:59.9999999Z' AND EndDateTime <= '2022-05-01T23:59:59.9999999Z' )
OR 
(StartDateTime <= '2022-05-01T00:00:00.0000000Z' AND EndDateTime >= '2022-05-01T23:59:59.9999999Z' )

and this would change it to be

StartDateTime <= '2022-05-01T23:59:59.9999999Z' AND EndDateTime >= '2022-05-01T00:00:00.0000000Z'

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Azure API for FHIR Label denotes that the issue or PR is relevant to the Azure API for FHIR Azure Healthcare APIs Label denotes that the issue or PR is relevant to the FHIR service in the Azure Healthcare APIs Bug Bug bug bug. Open source This change is only relevant to the OSS code or release.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants