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

Assign functionality to start & stop buttons #109

Merged
merged 4 commits into from
Dec 15, 2023
Merged

Assign functionality to start & stop buttons #109

merged 4 commits into from
Dec 15, 2023

Conversation

tsmbland
Copy link
Member

@tsmbland tsmbland commented Dec 13, 2023

Description

This PR adds functionality to the start, stop and restart buttons in the control app.

Most of the changes can be found in control.py. This used to contain one large callback function (update_button_click) responsible for all the button callbacks (which were mostly empty), but since #92 Adrian has started moving button callbacks into their own functions which I think is a good move so I've followed suit here. I have written three new callbacks for the start, stop and restart buttons. The start and stop buttons are responsible for starting/stopping the live model, which it does via the new start_model and stop_model functions in datahub_api.py. These interact with the DataHub API introduced in this PR, which modifies the DataHub variable model_running which is tracked by the model. I hope I've done this correctly, however it's difficult for me to test without access to the live model. The start/stop buttons also interact with data_interval to start/stop data and figure updates in the vis system. The restart button sends data_interval back to the beginning, which resets the pre-set data. It already effectively did this when connected to the OVE (via core.refresh_sections()), but now it also works outside the OVE. In theory I think this button should also send a restart signal to the model via the DataHub, but it doesn't seem to me like this is possible yet, so I've left this as a TODO. (EDIT: Actually I think stopping the model also restarts it, so this would just be a stop call followed by a start call - I will update)

I also had to rewrite some of the tests. The diffs look messy, but really I'm just moving the tests for each button into their own functions, and modifying tests for the start, stop and restart buttons in accordance with my changes.

Close #41 #61 #48

Type of change

  • New feature (non-breaking change which adds functionality)
  • Optimization (non-breaking, back-end change that speeds up the code)
  • Bug fix (non-breaking change which fixes an issue)
  • Breaking change (whatever its nature)

Key checklist

  • All tests pass (python -m pytest)
  • Pre-commit hooks run successfully (pre-commit run --all-files)

This was linked to issues Dec 13, 2023
@tsmbland tsmbland mentioned this pull request Dec 14, 2023
6 tasks
Base automatically changed from playback to main December 14, 2023 20:17
@tsmbland tsmbland marked this pull request as ready for review December 14, 2023 22:29
@tsmbland tsmbland requested a review from dalonsoa December 14, 2023 22:29
@tsmbland tsmbland linked an issue Dec 14, 2023 that may be closed by this pull request
5 tasks
Copy link
Contributor

@dalonsoa dalonsoa left a comment

Choose a reason for hiding this comment

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

I only have comments, not anything to change.

Having said that, I am not entirely sure this will have any effect in the backend. The functions you have added connect to endpoints that, essentially, just set flags. But those flags, as far as I can tell, do nothing. They are not used anywhere else to define the behavior of the model. For example, the reset_data function in here, which presumably brings the data model back to its initial state, is not used.

In summary, this PR looks good and is needed, but I'm not sure if it will work as intended without appropriate changes in the datahub.

app/datahub_api.py Show resolved Hide resolved
app/datahub_api.py Show resolved Hide resolved
app/pages/control.py Show resolved Hide resolved
app/pages/control.py Show resolved Hide resolved
@tsmbland
Copy link
Member Author

Having said that, I am not entirely sure this will have any effect in the backend. The functions you have added connect to endpoints that, essentially, just set flags. But those flags, as far as I can tell, do nothing. They are not used anywhere else to define the behavior of the model. For example, the reset_data function in here, which presumably brings the data model back to its initial state, is not used.

As discussed, I believe Yue's model will check the DataHub for the model_running flag to decide when to start/stop the model (see here and here). When stopping the model, I belive the model will then use the signal_model_ready API call to indicate to the DataHub when the model is ready to start again by setting the model_resetting flag. We probably need to use this flag in either the vis system or the DataHub to prevent the model from starting until it's ready, but this functionality doesn't appear to be in place without changes to the DataHub (as far as I can tell). Also, you're right that the reset_data function isn't used at all, and I imagine this should be included in one of the API calls.

I'm going to leave everything as it is for now and merge it, and will suggest that Adrian takes a look at this PR when he's back. I think it won't need any drastic changes, but Adrian knows how all the parts interact better than I do.

@tsmbland tsmbland merged commit 07ea5ac into main Dec 15, 2023
4 checks passed
@tsmbland tsmbland deleted the buttons branch December 15, 2023 11:24
@tsmbland
Copy link
Member Author

@AdrianDAlessandro Can you check the start and stop buttons, and add the desired behaviour for the restart button? It all works when using the pre-set data, but not really sure what's required for the live model

@AdrianDAlessandro
Copy link
Collaborator

@AdrianDAlessandro Can you check the start and stop buttons, and add the desired behaviour for the restart button? It all works when using the pre-set data, but not really sure what's required for the live model

Yes I checked them yesterday, they make the expected changes in the datahub, but the model needs to be developed to hook into the datahub, which is not up to us.

@tsmbland
Copy link
Member Author

Ok. The restart button doesn't send any signals yet, just refreshes the page and resets the counter. Is this what we want?

@AdrianDAlessandro
Copy link
Collaborator

Yea, should be fine. I can't see a simple way to send a stop and then start signal that doesn't cause a race condition with the Opal model

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.

Create Stop Model API call Backend for Control view Create start model API call
3 participants