MinimalTestCsc¶
- class lsst.ts.authorize.MinimalTestCsc(index: int, config_dir: None | str = None, initial_state: State = State.STANDBY, simulation_mode: int = 0)¶
- Bases: - BaseCsc- A mimial “Test” CSC that is not configurable. - By being non-configurable it simplifies the conda build. - Attributes Summary - Return True if the summary state is - State.DISABLEDor- State.ENABLED.- Get the current simulation mode. - Get the summary state as a - Stateenum.- Methods Summary - add_arguments(parser)- Add arguments to the parser created by - make_from_cmd_line.- add_kwargs_from_args(args, kwargs)- Add constructor keyword arguments based on parsed arguments. - amain(index, **kwargs)- Make a CSC from command-line arguments and run it. - assert_enabled([action])- Assert that an action that requires ENABLED state can be run. - begin_disable(data)- Begin do_disable; called before state changes. - begin_enable(data)- Begin do_enable; called before state changes. - begin_exitControl(data)- Begin do_exitControl; called before state changes. - begin_standby(data)- Begin do_standby; called before the state changes. - begin_start(data)- Begin do_start; called before state changes. - check_for_duplicate_heartbeat([num_messages])- Monitor heartbeat events and return True if any have a different private_origin. - close([exception, cancel_start])- Shut down, clean up resources and set done_task done. - Shut down pending tasks. - do_disable(data)- Transition from - State.ENABLEDto- State.DISABLED.- do_enable(data)- Transition from - State.DISABLEDto- State.ENABLED.- do_exitControl(data)- Transition from - State.STANDBYto- State.OFFLINEand quit.- do_fault(data)- Execute the fault command. - do_setArrays(data)- Execute the setArrays command. - do_setAuthList(data)- Update the authorization list. - do_setLogLevel(data)- Set logging level. - do_setScalars(data)- Execute the setScalars command. - do_standby(data)- Transition from - State.DISABLEDor- State.FAULTto- State.STANDBY.- do_start(data)- Transition from - State.STANDBYto- State.DISABLED.- do_wait(data)- Execute the wait command. - end_disable(data)- End do_disable; called after state changes but before command acknowledged. - end_enable(data)- End do_enable; called after state changes but before command acknowledged. - end_exitControl(data)- End do_exitControl; called after state changes but before command acknowledged. - end_standby(data)- End do_standby; called after state changes but before command acknowledged. - end_start(data)- End do_start; called after state changes but before command acknowledged. - fault(code, report[, traceback])- Enter the fault state and output the - errorCodeevent.- Called when the summary state has changed. - implement_simulation_mode(simulation_mode)- Implement going into or out of simulation mode. - make_from_cmd_line(index[, check_if_duplicate])- Construct a CSC from command line arguments. - Output the logLevel event. - set_simulation_mode(simulation_mode)- Set the simulation mode. - start()- Finish constructing the CSC. - Handle the initial state. - Attributes Documentation - default_initial_state: State = 5¶
 - disabled_or_enabled¶
- Return True if the summary state is - State.DISABLEDor- State.ENABLED.- This is useful in - handle_summary_stateto determine if you should start or stop a telemetry loop, and connect to or disconnect from an external controller
 - domain¶
 - enable_cmdline_state = False¶
 - simulation_mode¶
- Get the current simulation mode. - 0 means normal operation (no simulation). - Raises
- ExpectedError
- If the new simulation mode is not a supported value. 
 
 
 - summary_state¶
- Get the summary state as a - Stateenum.
 - version = '?'¶
 - Methods Documentation - classmethod add_arguments(parser: ArgumentParser) None¶
- Add arguments to the parser created by - make_from_cmd_line.- Parameters
- parserargparse.ArgumentParser
- The argument parser. 
 
- parser
 - Notes - If you override this method then you should almost certainly override - add_kwargs_from_argsas well.
 - classmethod add_kwargs_from_args(args: Namespace, kwargs: dict[str, Any]) None¶
- Add constructor keyword arguments based on parsed arguments. - Parameters
- argsargparse.Namespace
- Parsed command. 
- kwargsdict
- Keyword argument dict for the constructor. Update this based on - args. The index argument will already be present if relevant.
 
