mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-31 03:53:50 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python3
 | |
| import os
 | |
| import signal
 | |
| import subprocess
 | |
| import sys
 | |
| import tempfile
 | |
| import time
 | |
| 
 | |
| sys.path.insert(0, os.path.join(os.path.dirname(__file__), ".."))
 | |
| 
 | |
| from tools.lib import sanity_check
 | |
| 
 | |
| sanity_check.check_venv(__file__)
 | |
| 
 | |
| TOOLS_DIR = os.path.dirname(os.path.abspath(__file__))
 | |
| 
 | |
| 
 | |
| def start_server(logfile_name: str) -> tuple[bool, str]:
 | |
|     failure = True
 | |
|     key = "Quit the server with CONTROL-C."
 | |
|     datalog = []
 | |
|     with open(logfile_name, "rb", buffering=0) as logfile:
 | |
|         for i in range(200):
 | |
|             time.sleep(0.5)
 | |
|             print(f"{i}. Polling run-dev...")
 | |
|             new_data = logfile.read().decode()
 | |
|             if new_data:
 | |
|                 datalog.append(new_data)
 | |
| 
 | |
|             if key in "".join(datalog):
 | |
|                 failure = False
 | |
|                 break
 | |
| 
 | |
|     return failure, "".join(datalog)
 | |
| 
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     print("Testing development server start!")
 | |
| 
 | |
|     with tempfile.NamedTemporaryFile(buffering=0) as logfile:
 | |
|         run_dev = subprocess.Popen(
 | |
|             [os.path.join(TOOLS_DIR, "run-dev")], stdout=logfile, stderr=subprocess.STDOUT
 | |
|         )
 | |
|         failure, log = start_server(logfile.name)
 | |
| 
 | |
|     run_dev.send_signal(signal.SIGINT)
 | |
|     run_dev.wait()
 | |
| 
 | |
|     if "Traceback" in log:
 | |
|         failure = True
 | |
| 
 | |
|     if failure:
 | |
|         print("Development server is not working properly:")
 | |
|         print(log)
 | |
|         sys.exit(1)
 | |
|     else:
 | |
|         print("Development server is working properly.")
 | |
|         sys.exit(0)
 |