summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorISHIDA Wataru <ishida.wataru@lab.ntt.co.jp>2015-11-09 14:13:39 +0900
committerISHIDA Wataru <ishida.wataru@lab.ntt.co.jp>2015-11-11 00:47:17 +0900
commit660b38e5aecfec22563b90f43e0ed7a99bb4cc0d (patch)
tree4f2a57c75bfc1a0a5b55450ae1645faf1dcd4954
parent34bd365bb4534f2321acea686996e2293727923c (diff)
test: add BIRD for performance test target
Signed-off-by: ISHIDA Wataru <ishida.wataru@lab.ntt.co.jp>
-rw-r--r--test/lib/bird.py78
-rw-r--r--test/performance_test/README.md7
-rw-r--r--test/performance_test/test.py3
3 files changed, 88 insertions, 0 deletions
diff --git a/test/lib/bird.py b/test/lib/bird.py
new file mode 100644
index 00000000..c08a381c
--- /dev/null
+++ b/test/lib/bird.py
@@ -0,0 +1,78 @@
+# Copyright (C) 2015 Nippon Telegraph and Telephone Corporation.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+# implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+from base import *
+
+class BirdContainer(BGPContainer):
+
+ WAIT_FOR_BOOT = 1
+ SHARED_VOLUME = '/etc/bird'
+
+ def __init__(self, name, asn, router_id, ctn_image_name='osrg/bird'):
+ super(BirdContainer, self).__init__(name, asn, router_id,
+ ctn_image_name)
+ self.shared_volumes.append((self.config_dir, self.SHARED_VOLUME))
+
+ def _start_bird(self):
+ c = CmdBuffer()
+ c << '#!/bin/bash'
+ c << 'bird'
+ cmd = 'echo "{0:s}" > {1}/start.sh'.format(c, self.config_dir)
+ local(cmd)
+ cmd = 'chmod 755 {0}/start.sh'.format(self.config_dir)
+ local(cmd)
+ self.local('{0}/start.sh'.format(self.SHARED_VOLUME))
+
+ def run(self):
+ super(BirdContainer, self).run()
+ self.reload_config()
+ return self.WAIT_FOR_BOOT
+
+ def create_config(self):
+ c = CmdBuffer()
+ c << 'router id {0};'.format(self.router_id)
+ for peer, info in self.peers.iteritems():
+ c << 'protocol bgp {'
+ c << ' local as {0};'.format(self.asn)
+ n_addr = info['neigh_addr'].split('/')[0]
+ c << ' neighbor {0} as {1};'.format(n_addr, peer.asn)
+ c << ' multihop;'
+ c << '}'
+
+ with open('{0}/bird.conf'.format(self.config_dir), 'w') as f:
+ print colors.yellow('[{0}\'s new config]'.format(self.name))
+ print colors.yellow(indent(str(c)))
+ f.writelines(str(c))
+
+ def reload_config(self):
+ if len(self.peers) == 0:
+ return
+
+ def _reload():
+ def _is_running():
+ ps = self.local('ps', capture=True)
+ running = False
+ for line in ps.split('\n')[1:]:
+ if 'bird' in line:
+ running = True
+ return running
+ if _is_running():
+ self.local('birdc configure')
+ else:
+ self._start_bird()
+ time.sleep(1)
+ if not _is_running():
+ raise RuntimeError()
+ try_several_times(_reload)
diff --git a/test/performance_test/README.md b/test/performance_test/README.md
index 841370ca..f0edaea3 100644
--- a/test/performance_test/README.md
+++ b/test/performance_test/README.md
@@ -22,3 +22,10 @@ $ cd $GOPATH/src/github.com/osrg/gobgp/test/performance_test
$ sudo PYTHONPATH=../ python test.py -t gobgp -n 1000 T1
$ sudo PYTHONPATH=../ python test.py -t quagga -n 1000 T1
```
+
+To test BIRD, pull BIRD docker image first.
+
+```shell
+$ docker pull osrg/bird
+$ sudo PYTHONPATH=../ python test.py -t bird -n 1000 T1
+```
diff --git a/test/performance_test/test.py b/test/performance_test/test.py
index 20ff6d6d..4d3e8cc8 100644
--- a/test/performance_test/test.py
+++ b/test/performance_test/test.py
@@ -1,5 +1,6 @@
from lib.gobgp import *
from lib.quagga import *
+from lib.bird import *
from fabric.api import local
from optparse import OptionParser
import sys
@@ -40,6 +41,8 @@ if __name__ == '__main__':
target = GoBGPContainer("target", 1000, "10.10.0.1", log_level='info')
elif options.target_rs == "quagga":
target = QuaggaBGPContainer("target", 1000, "10.10.0.1")
+ elif options.target_rs == "bird":
+ target = BirdContainer("target", 1000, "10.10.0.1")
else:
print 'Unknown target implementation:', options.target_rs
sys.exit(1)