diff options
| author | Daniel Friesel <derf@finalrewind.org> | 2019-03-01 15:01:22 +0100 | 
|---|---|---|
| committer | Daniel Friesel <derf@finalrewind.org> | 2019-03-01 15:01:22 +0100 | 
| commit | 610fb4b531d12886ec144e3004b4c90a2051d96f (patch) | |
| tree | 09f4c26dfc07ebc30fdd7fac3ff9637db7f8aafc | |
| parent | 8e07e6b127c6481eedd208e7901440be9b2e60fb (diff) | |
add tests fore accepting states and get_transition_id
| -rwxr-xr-x | bin/test_automata.py | 33 | 
1 files changed, 33 insertions, 0 deletions
| diff --git a/bin/test_automata.py b/bin/test_automata.py index c6f473b..0ed95be 100755 --- a/bin/test_automata.py +++ b/bin/test_automata.py @@ -112,6 +112,32 @@ class TestPTA(unittest.TestCase):              ['init', 'set2', 'set1'],              ['init', 'set2', 'set2']]) +    def test_dfs_accepting(self): +        pta = PTA(['IDLE', 'TX'], accepting_states = ['IDLE']) +        pta.add_transition('UNINITIALIZED', 'IDLE', 'init') +        pta.add_transition('IDLE', 'TX', 'send') +        pta.add_transition('TX', 'IDLE', 'txComplete') +        self.assertEqual(dfs_tran_to_name(pta.dfs(0), False), [['init']]) +        self.assertEqual(dfs_tran_to_name(pta.dfs(1), False), []) +        self.assertEqual(dfs_tran_to_name(pta.dfs(2), False), [['init', 'send', 'txComplete']]) +        self.assertEqual(dfs_tran_to_name(pta.dfs(3), False), []) + +    def test_dfs_objects(self): +        pta = PTA(['IDLE', 'TX']) +        pta.add_transition('UNINITIALIZED', 'IDLE', 'init') +        pta.add_transition('IDLE', 'TX', 'send') +        pta.add_transition('TX', 'IDLE', 'txComplete') +        traces = list(pta.dfs(2)) +        self.assertEqual(len(traces), 1) +        trace = traces[0] +        self.assertEqual(len(trace), 3) +        self.assertEqual(trace[0][0].name, 'init') +        self.assertEqual(trace[1][0].name, 'send') +        self.assertEqual(trace[2][0].name, 'txComplete') +        self.assertEqual(pta.get_transition_id(trace[0][0]), 0) +        self.assertEqual(pta.get_transition_id(trace[1][0]), 1) +        self.assertEqual(pta.get_transition_id(trace[2][0]), 2) +      def test_from_json(self):          pta = PTA.from_json(example_json_1)          self.assertEqual(pta.parameters, ['datarate', 'txbytes', 'txpower']) @@ -125,6 +151,13 @@ class TestPTA(unittest.TestCase):          self.assertEqual(pta.transitions[3].name, 'send')          self.assertEqual(pta.transitions[4].name, 'txComplete') +    #def test_to_json(self): +    #    pta = PTA.from_json(example_json_1) +    #    json = pta.to_json() +    #    json['state'].pop('UNINITIALIZED') +    #    print(json) +    #    self.assertDictEqual(json, example_json_1) +      def test_from_json_dfs(self):          pta = PTA.from_json(example_json_1)          self.assertEqual(sorted(dfs_tran_to_name(pta.dfs(1), False)), [['init', 'init'], ['init', 'send'], ['init', 'setTxPower']]) | 
