Augment Local Env With Coordinator-side Remote Env#1889
Conversation
…ed methods Signed-off-by: Bastian Krause <bst@pengutronix.de>
Signed-off-by: Bastian Krause <bst@pengutronix.de>
Signed-off-by: Bastian Krause <bst@pengutronix.de>
Signed-off-by: Bastian Krause <bst@pengutronix.de>
…nfig() Signed-off-by: Bastian Krause <bst@pengutronix.de>
Signed-off-by: Bastian Krause <bst@pengutronix.de>
Codecov Report❌ Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## master #1889 +/- ##
========================================
- Coverage 46.0% 45.8% -0.2%
========================================
Files 180 180
Lines 14464 14561 +97
========================================
+ Hits 6654 6674 +20
- Misses 7810 7887 +77
Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Harness. |
|
Hi @Bastian-Krause, Sorry for the late reply, I only found time to look at this now. Overall, the approach makes sense to me. In the meeting I mentioned defining this kind of configuration via the exporters, mainly because I had the case in mind where the person changing the hardware is physically close to the setup and could update the configuration directly there. But if the remote environment can be edited via the client, then that requirement mostly goes away. I have a few questions/comments: First, I am wondering about the relationship between places and targets in this model. So far I have thought of a place mostly as a named group of hardware resources, while a target describes how that hardware is used for a specific use case. With the current implementation, is it possible to store more than one remote environment for a single place? I think this could be useful, for example if the same hardware setup can be used in different ways. On the CLI side, selecting one of multiple remote environments might be relatively straightforward, but I am not sure yet what the best interface would be. Second, I would like to better understand the intended scope of this feature. Is the goal mainly to augment a local environment with configuration from the coordinator, or is it also intended to allow some users to avoid local env files completely? I think the latter is already achieved within the PR. If one user has configured the remote environment for a place, another user can directly use it without interacting with any env file at all. I think that would be a really nice property for larger labs. One more related point: in the example, I saw a Regarding storage, I do not have a very strong opinion yet, but my first preference would probably be something versioned :) Those were the main things that came to my mind. I would also be happy to help with some of the open tasks if needed. |
Description
In larger labs, maintaining and distributing environment configs for all the different places can become cumbersome. Defining resources, drivers, feature and options per place in the coordinator could help solve that problem.
This prototype adds a remote_env attribute to the Place class, a SetPlaceRemoteEnv method to the Coordinator class and a new sub command
labgrid-client editto edit the remote environment. The remote environment is printed inlabgrid-client showandlabgrid-client env. The RemotePlaceManager creates resources and drivers after expanding resource matches. If a local environment exists, it is augmented with the remote environment.This is a prototype. Open tasks:
RemotePlace.ignore_drivers/RemotePlace.ignore_resourcesFollow-up tasks could be
labgrid-client editlabgrid-client editMinimal test with
labgrid-clientSave this in your editor:
Minimal test with
pytest(using the place created above in "Minimal test withlabgrid-client")env.yaml:
$ pytest --lg-env env.yamlChecklist
Related to #1866