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

Sort envs returned by REST API by current build's scheduled_on time #881

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

Conversation

peytondmurray
Copy link
Contributor

Fixes #859.

Description

This PR sorts environments returned when a GET is sent to /environment/ by the time the environments' current builds were submitted. In systems where users are creating environments while environments are being queried, this ensures that all results are returned; other sorting methods (e.g. by name) can yield incomplete results.

Pull request checklist

  • Did you test this change locally?
  • Did you update the documentation (if required)?
  • Did you add/update relevant tests for this change (if required)?

Copy link

netlify bot commented Sep 17, 2024

Deploy Preview for conda-store canceled.

Name Link
🔨 Latest commit 1371f2c
🔍 Latest deploy log https://app.netlify.com/sites/conda-store/deploys/67870faf32be8d0008c6d930

@peytondmurray peytondmurray force-pushed the 859-sorted-pagination branch 2 times, most recently from 7a9b540 to 0d57b2b Compare September 26, 2024 21:51
@peytondmurray peytondmurray force-pushed the 859-sorted-pagination branch from 871e0e3 to 0442238 Compare October 3, 2024 21:10
@peytondmurray peytondmurray changed the title [WIP] Sort envs returned by REST API by current build's scheduled_on time Sort envs returned by REST API by current build's scheduled_on time Oct 3, 2024
@peytondmurray peytondmurray marked this pull request as ready for review October 17, 2024 03:11
@peytondmurray peytondmurray requested a review from soapy1 October 17, 2024 03:11
@peytondmurray peytondmurray marked this pull request as draft October 17, 2024 18:36
@peytondmurray
Copy link
Contributor Author

After a discussion, it seems like no matter how we solve this there's going to be a breaking change to the API. Cursor-based pagination will allow for any sorting order, so I'll look into implementing that, probably through fastapi-pagination.

@peytondmurray
Copy link
Contributor Author

peytondmurray commented Oct 18, 2024

Adding pagination via fastapi-pagination seems simple on the surface, but they don't publish an API reference in the docs, so without reading the source for the project I'm not sure how it affects what query parameters are accepted by our API. So in the process of trying to implement this, I started working on adding hot reloading, but due to the fact that we're using traitlets to load server configuration (and instantiate the FastAPI app) and that uvicorn has specific requirements about how the FastAPI app is instantiated when hot reloading, it's trickier to get this working than I thought. See #901 for details.

@peytondmurray peytondmurray force-pushed the 859-sorted-pagination branch 2 times, most recently from 9e55051 to 847eed4 Compare November 1, 2024 21:28
@peytondmurray
Copy link
Contributor Author

Hot reloading's done, but the fastapi_pagination docs aren't enough to get this working easily, and in the time it would take to actually read through the source for the project I think we can just implement a simple cursor-based paginator instead :/

@peytondmurray peytondmurray force-pushed the 859-sorted-pagination branch 2 times, most recently from 7b5a0bc to dd5a139 Compare November 6, 2024 21:59
@peytondmurray peytondmurray force-pushed the 859-sorted-pagination branch 3 times, most recently from de37aea to b673196 Compare January 3, 2025 23:51
@peytondmurray peytondmurray force-pushed the 859-sorted-pagination branch from b673196 to 54f7907 Compare January 3, 2025 23:53
@peytondmurray peytondmurray force-pushed the 859-sorted-pagination branch 2 times, most recently from a48d833 to ee054f0 Compare January 14, 2025 22:51
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area: api 🌐 area: user experience 👩🏻‍💻 Items impacting the end-user experience needs: review 👀 type: bug 🐛 Something isn't working
Projects
Status: In Progress 🏗
Development

Successfully merging this pull request may close these issues.

[ENH] - Ensure completeness when fetching all pages using REST API
1 participant