forked from OpenZWave/python-openzwave
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest_network.py
More file actions
152 lines (133 loc) · 5.45 KB
/
test_network.py
File metadata and controls
152 lines (133 loc) · 5.45 KB
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
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
#!/usr/bin/python
# -*- coding: utf-8 -*-
"""
.. module:: tests
This file is part of **python-openzwave** project https://github.com/OpenZWave/python-openzwave.
:platform: Unix, Windows, MacOS X
:sinopsis: openzwave Library
.. moduleauthor: bibi21000 aka Sébastien GALLET <bibi21000@gmail.com>
License : GPL(v3)
**python-openzwave** is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
**python-openzwave** is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with python-openzwave. If not, see http://www.gnu.org/licenses.
"""
import sys, os, shutil
import time
import unittest
from pprint import pprint
import datetime
import random
import socket
import libopenzwave
import re
import time
import sys
import six
if six.PY3:
from pydispatch import dispatcher
else:
from louie import dispatcher
import libopenzwave
import openzwave
from openzwave.node import ZWaveNode
from openzwave.value import ZWaveValue
from openzwave.scene import ZWaveScene
from openzwave.controller import ZWaveController
from openzwave.network import ZWaveNetwork
from openzwave.option import ZWaveOption
from tests.common import pyozw_version
from tests.common import SLEEP
from tests.api.common import TestApi
from tests.common import TestPyZWave
import json
class TestNetwork(TestApi):
def test_000_network_awake(self):
self.wait_for_network_state(self.network.STATE_AWAKED, 1)
self.assertTrue(self.network.state>=self.network.STATE_AWAKED)
self.assertEqual(type(self.network.home_id_str), type(""))
self.assertTrue(self.network.manager is not None)
self.assertTrue(self.network.controller is not None)
def test_010_network_ready(self):
self.wait_for_network_state(self.network.STATE_READY, 2)
if self.network.state<self.network.STATE_READY:
self.skipNotReady("Newtork is not ready ... but continue")
self.assertTrue(self.network.state>=self.network.STATE_READY)
def test_100_network_test(self):
self.network.test()
def test_110_network_heal(self):
self.network.heal()
def test_120_network_poll(self):
self.network.set_poll_interval(milliseconds=500, bIntervalBetweenPolls=True)
self.assertEqual(self.network.get_poll_interval(), 500)
def test_200_network_to_dict(self):
dnetwork = self.network.to_dict()
self.assertEqual(type(dnetwork), type({}))
res = json.dumps(dnetwork)
self.assertNotEqual(res, None)
self.assertTrue(len(res)>0)
def test_220_network_nodes_to_dict(self):
dnodes = self.network.nodes_to_dict()
self.assertEqual(type(dnodes), type({}))
res = json.dumps(dnodes)
self.assertNotEqual(res, None)
self.assertTrue(len(res)>0)
def test_300_network_kvals_nodes(self):
nodes_id = self.network.nodes.keys()
for nid in nodes_id:
kvals=self.network.nodes[nid].kvals
self.assertNotEqual(kvals, None)
for nid in nodes_id:
self.network.nodes[nid].kvals = {'data1':1}
kvals=self.network.nodes[nid].kvals
self.assertEqual(int(kvals['data1']), 1)
for nid in nodes_id:
self.network.nodes[nid].kvals = {'data2':'chaine'}
kvals=self.network.nodes[nid].kvals
self.assertEqual(int(kvals['data1']), 1)
self.assertEqual(kvals['data2'], 'chaine')
for nid in nodes_id:
self.network.nodes[nid].kvals = {'data1':None}
kvals=self.network.nodes[nid].kvals
self.assertFalse('data1' in kvals)
self.assertEqual(kvals['data2'], 'chaine')
for nid in nodes_id:
self.network.nodes[nid].kvals = {'data2':None}
kvals=self.network.nodes[nid].kvals
self.assertFalse('data1' in kvals)
self.assertFalse('data2' in kvals)
def test_310_network_kvals_controller(self):
nodes_id = [self.network.controller.node_id]
for nid in nodes_id:
kvals=self.network.nodes[nid].kvals
self.assertNotEqual(kvals, None)
for nid in nodes_id:
self.network.nodes[nid].kvals = {'data1':1}
kvals=self.network.nodes[nid].kvals
self.assertEqual(int(kvals['data1']), 1)
for nid in nodes_id:
self.network.nodes[nid].kvals = {'data2':'chaine'}
kvals=self.network.nodes[nid].kvals
self.assertEqual(int(kvals['data1']), 1)
self.assertEqual(kvals['data2'], 'chaine')
for nid in nodes_id:
self.network.nodes[nid].kvals = {'data1':None}
kvals=self.network.nodes[nid].kvals
self.assertFalse('data1' in kvals)
self.assertEqual(kvals['data2'], 'chaine')
for nid in nodes_id:
self.network.nodes[nid].kvals = {'data2':None}
kvals=self.network.nodes[nid].kvals
for nid in nodes_id:
self.network.nodes[nid].kvals = {'data1':None}
kvals=self.network.nodes[nid].kvals
self.assertFalse('data1' in kvals)
if __name__ == '__main__':
sys.argv.append('-v')
unittest.main()