test_figure.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. # -*- coding: utf-8 -*-
  2. import pytest
  3. import copy
  4. from ioex.calcex import Figure, UnitMismatchError
  5. @pytest.mark.parametrize(('init_params', 'init_kwargs', 'expected_value', 'expected_unit'), [
  6. [[], {}, None, None],
  7. [[123.4], {}, 123.4, None],
  8. [[None, 'm/s²'], {}, None, 'm/s²'],
  9. [[123.4, 'm/s²'], {}, 123.4, 'm/s²'],
  10. [[1234, '米/s²'], {}, 1234, '米/s²'],
  11. [[], {'value': 123.4}, 123.4, None],
  12. [[], {'unit': 'm/s²'}, None, 'm/s²'],
  13. [[], {'value': 123.4, 'unit': 'm/s²'}, 123.4, 'm/s²'],
  14. [[], {'value': 1234, 'unit': '米/s²'}, 1234, '米/s²'],
  15. [[1234], {'unit': '米/s²'}, 1234, '米/s²'],
  16. ])
  17. def test_init(init_params, init_kwargs, expected_value, expected_unit):
  18. f = Figure(*init_params, **init_kwargs)
  19. assert expected_value == f.value
  20. assert expected_unit == f.unit
  21. @pytest.mark.parametrize(('init_params', 'init_kwargs'), [
  22. [[12.34], {'value': 123.4}],
  23. [[12, 'm/h'], {'unit': 'm/s²'}],
  24. ])
  25. def test_init_multiple_values(init_params, init_kwargs):
  26. with pytest.raises(Exception):
  27. Figure(*init_params, **init_kwargs)
  28. @pytest.mark.parametrize(('value'), [
  29. 1234,
  30. 123.4,
  31. '一千',
  32. ])
  33. def test_set_value(value):
  34. f = Figure()
  35. assert None == f.value
  36. f.value = value
  37. assert value == f.value
  38. f.value = None
  39. assert None == f.value
  40. f.set_value(value)
  41. assert value == f.value
  42. @pytest.mark.parametrize(('unit'), [
  43. 'μg/l',
  44. '米/s²',
  45. ])
  46. def test_set_unit(unit):
  47. f = Figure()
  48. assert None == f.unit
  49. f.unit = unit
  50. assert unit == f.unit
  51. f.unit = None
  52. assert None == f.unit
  53. f.set_unit(unit)
  54. assert unit == f.unit
  55. @pytest.mark.parametrize(('figure', 'expected_string'), [
  56. [Figure(), '?'],
  57. [Figure(value=123.4), '123.4'],
  58. [Figure(unit='m/s²'), '? m/s²'],
  59. [Figure(value=123.4, unit='m/s²'), '123.4 m/s²'],
  60. [Figure(value=1234, unit='米/s²'), '1234 米/s²'],
  61. ])
  62. def test_str(figure, expected_string):
  63. assert expected_string == str(figure)
  64. @pytest.mark.parametrize(('a', 'b'), [
  65. [Figure(1, 'm'), Figure(1, 'm')],
  66. ])
  67. def test_eq(a, b):
  68. assert a == b
  69. assert not (a != b)
  70. @pytest.mark.parametrize(('a', 'b'), [
  71. [Figure(1, 'm'), Figure(2, 'g')],
  72. [Figure(1, 'm'), Figure(2, 'm')],
  73. [Figure(2, 'm'), Figure(2, 'g')],
  74. ])
  75. def test_neq(a, b):
  76. assert a != b
  77. assert not (a == b)
  78. @pytest.mark.parametrize(('a', 'b', 'expected_sum'), [
  79. [Figure(1, 'm'), Figure(2, 'm'), Figure(3, 'm')],
  80. [Figure(-2, 'l'), Figure(-4, 'l'), Figure(-6, 'l')],
  81. [Figure(-1), Figure(3), Figure(2, None)],
  82. ])
  83. def test_add(a, b, expected_sum):
  84. assert expected_sum == a + b
  85. @pytest.mark.parametrize(('a', 'b'), [
  86. [Figure(1, 'm'), Figure(2, 'l')],
  87. [Figure(-2, 'l'), Figure(-4, None)],
  88. ])
  89. def test_add_unit_mismatch(a, b):
  90. with pytest.raises(UnitMismatchError):
  91. a + b
  92. def test_add_persistent():
  93. a = Figure([1], ['m'])
  94. b = Figure([2], ['m'])
  95. s = a + b
  96. assert Figure([1, 2], ['m']) == s
  97. a.value[0] = 3
  98. a.unit[0] = 'g'
  99. b.value[0] = 4
  100. b.unit[0] = 'l'
  101. assert Figure([1, 2], ['m']) == s
  102. @pytest.mark.parametrize(('a', 'b', 'expected_sum'), [
  103. [Figure(1, 'm'), Figure(2, 'm'), Figure(-1, 'm')],
  104. [Figure(-2, 'l'), Figure(-4, 'l'), Figure(2, 'l')],
  105. [Figure(-1), Figure(3), Figure(-4, None)],
  106. ])
  107. def test_sub(a, b, expected_sum):
  108. assert expected_sum == a - b
  109. @pytest.mark.parametrize(('a', 'b'), [
  110. [Figure(1, 'm'), Figure(2, 'l')],
  111. [Figure(-2, 'l'), Figure(-4, None)],
  112. ])
  113. def test_sub_unit_mismatch(a, b):
  114. with pytest.raises(UnitMismatchError):
  115. a - b
  116. def test_sub_persistent():
  117. a = Figure(1, ['m'])
  118. b = Figure(2, ['m'])
  119. d = a - b
  120. assert Figure(-1, ['m']) == d
  121. a.value = 3
  122. a.unit[0] = 'g'
  123. b.value = 4
  124. b.unit[0] = 'l'
  125. assert Figure(-1, ['m']) == d