from overload_numeric import * import math nums = Nums() limits = Limits() def check(got, expected): if got != expected: raise RuntimeError("got: " + got + " expected: " + expected) check(nums.over(0), "signed char") check(nums.over(0.0), "float") check(nums.over(limits.schar_min()), "signed char") check(nums.over(limits.schar_max()), "signed char") check(nums.over(limits.schar_min() - 1), "short") check(nums.over(limits.schar_max() + 1), "short") check(nums.over(limits.shrt_min()), "short") check(nums.over(limits.shrt_max()), "short") check(nums.over(limits.shrt_min() - 1), "int") check(nums.over(limits.shrt_max() + 1), "int") check(nums.over(limits.int_min()), "int") check(nums.over(limits.int_max()), "int") check(nums.over(limits.flt_min()), "float") check(nums.over(limits.flt_max()), "float") check(nums.over(limits.flt_max() * 10), "double") check(nums.over(-limits.flt_max() * 10), "double") check(nums.over(limits.dbl_max()), "double") check(nums.over(-limits.dbl_max()), "double") check(nums.over(float("inf")), "float") check(nums.over(float("-inf")), "float") check(nums.over(float("nan")), "float") # Just check if the following are accepted without exceptions being thrown nums.doublebounce(float("inf")) nums.doublebounce(float("-inf")) nums.doublebounce(float("nan"))