No Description
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.

test_integer.py 2.1KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. #
  2. # This file is part of Lodel 2 (https://github.com/OpenEdition)
  3. #
  4. # Copyright (C) 2015-2017 Cléo UMS-3287
  5. #
  6. # This program is free software: you can redistribute it and/or modify
  7. # it under the terms of the GNU Affero General Public License as published
  8. # by the Free Software Foundation, either version 3 of the License, or
  9. # (at your option) any later version.
  10. #
  11. # This program is distributed in the hope that it will be useful,
  12. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. # GNU Affero General Public License for more details.
  15. #
  16. # You should have received a copy of the GNU Affero General Public License
  17. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. #
  19. import unittest
  20. from lodel.leapi.datahandlers.datas import Integer, Boolean
  21. from lodel.exceptions import *
  22. test_int = Integer()
  23. class IntegerTestCase(unittest.TestCase):
  24. def test_integer_check_bad_data_value(self):
  25. # Incorrect values
  26. for test_bad_value in ['ok','ceci est un test']:
  27. with self.assertRaises(FieldValidationError):
  28. test_int._check_data_value(test_bad_value)
  29. def test_integer_check_good_data_value(self):
  30. # Correct values
  31. for test_correct_value in [10, '15.2', 15.0, '-15.0']:
  32. value = test_int._check_data_value(test_correct_value)
  33. self.assertEqual(value, int(float(test_correct_value)))
  34. def test_integer_check_bad_strict_data_value(self):
  35. # Incorrect values
  36. for test_correct_value in ['15', 15.0, '15.0']:
  37. with self.assertRaises(FieldValidationError):
  38. test_int._check_data_value(test_correct_value, True)
  39. def test_integer_check_good_strict_data_value(self):
  40. # Correct values
  41. for test_correct_value in [0, 15, -15]:
  42. value = test_int._check_data_value(test_correct_value)
  43. self.assertEqual(value, int(float(test_correct_value)))
  44. def test_can_override(self):
  45. test_boolean = Boolean()
  46. self.assertFalse(test_int.can_override(test_boolean))