# Copyright (c) 2016-2017 Intel 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. """ Trex traffic generation definitions which implements rfc2544 """ from __future__ import absolute_import from __future__ import print_function import time import logging from collections import Mapping from itertools import chain from yardstick.network_services.helpers.samplevnf_helper import MultiPortConfig from yardstick.network_services.vnf_generic.vnf.tg_trex import TrexTrafficGen from yardstick.network_services.vnf_generic.vnf.sample_vnf import Rfc2544ResourceHelper from yardstick.network_services.vnf_generic.vnf.tg_trex import TrexResourceHelper LOGGING = logging.getLogger(__name__) class TrexRfc2544ResourceHelper(Rfc2544ResourceHelper): def is_done(self): return self.latency and self.iteration.value > 10 class TrexRfcResourceHelper(TrexResourceHelper): LATENCY_TIME_SLEEP = 120 RUN_DURATION = 30 WAIT_TIME = 3 def __init__(self, setup_helper, rfc_helper_type=None): super(TrexRfcResourceHelper, self).__init__(setup_helper) if rfc_helper_type is None: rfc_helper_type = TrexRfc2544ResourceHelper self.rfc2544_helper = rfc_helper_type(self.scenario_helper) # self.tg_port_pairs = [] def _build_ports(self): self.tg_port_pairs, self.networks = MultiPortConfig.get_port_pairs( self.vnfd_helper.interfaces) self.priv_ports = [int(x[0][2:]) for x in self.tg_port_pairs] self.pub_ports = [int(x[1][2:]) for x in self.tg_port_pairs] self.my_ports = list(set(chain(self.priv_ports, self.pub_ports))) def _run_traffic_once(self, traffic_profile): if self._terminated.value: return traffic_profile.execute(self) self.client_started.value = 1 time.sleep(self.RUN_DURATION) self.client.stop(self.my_ports) time.sleep(self.WAIT_TIME) samples = traffic_profile.get_drop_percentage(self) self._queue.put(samples) if not self.rfc2544_helper.is_done(): return self.client.stop(self.my_ports) self.client.reset(ports=self.my_ports) self.client.remove_all_streams(self.my_ports) traffic_profile.execute_latency(samples=samples) multiplier = traffic_profile.calculate_pps(samples)[1] for _ in range(5): time.sleep(self.LATENCY_TIME_SLEEP) self.client.stop(self.my_ports) time.sleep(self.WAIT_TIME) last_res = self.client.get_stats(self.my_ports) if not isinstance(last_res, Mapping): self._terminated.value = 1 continue self.generate_samples('latency', {}) self._queue.put(samples) self.client.start(mult=str(multiplier), ports=self.my_ports, duration=120, force=True) def start_client(self, mult, duration, force=True): self.client.start(ports=self.my_ports, mult=mult, duration=duration, force=force) def clear_client_stats(self): self.client.clear_stats(ports=self.my_ports) def collect_kpi(self): self.rfc2544_helper.iteration.value += 1 return super(TrexRfcResourceHelper, self).collect_kpi() class TrexTrafficGenRFC(TrexTrafficGen): """ This class handles mapping traffic profile and generating traffic for rfc2544 testcase. """ def __init__(self, name, vnfd, setup_env_helper_type=None, resource_helper_type=None): if resource_helper_type is None: resource_helper_type = TrexRfcResourceHelper super(TrexTrafficGenRFC, self).__init__(name, vnfd, setup_env_helper_type, resource_helper_type)