mirror of
https://github.com/asterisk/asterisk.git
synced 2025-11-16 14:58:25 +00:00
Add support for ICE/STUN/TURN in res_rtp_asterisk and chan_sip.
Review: https://reviewboard.asterisk.org/r/1891/ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@369517 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
354
res/pjproject/tests/automated/configure.py
Executable file
354
res/pjproject/tests/automated/configure.py
Executable file
@@ -0,0 +1,354 @@
|
||||
#!/usr/bin/python
|
||||
|
||||
import optparse
|
||||
import os
|
||||
import platform
|
||||
import socket
|
||||
import subprocess
|
||||
import sys
|
||||
|
||||
PROG = "r" + "$Rev$".strip("$ ").replace("Rev: ", "")
|
||||
PYTHON = os.path.basename(sys.executable)
|
||||
build_type = ""
|
||||
vs_target = ""
|
||||
s60_target = ""
|
||||
no_test = False
|
||||
no_pjsua_test = False
|
||||
|
||||
#
|
||||
# Get gcc version
|
||||
#
|
||||
def gcc_version(gcc):
|
||||
proc = subprocess.Popen(gcc + " -v", stdout=subprocess.PIPE,
|
||||
stderr=subprocess.STDOUT, shell=True)
|
||||
ver = ""
|
||||
while True:
|
||||
s = proc.stdout.readline()
|
||||
if not s:
|
||||
break
|
||||
if s.find("gcc version") >= 0:
|
||||
ver = s.split(None, 3)[2]
|
||||
break
|
||||
proc.wait()
|
||||
return "gcc-" + ver
|
||||
|
||||
#
|
||||
# Get Visual Studio info
|
||||
#
|
||||
class VSVersion:
|
||||
def __init__(self):
|
||||
self.version = "8"
|
||||
self.release = "2005"
|
||||
|
||||
proc = subprocess.Popen("cl", stdout=subprocess.PIPE,
|
||||
stderr=subprocess.STDOUT)
|
||||
while True:
|
||||
s = proc.stdout.readline()
|
||||
if s=="":
|
||||
break
|
||||
pos = s.find("Version")
|
||||
if pos > 0:
|
||||
proc.wait()
|
||||
s = s[pos+8:]
|
||||
ver = s.split(None, 1)[0]
|
||||
major = ver[0:2]
|
||||
if major=="12":
|
||||
self.version = "6"
|
||||
self.release = "98"
|
||||
break
|
||||
elif major=="13":
|
||||
self.version = "7"
|
||||
self.release = "2003"
|
||||
break
|
||||
elif major=="14":
|
||||
self.version = "8"
|
||||
self.release = "2005"
|
||||
break
|
||||
elif major=="15":
|
||||
self.version = "9"
|
||||
self.release = "2008"
|
||||
break
|
||||
elif major=="16":
|
||||
self.version = "10"
|
||||
self.release = "2010"
|
||||
break
|
||||
else:
|
||||
self.version = "11"
|
||||
self.release = "2012"
|
||||
break
|
||||
proc.wait()
|
||||
self.vs_version = "vs" + self.version
|
||||
self.vs_release = "vs" + self.release
|
||||
|
||||
|
||||
#
|
||||
# Get S60 SDK info
|
||||
#
|
||||
class S60SDK:
|
||||
def __init__(self):
|
||||
self.epocroot = ""
|
||||
self.sdk = ""
|
||||
self.device = ""
|
||||
|
||||
# Check that EPOCROOT is set
|
||||
if not "EPOCROOT" in os.environ:
|
||||
sys.stderr.write("Error: EPOCROOT environment variable is not set\n")
|
||||
sys.exit(1)
|
||||
epocroot = os.environ["EPOCROOT"]
|
||||
# EPOCROOT must have trailing backslash
|
||||
if epocroot[-1] != "\\":
|
||||
epocroot = epocroot + "\\"
|
||||
os.environ["EPOCROOT"] = epocroot
|
||||
self.epocroot = epocroot
|
||||
self.sdk = sdk1 = epocroot.split("\\")[-2]
|
||||
self.device = "@" + self.sdk + ":com.nokia.s60"
|
||||
|
||||
# Check that correct device is set
|
||||
proc = subprocess.Popen("devices", stdout=subprocess.PIPE,
|
||||
stderr=subprocess.STDOUT, shell=True)
|
||||
sdk2 = ""
|
||||
while True:
|
||||
line = proc.stdout.readline()
|
||||
if line.find("- default") > 0:
|
||||
sdk2 = line.split(":",1)[0]
|
||||
break
|
||||
proc.wait()
|
||||
|
||||
if sdk1 != sdk2:
|
||||
sys.stderr.write("Error: default SDK in device doesn't match EPOCROOT\n")
|
||||
sys.stderr.write("Default device SDK = '" + sdk2 + "'\n")
|
||||
sys.stderr.write("EPOCROOT SDK = '" + sdk1 + "'\n")
|
||||
sys.exit(1)
|
||||
|
||||
self.name = sdk2.replace("_", "-")
|
||||
|
||||
|
||||
|
||||
def replace_vars(text):
|
||||
global vs_target, s60_target, build_type, no_test, no_pjsua_test
|
||||
suffix = ""
|
||||
|
||||
os_info = platform.system() + platform.release() + "-" + platform.machine()
|
||||
|
||||
# osinfo
|
||||
s60sdk_var = None
|
||||
if build_type == "s60":
|
||||
s60sdk_var = S60SDK()
|
||||
os_info = s60sdk_var.name
|
||||
elif platform.system().lower() == "windows" or platform.system().lower() == "microsoft":
|
||||
if platform.system().lower() == "microsoft":
|
||||
os_info = platform.release() + "-" + platform.version() + "-" + platform.win32_ver()[2]
|
||||
elif platform.system().lower() == "linux":
|
||||
os_info = "-" + "-".join(platform.linux_distribution()[0:2])
|
||||
|
||||
# vs_target
|
||||
if not vs_target and text.find("$(VSTARGET)") >= 0:
|
||||
if build_type != "vs":
|
||||
sys.stderr.write("Warning: $(VSTARGET) only valid for Visual Studio\n")
|
||||
print "Enter Visual Studio vs_target name (e.g. Release, Debug) [Release]: ",
|
||||
vs_target = sys.stdin.readline().replace("\n", "").replace("\r", "")
|
||||
if not vs_target:
|
||||
vs_target = "Release"
|
||||
|
||||
# s60_target
|
||||
if not s60_target and text.find("$(S60TARGET)") >= 0:
|
||||
if build_type != "s60":
|
||||
sys.stderr.write("Warning: $(S60TARGET) only valid for S60\n")
|
||||
print "Enter S60 target name (e.g. \"gcce urel\") [gcce urel]: ",
|
||||
s60_target = sys.stdin.readline().replace("\n", "").replace("\r", "")
|
||||
if not s60_target:
|
||||
s60_target = "gcce urel"
|
||||
|
||||
# Suffix
|
||||
if build_type == "vs":
|
||||
suffix = "i386-Win32-vc8-" + vs_target
|
||||
elif build_type == "s60":
|
||||
suffix = s60sdk_var.name + "-" + s60_target.replace(" ", "-")
|
||||
elif build_type == "gnu":
|
||||
proc = subprocess.Popen("sh config.guess", cwd="../..",
|
||||
shell=True, stdout=subprocess.PIPE)
|
||||
suffix = proc.stdout.readline().rstrip(" \r\n")
|
||||
else:
|
||||
sys.stderr.write("Error: unsupported build type '" + build_type + "'\n")
|
||||
sys.exit(1)
|
||||
|
||||
while True:
|
||||
if text.find("$(PJSUA-TESTS)") >= 0:
|
||||
if no_test==False and no_pjsua_test==False:
|
||||
# Determine pjsua exe to use
|
||||
exe = "../../pjsip-apps/bin/pjsua-" + suffix
|
||||
proc = subprocess.Popen(PYTHON + " runall.py --list-xml -e " + exe,
|
||||
cwd="../pjsua",
|
||||
shell=True, stdout=subprocess.PIPE)
|
||||
content = proc.stdout.read()
|
||||
else:
|
||||
content = ""
|
||||
text = text.replace("$(PJSUA-TESTS)", content)
|
||||
elif text.find("$(GCC)") >= 0:
|
||||
text = text.replace("$(GCC)", gcc_version("gcc"))
|
||||
elif text.find("$(VS)") >= 0:
|
||||
vsver = VSVersion()
|
||||
text = text.replace("$(VS)", VSVersion().vs_release)
|
||||
elif text.find("$(VSTARGET)") >= 0:
|
||||
text = text.replace("$(VSTARGET)", vs_target)
|
||||
elif text.find("$(S60TARGET)") >= 0:
|
||||
text = text.replace("$(S60TARGET)", s60_target)
|
||||
elif text.find("$(S60TARGETNAME)") >= 0:
|
||||
text = text.replace("$(S60TARGETNAME)", s60_target.replace(" ", "-"))
|
||||
elif text.find("$(S60DEVICE)") >= 0:
|
||||
text = text.replace("$(S60DEVICE)", s60sdk_var.device)
|
||||
elif text.find("$(EPOCROOT)") >= 0:
|
||||
text = text.replace("$(EPOCROOT)", s60sdk_var.epocroot)
|
||||
elif text.find("$(DISABLED)") >= 0:
|
||||
text = text.replace("$(DISABLED)", "0")
|
||||
elif text.find("$(IPPROOT)") >= 0:
|
||||
if not os.environ.has_key("IPPROOT"):
|
||||
sys.stderr.write("Error: environment variable IPPROOT is needed but not set\n")
|
||||
sys.exit(1)
|
||||
text = text.replace("$(IPPROOT)", os.environ["IPPROOT"])
|
||||
elif text.find("$(IPPSAMPLES)") >= 0:
|
||||
if not os.environ.has_key("IPPSAMPLES"):
|
||||
sys.stderr.write("Error: environment variable IPPSAMPLES is needed but not set\n")
|
||||
sys.exit(1)
|
||||
text = text.replace("$(IPPSAMPLES)", os.environ["IPPSAMPLES"])
|
||||
elif text.find("$(IPPARCH)") >= 0:
|
||||
if not os.environ.has_key("IPPARCH"):
|
||||
text = text.replace("$(IPPARCH)", "")
|
||||
else:
|
||||
text = text.replace("$(IPPARCH)", os.environ["IPPARCH"])
|
||||
elif text.find("$(OS)") >= 0:
|
||||
text = text.replace("$(OS)", os_info)
|
||||
elif text.find("$(SUFFIX)") >= 0:
|
||||
text = text.replace("$(SUFFIX)", suffix)
|
||||
elif text.find("$(HOSTNAME)") >= 0:
|
||||
text = text.replace("$(HOSTNAME)", socket.gethostname())
|
||||
elif text.find("$(PJDIR)") >= 0:
|
||||
wdir = os.path.join(os.getcwd(), "../..")
|
||||
wdir = os.path.normpath(wdir)
|
||||
text = text.replace("$(PJDIR)", wdir)
|
||||
elif text.find("$(NOP)") >= 0:
|
||||
if platform.system().lower() == "windows" or platform.system().lower() == "microsoft":
|
||||
cmd = "CMD /C echo Success"
|
||||
else:
|
||||
cmd = "echo Success"
|
||||
text = text.replace("$(NOP)", cmd)
|
||||
elif text.find("$(NOTEST)") >= 0:
|
||||
if no_test:
|
||||
str = '"1"'
|
||||
else:
|
||||
str = '"0"'
|
||||
text = text.replace("$(NOTEST)", str)
|
||||
else:
|
||||
break
|
||||
return text
|
||||
|
||||
|
||||
def main(args):
|
||||
global vs_target, s60_target, build_type, no_test, no_pjsua_test
|
||||
output = sys.stdout
|
||||
usage = """Usage: configure.py [OPTIONS] scenario_template_file
|
||||
|
||||
Where OPTIONS:
|
||||
-o FILE Output to file, otherwise to stdout.
|
||||
-t TYPE Specify build type. If not specified, it will be
|
||||
asked if necessary. Values are:
|
||||
vs: Visual Studio
|
||||
gnu: Makefile based
|
||||
s60: Symbian S60
|
||||
-vstarget TARGETNAME Specify Visual Studio target name if build type is set
|
||||
to vs. If not specified then it will be asked.
|
||||
Sample target names:
|
||||
- Debug
|
||||
- Release
|
||||
- or any other target in the project file
|
||||
-s60target TARGETNAME Specify S60 target name if build type is set to s60.
|
||||
If not specified then it will be asked. Sample target
|
||||
names:
|
||||
- "gcce udeb"
|
||||
- "gcce urel"
|
||||
-notest Disable all tests in the scenario.
|
||||
-nopjsuatest Disable pjsua tests in the scenario.
|
||||
"""
|
||||
|
||||
args.pop(0)
|
||||
while len(args):
|
||||
if args[0]=='-o':
|
||||
args.pop(0)
|
||||
if len(args):
|
||||
output = open(args[0], "wt")
|
||||
args.pop(0)
|
||||
else:
|
||||
sys.stderr.write("Error: needs value for -o\n")
|
||||
sys.exit(1)
|
||||
elif args[0]=='-vstarget':
|
||||
args.pop(0)
|
||||
if len(args):
|
||||
vs_target = args[0]
|
||||
args.pop(0)
|
||||
else:
|
||||
sys.stderr.write("Error: needs value for -vstarget\n")
|
||||
sys.exit(1)
|
||||
elif args[0]=='-s60target':
|
||||
args.pop(0)
|
||||
if len(args):
|
||||
s60_target = args[0]
|
||||
args.pop(0)
|
||||
else:
|
||||
sys.stderr.write("Error: needs value for -s60target\n")
|
||||
sys.exit(1)
|
||||
elif args[0]=='-t':
|
||||
args.pop(0)
|
||||
if len(args):
|
||||
build_type = args[0].lower()
|
||||
args.pop(0)
|
||||
else:
|
||||
sys.stderr.write("Error: needs value for -t\n")
|
||||
sys.exit(1)
|
||||
if not ["vs", "gnu", "s60"].count(build_type):
|
||||
sys.stderr.write("Error: invalid -t argument value\n")
|
||||
sys.exit(1)
|
||||
elif args[0]=='-notest' or args[0]=='-notests':
|
||||
args.pop(0)
|
||||
no_test = True
|
||||
elif args[0]=='-nopjsuatest' or args[0]=='-nopjsuatests':
|
||||
args.pop(0)
|
||||
no_pjsua_test = True
|
||||
else:
|
||||
break
|
||||
|
||||
if len(args) != 1:
|
||||
sys.stderr.write(usage + "\n")
|
||||
return 1
|
||||
|
||||
if not build_type:
|
||||
defval = "vs"
|
||||
if "SHELL" in os.environ:
|
||||
shell = os.environ["SHELL"]
|
||||
if shell.find("sh") > -1:
|
||||
defval = "gnu"
|
||||
print "Enter the build type (values: vs, gnu, s60) [%s]: " % (defval),
|
||||
build_type = sys.stdin.readline().replace("\n", "").replace("\r", "")
|
||||
if not build_type:
|
||||
build_type = defval
|
||||
|
||||
|
||||
tpl_file = args[len(args)-1]
|
||||
if not os.path.isfile(tpl_file):
|
||||
print "Error: unable to find template file '%s'" % (tpl_file)
|
||||
return 1
|
||||
|
||||
f = open(tpl_file, "r")
|
||||
tpl = f.read()
|
||||
f.close()
|
||||
|
||||
tpl = replace_vars(tpl)
|
||||
output.write(tpl)
|
||||
if output != sys.stdout:
|
||||
output.close()
|
||||
return 0
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
rc = main(sys.argv)
|
||||
sys.exit(rc)
|
||||
|
||||
Reference in New Issue
Block a user