- args
 - Notes - If you override this method then you should almost certainly override - add_argumentsas well.
 - async classmethod amain(index: int | enum.IntEnum | bool | None, **kwargs: Any) None¶
- Make a CSC from command-line arguments and run it. - Parameters
- indexint,enum.IntEnum,True, orNone
- If the CSC is indexed, do one of the following: - Specify - Trueto make- indexa required command-line argument that accepts any nonzero index.
- Specify an - enum.IntEnumclass to make- indexa required command-line argument that only accepts the enum values.
- Specify a non-zero integer to use that index. This is rare; if the CSC is indexed then the user should usually be allowed to specify the index. 
 - If the CSC is not indexed, specify - Noneor 0.
- **kwargsdict, optional
- Additional keyword arguments for your CSC’s constructor. 
 
- index
 
 - assert_enabled(action: str = '') None¶
- Assert that an action that requires ENABLED state can be run. - Parameters
- actionstr, optional
- Action attempted. Not needed if this is called at the beginning of a - do_...method, since the user will know what command was called.
 
- action
 
 - async begin_disable(data: BaseMsgType) None¶
- Begin do_disable; called before state changes. - Parameters
- dataDataType
- Command data 
 
- data
 
 - async begin_enable(data: BaseMsgType) None¶
- Begin do_enable; called before state changes. - Parameters
- dataDataType
- Command data 
 
- data
 
 - async begin_exitControl(data: BaseMsgType) None¶
- Begin do_exitControl; called before state changes. - Parameters
- dataDataType
- Command data 
 
- data
 
 - async begin_standby(data: BaseMsgType) None¶
- Begin do_standby; called before the state changes. - Parameters
- dataDataType
- Command data 
 
- data
 
 - async begin_start(data: BaseMsgType) None¶
- Begin do_start; called before state changes. - Parameters
- dataDataType
- Command data 
 
- data
 
 - async check_for_duplicate_heartbeat(num_messages: int = 5) int¶
- Monitor heartbeat events and return True if any have a different private_origin. - Intended for use by check_if_duplicate. - The heartbeat loop should be running before this is called. This avoids the issue that if 2 CSCs are started at the same time then neither will see the other one’s heartbeat. This code also assumes that will be true; it will likely raise asyncio.TimeoutError if not. 
 - async close(exception: Exception | None = None, cancel_start: bool = True) None¶
- Shut down, clean up resources and set done_task done. - May be called multiple times. The first call closes the Controller; subsequent calls wait until the Controller is closed. - Subclasses should override - close_tasksinstead of- close, unless you have a good reason to do otherwise.- Parameters
- exceptionException, optional
- The exception that caused stopping, if any, in which case the - self.done_taskexception is set to this value. Specify- Nonefor a normal exit, in which case the- self.done_taskresult is set to- None.
- cancel_startbool, optional
- Cancel the start task? Leave this true unless calling this from the start task. 
 
- exception
 - Notes - Removes the SAL log handler, calls - close_tasksto stop all background tasks, pauses briefly to allow final SAL messages to be sent, then closes the dds domain.
 - async do_disable(data: BaseMsgType) None¶
- Transition from - State.ENABLEDto- State.DISABLED.- Parameters
- datacmd_disable.DataType
- Command data 
 
- data
 
 - async do_enable(data: BaseMsgType) None¶
- Transition from - State.DISABLEDto- State.ENABLED.- Parameters
- datacmd_enable.DataType
- Command data 
 
- data
 
 - async do_exitControl(data: BaseMsgType) None¶
- Transition from - State.STANDBYto- State.OFFLINEand quit.- Parameters
- datacmd_exitControl.DataType
- Command data 
 
- data
 
 - async do_fault(data: BaseMsgType) None¶
- Execute the fault command. - Change the summary state to State.FAULT 
 - async do_setArrays(data: BaseMsgType) None¶
- Execute the setArrays command. 
 - async do_setAuthList(data: BaseMsgType) None¶
- Update the authorization list. - Parameters
- datacmd_setAuthList.DataType
- Authorization lists. 
 
- data
 - Notes - Add items if the data string starts with “+”, ignoring duplicates (both with respect to the existing items and within the data string). Remove items if the data string starts with “-”, ignoring missing items (items specified for removal that do not exist). Ignore whitespace after each comma and after the +/- prefix. 
 - async do_setLogLevel(data: BaseMsgType) None¶
