You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

30 lines
1.0 KiB

  1. import stormpy
  2. import stormpy.logic
  3. from helpers.helper import get_example_path
  4. import math
  5. from configurations import dft
  6. @dft
  7. class TestBuild:
  8. def test_load_dft_json(self):
  9. dft = stormpy.dft.load_dft_json_file(get_example_path("dft", "and.json"))
  10. assert dft.nr_elements() == 3
  11. assert dft.nr_be() == 2
  12. assert dft.nr_dynamic() == 0
  13. assert not dft.can_have_nondeterminism()
  14. def test_load_dft_galileo(self):
  15. dft = stormpy.dft.load_dft_galileo_file(get_example_path("dft", "hecs.dft"))
  16. assert dft.nr_elements() == 23
  17. assert dft.nr_be() == 13
  18. assert dft.nr_dynamic() == 2
  19. assert not dft.can_have_nondeterminism()
  20. def test_analyze_mttf(self):
  21. dft = stormpy.dft.load_dft_json_file(get_example_path("dft", "and.json"))
  22. formulas = stormpy.parse_properties("T=? [ F \"failed\" ]")
  23. assert dft.nr_elements() == 3
  24. results = stormpy.dft.analyze_dft(dft, [formulas[0].raw_formula])
  25. assert math.isclose(results[0], 3)