File: test_regression.py

package info (click to toggle)
orange3 3.40.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 15,908 kB
  • sloc: python: 162,745; ansic: 622; makefile: 322; sh: 93; cpp: 77
file content (64 lines) | stat: -rw-r--r-- 1,919 bytes parent folder | download | duplicates (2)
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
# Test methods with long descriptive names can omit docstrings
# pylint: disable=missing-docstring

import unittest
import inspect
import pkgutil
import traceback

import Orange
from Orange.data import Table
from Orange.regression import Learner, CurveFitLearner
from Orange.tests import test_filename


def all_learners():
    regression_modules = pkgutil.walk_packages(
        path=Orange.regression.__path__,
        prefix="Orange.regression.",
        onerror=lambda x: None)
    for _, modname, _ in regression_modules:
        try:
            module = pkgutil.importlib.import_module(modname)
        except ImportError:
            continue

        for _, class_ in inspect.getmembers(module, inspect.isclass):
            if issubclass(class_, Learner) and 'base' not in class_.__module__:
                yield class_


def init_learner(learner, table):
    if learner == CurveFitLearner:
        return CurveFitLearner(
            lambda x, a: x[:, -1] * a, [],
            [table.domain.attributes[-1].name]
        )
    return learner()


class TestRegression(unittest.TestCase):
    def test_adequacy_all_learners(self):
        table = Table("iris")
        for learner in all_learners():
            learner = init_learner(learner, table)
            with self.assertRaises(ValueError):
                learner(table)

    def test_adequacy_all_learners_multiclass(self):
        table = Table(test_filename("datasets/test8.tab"))
        for learner in all_learners():
            learner = init_learner(learner, table)
            with self.assertRaises(ValueError):
                learner(table)

    def test_missing_class(self):
        table = Table(test_filename("datasets/imports-85.tab"))
        for learner in all_learners():
            learner = init_learner(learner, table)
            model = learner(table)
            model(table)


if __name__ == "__main__":
    unittest.main()