aboutsummaryrefslogtreecommitdiffstats
path: root/src/vppinfra/tw_timer_16t_1w_2048sl.h
AgeCommit message (Expand)AuthorFilesLines
2019-04-08host stack: update stale copyrightFlorin Coras1-1/+1
2018-12-19tw: fix _16t_1w_2048sl timer weel definitionFlorin Coras1-3/+3
2017-09-01Add fixed-size, preallocated pool supportDave Barach1-0/+1
2017-06-28switch vlib process model to tw_timer_template timer implDave Barach1-0/+4
2017-06-12three-level timer wheel implementation w/ overflow vectorDave Barach1-0/+1
2017-03-01VPP-598: tcp stack initial commitDave Barach1-0/+46
*/ .highlight .py { color: #336699; font-weight: bold } /* Name.Property */ .highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */ .highlight .nv { color: #336699 } /* Name.Variable */ .highlight .ow { color: #008800 } /* Operator.Word */ .highlight .w { color: #bbbbbb } /* Text.Whitespace */ .highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */ .highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */ .highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */ .highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */ .highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */ .highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */ .highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */
#!/usr/bin/env python
# Copyright (c) 2015 Cisco and/or its affiliates.
# 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.


import os
import robot
from robot.run import RobotFramework
from robot.conf.settings import RobotSettings
from robot.running.builder import TestSuiteBuilder
from robot.running.model import TestSuite


def get_suite_list(*datasources, **options):
    class _MyRobotFramework(RobotFramework):
        def main(self, datasources, **options):
            # copied from robot.run.RobotFramework.main
            settings = RobotSettings(options)
            suite = TestSuiteBuilder(settings['SuiteNames'],
                                     settings['WarnOnSkipped']).build(*datasources)
            suite.configure(**settings.suite_config)

            return suite

    # Options are in robot.conf.settings
    suite = _MyRobotFramework().execute(*datasources, **options)
    if isinstance(suite, TestSuite):
        suites = []
        suites.append(suite)
        append_new = True
        while append_new:
            append_new = False
            tmp = []
            for s in suites:
                if len(s.suites._items) > 0:
                    for i in s.suites._items:
                        tmp.append(i)
                    append_new = True
                else:
                    tmp.append(s)
            suites = tmp
        return suites
    else:
        # TODO: add from robot.errors typ error
        return []


def run_suites(test_dir, suites, out_dir="./outputs", **options):
    # TODO: add logic

    try:
        for f in os.listdir(out_dir):
            os.remove('/'.join((out_dir, f)))
    except OSError:
        pass
    if not os.path.exists(out_dir):
        os.makedirs(out_dir)

    for s in suites:
        longname = s.longname
        varfile=[]
        varfile.append('resources/libraries/python/topology.py')

        # TODO: check testcases Tags

        with open('{}/{}.out'.format(out_dir, longname), 'w') as out, \
             open('{}/{}.log'.format(out_dir, longname), 'w') as debug:
            robot.run(test_dir,
                      suite=[longname],
                      output='{}/{}.xml'.format(out_dir, longname),
                      debugfile=debug,
                      log=None,
                      report=None,
                      stdout=out,
                      variablefile=varfile,
                      **options)


def parse_outputs(out_dir='./'):
    outs = ['/'.join((out_dir, file)) for file in os.listdir(out_dir) if file.endswith('.xml')]
    robot.rebot(*outs, merge=True)


if __name__ == "__main__":
    i = []
    e = []
    # i = ['bd', 'ip']
    # i = ['hw']
    # e = ['hw']
    test_dir = "./tests"
    out_dir = "./outputs"

    suite_list = get_suite_list(test_dir, include=i, exclude=e, output=None, dryrun=True)
    run_suites(test_dir, suite_list, include=i, exclude=e, out_dir=out_dir)
    parse_outputs(out_dir=out_dir)