 4ade0fc76d
			
		
	
	
		4ade0fc76d
		
			
		
	
	
	
	
		
			
			* Unit bench: added retry count for finding flipper for reboot/reboot2dfu and power off scripts. Changed returns to sys.exit() since scripts are being used standalone * fixed typo in await flipper and changed debug level to info for searching flipper in power.py * reversed return operator instead of sys.exit, changed app.py exit behavior * test run to see if exit(1) fails the run * reversed test changes, fixed flipper name and increased await flipper timeout * await after flash increase * increased serial timeout * increased serial timeout, apparently it is for entire run Co-authored-by: doomwastaken <k.volkov@flipperdevices.com> Co-authored-by: あく <alleteam@gmail.com>
		
			
				
	
	
		
			84 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python3
 | |
| 
 | |
| import time
 | |
| from typing import Optional
 | |
| 
 | |
| from flipper.app import App
 | |
| from flipper.storage import FlipperStorage
 | |
| from flipper.utils.cdc import resolve_port
 | |
| 
 | |
| 
 | |
| class Main(App):
 | |
|     # this is basic use without sub-commands, simply to reboot flipper / power it off, not meant as a full CLI wrapper
 | |
|     def init(self):
 | |
|         self.parser.add_argument("-p", "--port", help="CDC Port", default="auto")
 | |
| 
 | |
|         self.subparsers = self.parser.add_subparsers(help="sub-command help")
 | |
| 
 | |
|         self.parser_power_off = self.subparsers.add_parser(
 | |
|             "power_off", help="Power off command, won't return to CLI"
 | |
|         )
 | |
|         self.parser_power_off.set_defaults(func=self.power_off)
 | |
| 
 | |
|         self.parser_reboot = self.subparsers.add_parser(
 | |
|             "reboot", help="Reboot command help"
 | |
|         )
 | |
|         self.parser_reboot.set_defaults(func=self.reboot)
 | |
| 
 | |
|         self.parser_reboot2dfu = self.subparsers.add_parser(
 | |
|             "reboot2dfu", help="Reboot to DFU, won't return to CLI"
 | |
|         )
 | |
|         self.parser_reboot2dfu.set_defaults(func=self.reboot2dfu)
 | |
| 
 | |
|     def _get_flipper(self, retry_count: Optional[int] = 1):
 | |
|         port = None
 | |
|         self.logger.info(f"Attempting to find flipper with {retry_count} attempts.")
 | |
| 
 | |
|         for i in range(retry_count):
 | |
|             time.sleep(1)
 | |
|             self.logger.info(f"Attempting to find flipper #{i}.")
 | |
| 
 | |
|             if port := resolve_port(self.logger, self.args.port):
 | |
|                 self.logger.info(f"Found flipper at {port}")
 | |
|                 break
 | |
| 
 | |
|         if not port:
 | |
|             self.logger.info(f"Failed to find flipper")
 | |
|             return None
 | |
| 
 | |
|         flipper = FlipperStorage(port)
 | |
|         flipper.start()
 | |
|         return flipper
 | |
| 
 | |
|     def power_off(self):
 | |
|         if not (flipper := self._get_flipper(retry_count=10)):
 | |
|             return 1
 | |
| 
 | |
|         self.logger.info("Powering off")
 | |
|         flipper.send("power off" + "\r")
 | |
|         flipper.stop()
 | |
|         return 0
 | |
| 
 | |
|     def reboot(self):
 | |
|         if not (flipper := self._get_flipper(retry_count=10)):
 | |
|             return 1
 | |
| 
 | |
|         self.logger.info("Rebooting")
 | |
|         flipper.send("power reboot" + "\r")
 | |
|         flipper.stop()
 | |
|         return 0
 | |
| 
 | |
|     def reboot2dfu(self):
 | |
|         if not (flipper := self._get_flipper(retry_count=10)):
 | |
|             return 1
 | |
| 
 | |
|         self.logger.info("Rebooting to DFU")
 | |
|         flipper.send("power reboot2dfu" + "\r")
 | |
|         flipper.stop()
 | |
| 
 | |
|         return 0
 | |
| 
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     Main()()
 |