-
Notifications
You must be signed in to change notification settings - Fork 27
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
aotf: load the schema for each workflow #1225
Comments
Since the UI only interacts with the UIS, how does it make sense to load a scheduler schema that might be incompatible with the UIS? |
Providing that the UIS passes the mutations through to the scheduler without meddling with them this should work fine.
The design and motive are documented here - cylc/cylc-flow#2123 tldr; We keep fiddling the workflow interfaces for valid reasons, adding mutations, options, etc. But our users have valid reasons for working with different versions of Cylc simultaneously (e.g. research & production workloads). This has caused a number of problems with GUIs over the years and has made user-facing documentation tricky. Note this is only for mutations, for queries / subscriptions the only thing we can do is to add back-compat in the UIS and try to handle forward compatibility breakages gracefully. In general we should expect the UI/UIS to be running at more recent versions. Related ideas (not documented anywhere yet):
|
See also cylc/cylc-uiserver#419
Presently the UI loads the UIS schema from which it gets the list of mutations.
This means that if the UIS is talking to two schedulers with different mutations (e.g. different Cylc versions), then mutations issued to one of the two will be drawn up with the wrong schema and will fail if the interfaces differ.
Rather than loading the schema once per-app, we should load it once-per-workflow.
Note: Since the AOTF work was put in, we have come to rely on introspection for the edit-runtime forms too, the same problem applies here also.
Pull requests welcome!
The text was updated successfully, but these errors were encountered: