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

Bug/1056 clinical download #721

Open
wants to merge 3 commits into
base: develop
Choose a base branch
from

Conversation

ciaranschutte
Copy link
Contributor

@ciaranschutte ciaranschutte commented Jan 23, 2025

Description of changes

Type of Change

  • Bug
  • New Feature

@ciaranschutte
Copy link
Contributor Author

investigating failing build in CI

Comment on lines +105 to +106
summary: Download clinical data for all available files from filter.
description: Download clinical data for all available files from filter.
Copy link
Member

Choose a reason for hiding this comment

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

thinking this may be a valid nuance?

Suggested change
summary: Download clinical data for all available files from filter.
description: Download clinical data for all available files from filter.
summary: Download clinical data for all available files from (optional) filters.
description: Download clinical data for all available files from (optional) filters.

Copy link
Member

Choose a reason for hiding this comment

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

thinking further on this, the "all" part of this endpoint implies to me no filtering should be possible. I mean why would a query give you partial results, unless it is due to pagination or hard limits?

@@ -0,0 +1,95 @@
import { ADVERTISED_HOST } from 'config';
Copy link
Member

Choose a reason for hiding this comment

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

naive question: is config an npm package or an internal module with an absolute path? if the latter, this looks weird in the same set of imports as the rest.

try {
const queryClient = createQueryClient({ requestConfig });
const queryVariables = { filters: requestFilter };
// need two queries to pass "total" into hits filter to specify offset range
Copy link
Member

@justincorrigible justincorrigible Jan 24, 2025

Choose a reason for hiding this comment

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

not sure it's helpful, just sharing unfinished/raw thoughts I got from reading this:

without sufficient context, this comment doesn't really add much clarity, neither of the intent nor the results. that is to say that line 75 is not exactly readable in terms of what the server will do with the values passed in.
"totalData" in contrast to "partialData", "uncertainData" or "doubtfulData"?

Copy link
Member

@justincorrigible justincorrigible Jan 24, 2025

Choose a reason for hiding this comment

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

...for instance, line 76 does say "this gets the total number of hits" -> a single absolute numerical value. clear. but totalData would be that "total hits" + what "total" else?

not sure I'm making sense... but the code + comment seem opaque/arcane to me, is ultimately my point.

Copy link
Member

@justincorrigible justincorrigible Jan 24, 2025

Choose a reason for hiding this comment

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

ok. rereading these lines a few more times, I think the issue I'm having is in how the code is separated into different lines; and that forces variable creation for every step, which in turn brings out how naming things is hard... cognitive burden multiplied.

so, suggestion: it occurs to me lines 75 - 76 could look more like the following (which I realize mixes then and await), but conceptually explains better the intent:

const totalHits = await queryClient({ 
  query: makeRequest({ query: totalQuery, variables: queryVariables })
}).then(response => get(response, 'data.file.hits.total'));

...maybe query client should also take a callback as an optional param?
"in case you want to do something with the response".

const totalHits = await queryClient({ 
  query: makeRequest({ query: totalQuery, variables: queryVariables }),
  callback: response => get(response, 'data.file.hits.total'),
});

this doesn't really explain why the "totalHits" is needed, which is then easier to describe in the comment

@@ -172,6 +160,63 @@ const createClincalApiRouter = async (esClient: Client, egoClient: EgoClient) =>
});
}
});

router.use('/donors/data-for-all-files', async (req: AuthenticatedRequest, res) => {
Copy link
Member

Choose a reason for hiding this comment

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

if a filter is passed, this should be read as "'some' data about 'some' of the files".

I think "all" here is either redundant or misleading, unless it actually means "'some' data for all the files", which is not immediately explicit in the name

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.

2 participants