aboutsummaryrefslogtreecommitdiffstats
path: root/functest/tests/unit/core/test_feature.py
blob: 8c73bb5d50a930d41b2262019dbe49552c723a84 (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
#!/usr/bin/env python

# Copyright (c) 2017 Orange and others.
#
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Apache License, Version 2.0
# which accompanies this distribution, and is available at
# http://www.apache.org/licenses/LICENSE-2.0

# pylint: disable=missing-docstring

import logging
import unittest

import mock

from functest.core import feature
from functest.core import testcase


class FeatureTestingBase(unittest.TestCase):

    _case_name = "foo"
    _project_name = "bar"
    _repo = "dir_repo_bar"
    _cmd = "run_bar_tests.py"
    _output_file = '/home/opnfv/functest/results/foo.log'
    feature = None

    @mock.patch('time.time', side_effect=[1, 2])
    def _test_run(self, status, mock_method=None):
        self.assertEqual(self.feature.run(cmd=self._cmd), status)
        if status == testcase.TestCase.EX_OK:
            self.assertEqual(self.feature.result, 100)
        else:
            self.assertEqual(self.feature.result, 0)
        mock_method.assert_has_calls([mock.call(), mock.call()])
        self.assertEqual(self.feature.start_time, 1)
        self.assertEqual(self.feature.stop_time, 2)

    def test_logger_module_ko(self):
        with mock.patch('six.moves.builtins.open'):
            self.feature = feature.Feature(
                project_name=self._project_name, case_name=self._case_name)
            self.assertEqual(self.feature.logger.name, self._case_name)

    def test_logger_module(self):
        with mock.patch('six.moves.builtins.open'):
            self.feature = feature.Feature(
                project_name=self._project_name, case_name=self._case_name,
                run={'module': 'bar'})
            self.assertEqual(self.feature.logger.name, 'bar')


class FeatureTesting(FeatureTestingBase):

    def setUp(self):
        with mock.patch('six.moves.builtins.open'):
            self.feature = feature.Feature(
                project_name=self._project_name, case_name=self._case_name)

    def test_run_exc(self):
        # pylint: disable=bad-continuation
        with mock.patch.object(
                self.feature, 'execute',
                side_effect=Exception) as mock_method:
            self._test_run(testcase.TestCase.EX_RUN_ERROR)
            mock_method.assert_called_once_with(cmd=self._cmd)

    def test_run(self):
        self._test_run(testcase.TestCase.EX_RUN_ERROR)


class BashFeatureTesting(FeatureTestingBase):

    def setUp(self):
        with mock.patch('six.moves.builtins.open'):
            self.feature = feature.BashFeature(
                project_name=self._project_name, case_name=self._case_name)

    @mock.patch('subprocess.Popen')
    def test_run_no_cmd(self, mock_subproc):
        self.assertEqual(
            self.feature.run(), testcase.TestCase.EX_RUN_ERROR)
        mock_subproc.assert_not_called()

    @mock.patch('subprocess.Popen')
    def test_run_ko(self, mock_subproc):
        with mock.patch('six.moves.builtins.open', mock.mock_open()) as mopen:
            mock_obj = mock.Mock()
            attrs = {'wait.return_value': 1}
            mock_obj.configure_mock(**attrs)

            mock_subproc.return_value = mock_obj
            self._test_run(testcase.TestCase.EX_RUN_ERROR)
            mopen.assert_called_once_with(self._output_file, "w+")

    @mock.patch('subprocess.Popen')
    def test_run(self, mock_subproc):
        with mock.patch('six.moves.builtins.open', mock.mock_open()) as mopen:
            mock_obj = mock.Mock()
            attrs = {'wait.return_value': 0}
            mock_obj.configure_mock(**attrs)

            mock_subproc.return_value = mock_obj
            self._test_run(testcase.TestCase.EX_OK)
            mopen.assert_called_once_with(self._output_file, "w+")


if __name__ == "__main__":
    # logging must be disabled else it calls time.time()
    # what will break these unit tests.
    logging.disable(logging.CRITICAL)
    unittest.main(verbosity=2)