- Set logging level. - Parameters
- datacmd_setLogLevel.DataType
- Logging level. 
 
- data
 
 - async do_setScalars(data: BaseMsgType) None¶
- Execute the setScalars command. 
 - async do_standby(data: BaseMsgType) None¶
- Transition from - State.DISABLEDor- State.FAULTto- State.STANDBY.- Parameters
- datacmd_standby.DataType
- Command data 
 
- data
 
 - async do_start(data: BaseMsgType) None¶
- Transition from - State.STANDBYto- State.DISABLED.- Parameters
- datacmd_start.DataType
- Command data 
 
- data
 
 - async do_wait(data: BaseMsgType) None¶
- Execute the wait command. - Wait for the specified time and then acknowledge the command using the specified ack code. 
 - async end_disable(data: BaseMsgType) None¶
- End do_disable; called after state changes but before command acknowledged. - Parameters
- dataDataType
- Command data 
 
- data
 
 - async end_enable(data: BaseMsgType) None¶
- End do_enable; called after state changes but before command acknowledged. - Parameters
- dataDataType
- Command data 
 
- data
 
 - async end_exitControl(data: BaseMsgType) None¶
- End do_exitControl; called after state changes but before command acknowledged. - Parameters
- dataDataType
- Command data 
 
- data
 
 - async end_standby(data: BaseMsgType) None¶
- End do_standby; called after state changes but before command acknowledged. - Parameters
- dataDataType
- Command data 
 
- data
 
 - async end_start(data: BaseMsgType) None¶
- End do_start; called after state changes but before command acknowledged. - Parameters
- dataDataType
- Command data 
 
- data
 
 - async fault(code: int | None, report: str, traceback: str = '') None¶
- Enter the fault state and output the - errorCodeevent.
 - async handle_summary_state() None¶
- Called when the summary state has changed. - Override to perform tasks such as starting and stopping telemetry (example). - Notes - The versions in - BaseCscand- ConfigurableCscdo nothing, so if you subclass one of those you do not need to call- await super().handle_summary_state().
 - async implement_simulation_mode(simulation_mode: int) None¶
- Implement going into or out of simulation mode. - Deprecated. See simulation mode for details. - Parameters
- simulation_modeint
- Requested simulation mode; 0 for normal operation. 
 
- simulation_mode
- Raises
- ExpectedError
- If - simulation_modeis not a supported value.
 
 
 - classmethod make_from_cmd_line(index: int | enum.IntEnum | bool | None, check_if_duplicate: bool = False, **kwargs: Any) BaseCsc¶
- Construct a CSC from command line arguments. - Parameters
- indexint,enum.IntEnum,True, orNone
- If the CSC is indexed, do one of the following: - Specify - Trueto make- indexa required command-line argument that accepts any nonzero index.
- Specify an - enum.IntEnumclass to make- indexa required command-line argument that only accepts the enum values.
- Specify a non-zero integer to use that index. This is rare; if the CSC is indexed then the user should usually be allowed to specify the index. 
 - If the CSC is not indexed, specify - Noneor 0.
- check_if_duplicatebool, optional
- Check for heartbeat events from the same SAL name and index at startup (before starting the heartbeat loop)? The default is False, to match the BaseCsc default. Note: handled by setting the attribute directly instead of as a constructor argument, because CSCs may not all support the constructor argument. 
- **kwargsdict, optional
- Additional keyword arguments for your CSC’s constructor. 
 
- index
- Returns
- csccls
- The CSC. 
 
- csc
 - Notes - To add additional command-line arguments, override - add_argumentsand- add_kwargs_from_args.
 - async set_simulation_mode(simulation_mode: int) None¶
- Set the simulation mode. - Await implement_simulation_mode, update the simulation mode property and report the new value. - Parameters
- simulation_modeint
- Requested simulation mode; 0 for normal operation. 
 
- simulation_mode
 
 - async start() None¶
- Finish constructing the CSC. - Call - set_simulation_mode. If this fails, set- self.start_taskto the exception, call- stop, making the CSC unusable, and return.
- Call - handle_summary_state
- Set - self.start_taskdone.