blob: ca406c99a774d087e27ab549820de7b5afe84b32 [file] [log] [blame] [edit]
#!/usr/bin/env python3
r"""
This module contains functions for tftp update.
"""
import gen_print as gp # NOQA
import state as st
def get_pre_reboot_state():
r"""
Get and return a custom state which is comprised of the
st.default_req_states plus epoch_seconds.
"""
global state
req_states = ["epoch_seconds"] + st.default_req_states
gp.qprint_timen("Get system state.")
state = st.get_state(req_states=req_states, quiet=0)
gp.qprint_var(state)
return state
def wait_for_reboot(start_boot_seconds, wait_state_check=True):
r"""
Wait for the BMC to complete a previously initiated reboot.
Description of argument(s):
start_boot_seconds The time that the boot test started. The format is the
epoch time in seconds, i.e. the number of seconds since
1970-01-01 00:00:00 UTC. This value should be obtained
from the BMC so that it is not dependent on any kind of
synchronization between this machine and the target BMC
This will allow this program to work correctly even in
a simulated environment. This value should be obtained
by the caller prior to initiating a reboot. It can be
obtained as follows:
state = st.get_state(req_states=['epoch_seconds'])
wait_state_check By default check the state, ignore if set to False.
"""
st.wait_for_comm_cycle(int(start_boot_seconds))
gp.qprintn()
if wait_state_check:
st.wait_state(
st.standby_match_state, wait_time="10 mins", interval="10 seconds"
)