mirror of
				https://github.com/ARM-software/workload-automation.git
				synced 2025-10-26 04:34:04 +00:00 
			
		
		
		
	framework/config: fix deserialization
- RebootPolicy: correctly handle being passed another instance of RebootPolicy on creation; this a requirement for it to be usable as a ConfigurationPoint kind. - RebootPolicy: move static method to above __init__ (consistency). - RunConfiguration: handle deserialization of 'device_config' entry. - RunConfiguration: move static method to above __init__ (consistency).
This commit is contained in:
		
				
					committed by
					
						 Marc Bonnici
						Marc Bonnici
					
				
			
			
				
	
			
			
			
						parent
						
							1e21bd2ca8
						
					
				
				
					commit
					8466b77d5b
				
			| @@ -61,7 +61,13 @@ class RebootPolicy(object): | ||||
|  | ||||
|     valid_policies = ['never', 'as_needed', 'initial', 'each_spec', 'each_iteration'] | ||||
|  | ||||
|     @staticmethod | ||||
|     def from_pod(pod): | ||||
|         return RebootPolicy(pod) | ||||
|  | ||||
|     def __init__(self, policy): | ||||
|         if isinstance(policy, RebootPolicy): | ||||
|             policy = policy.policy | ||||
|         policy = policy.strip().lower().replace(' ', '_') | ||||
|         if policy not in self.valid_policies: | ||||
|             message = 'Invalid reboot policy {}; must be one of {}'.format(policy, ', '.join(self.valid_policies)) | ||||
| @@ -98,10 +104,6 @@ class RebootPolicy(object): | ||||
|     def to_pod(self): | ||||
|         return self.policy | ||||
|  | ||||
|     @staticmethod | ||||
|     def from_pod(pod): | ||||
|         return RebootPolicy(pod) | ||||
|  | ||||
|  | ||||
| class status_list(list): | ||||
|  | ||||
| @@ -662,6 +664,20 @@ class RunConfiguration(Configuration): | ||||
|     ] | ||||
|     configuration = {cp.name: cp for cp in config_points + meta_data} | ||||
|  | ||||
|     @classmethod | ||||
|     def from_pod(cls, pod): | ||||
|         meta_pod = {} | ||||
|         for cfg_point in cls.meta_data: | ||||
|             meta_pod[cfg_point.name] = pod.pop(cfg_point.name, None) | ||||
|  | ||||
|         device_config = pod.pop('device_config', None) | ||||
|         instance = super(RunConfiguration, cls).from_pod(pod) | ||||
|         instance.device_config = device_config | ||||
|         for cfg_point in cls.meta_data: | ||||
|             cfg_point.set_value(instance, meta_pod[cfg_point.name]) | ||||
|  | ||||
|         return instance | ||||
|  | ||||
|     def __init__(self): | ||||
|         super(RunConfiguration, self).__init__() | ||||
|         for confpoint in self.meta_data: | ||||
| @@ -685,18 +701,6 @@ class RunConfiguration(Configuration): | ||||
|         pod['device_config'] = dict(self.device_config or {}) | ||||
|         return pod | ||||
|  | ||||
|     @classmethod | ||||
|     def from_pod(cls, pod): | ||||
|         meta_pod = {} | ||||
|         for cfg_point in cls.meta_data: | ||||
|             meta_pod[cfg_point.name] = pod.pop(cfg_point.name, None) | ||||
|  | ||||
|         instance = super(RunConfiguration, cls).from_pod(pod) | ||||
|         for cfg_point in cls.meta_data: | ||||
|             cfg_point.set_value(instance, meta_pod[cfg_point.name]) | ||||
|  | ||||
|         return instance | ||||
|  | ||||
|  | ||||
| class JobSpec(Configuration): | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user