aboutsummaryrefslogtreecommitdiffstats
path: root/yardstick/network_services/vnf_generic/vnf/tg_rfc2544_trex.py
blob: d94a9a6e6ee77da99e303b6b09987e593975a50f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# 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
        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)