summaryrefslogtreecommitdiffhomepage
path: root/test/scenario_test/docker_control.py
diff options
context:
space:
mode:
authorHiroshi Yokoi <yokoi.hiroshi@po.ntts.co.jp>2015-04-01 20:28:49 +0900
committerHiroshi Yokoi <yokoi.hiroshi@po.ntts.co.jp>2015-04-02 19:10:42 +0900
commit9ef122daf898dc2f27f9ff83f90d0403650d46cf (patch)
tree2da23d47258bdbbc8d22fce8e3e58b7e5ce4dcb3 /test/scenario_test/docker_control.py
parent5ae7bd597ebcf41db191a6db943e63e35d8658d1 (diff)
scenario_test: add helper functions for policy test
Diffstat (limited to 'test/scenario_test/docker_control.py')
-rw-r--r--test/scenario_test/docker_control.py74
1 files changed, 74 insertions, 0 deletions
diff --git a/test/scenario_test/docker_control.py b/test/scenario_test/docker_control.py
index 1e528bbf..64446111 100644
--- a/test/scenario_test/docker_control.py
+++ b/test/scenario_test/docker_control.py
@@ -287,6 +287,34 @@ def make_config(quagga_num, go_path, bridge, peer_opts=""):
local(cmd, capture=True)
+def make_config_with_policy(quagga_num, go_path, bridge, peer_opts="", policy_pattern=""):
+ if go_path != "":
+ print "specified go path is [ " + go_path + " ]."
+ if os.path.isdir(go_path):
+ go_path += "/"
+ else:
+ print "specified go path is not used."
+ pwd = local("pwd", capture=True)
+ cmd = go_path + "go run " + pwd + "/quagga-rsconfig.go "+" -p "+ policy_pattern + " -n " + str(quagga_num) + \
+ " -c /tmp/gobgp -v " + IP_VERSION + " -i " + bridge["BRIDGE_NAME"][-1] + " " + peer_opts
+ local(cmd, capture=True)
+
+
+def update_policy_config(go_path, policy_pattern=""):
+ if go_path != "":
+ print "specified go path is [ " + go_path + " ]."
+ if os.path.isdir(go_path):
+ go_path += "/"
+ else:
+ print "specified go path is not used."
+
+ pwd = local("pwd", capture=True)
+ cmd = go_path + "go run " + pwd + "/quagga-rsconfig.go --update-policy "+" -p "+ policy_pattern + \
+ " -c /tmp/gobgp "
+ local(cmd, capture=True)
+ reload_config()
+
+
def make_config_append(quagga_num, go_path, bridge, peer_opts=""):
if go_path != "":
print "specified go path is [ " + go_path + " ]."
@@ -357,6 +385,52 @@ def init_test_env_executor(quagga_num, use_local, go_path, log_debug=False, is_r
print "complete initialization of test environment."
+def init_policy_test_env_executor(quagga_num, use_local, go_path, log_debug=False, policy=""):
+ print "start initialization of test environment."
+
+ if docker_container_check() or bridge_setting_check():
+ print "gobgp test environment already exists."
+ print "so that remake gobgp test environment."
+ docker_containers_destroy()
+
+ print "make gobgp policy test environment."
+ create_config_dir()
+ bridge_setting_for_docker_connection(BRIDGES)
+ make_config_with_policy(quagga_num, go_path, BRIDGE_0, policy_pattern=policy)
+
+ # run gobgp docker container
+ docker_container_run_gobgp(BRIDGE_0)
+
+ # set log option
+ opt = "-l debug" if log_debug else ""
+
+ # execute local gobgp program in the docker container if the input option is local
+ if use_local:
+ print "execute gobgp program in local machine."
+ pwd = local("pwd", capture=True)
+ if A_PART_OF_CURRENT_DIR in pwd:
+ gobgp_path = re.sub(A_PART_OF_CURRENT_DIR, "", pwd)
+ cmd = "cp -r " + gobgp_path + " " + CONFIG_DIRR
+ local(cmd, capture=True)
+ make_startup_file_use_local_gobgp(log_opt=opt)
+ else:
+ print "scenario_test directory is not."
+ print "execute gobgp program of osrg/master in github."
+ make_startup_file(log_opt=opt)
+ else:
+ print "execute gobgp program of osrg/master in github."
+ make_startup_file(log_opt=opt)
+
+ change_owner_to_root(CONFIG_DIR)
+ start_gobgp()
+
+ # run quagga docker container
+ for num in range(1, quagga_num + 1):
+ docker_container_run_quagga(num, BRIDGE_0)
+
+ print "complete initialization of test environment."
+
+
def init_ipv6_test_env_executor(quagga_num, use_local, go_path, log_debug=False):
print "start initialization of test environment."