pytorch/caffe2/python/operator_fp_exceptions_test.py
Aaron Gokaslan 748bac8757 [BE]: Apply pyupgrade yield from and unit test alias upgrades (#94309)
Applies some more harmless pyupgrades. This one gets rid of deprecated aliases in unit_tests and more upgrades yield for loops into yield from generators which are more performance and propagates more information / exceptions from original generator. This is the modern recommended way of forwarding generators.
Pull Request resolved: https://github.com/pytorch/pytorch/pull/94309
Approved by: https://github.com/albanD
2023-02-07 20:08:58 +00:00

41 lines
1.2 KiB
Python

from caffe2.python import core, workspace
from caffe2.python.test_util import TestCase
import numpy as np
import unittest
def setThrowIfFpExceptions(enabled):
core.GlobalInit(["caffe2", "--caffe2_operator_throw_if_fp_exceptions=%d" % (1 if enabled else 0)])
class OperatorFPExceptionsTest(TestCase):
def test_fp_exception_divbyzero(self):
# This test asserts the followings
# - If flag caffe2_operator_throw_if_fp_exceptions is set,
# floating point exceptions will be thrown
# - If flag caffe2_operator_throw_if_fp_exceptions is not set,
# floating point exceptions will not be thrown
workspace.blobs["0"] = np.array([0.0], dtype=np.float32)
workspace.blobs["1"] = np.array([1.0], dtype=np.float32)
net = core.Net("test_fp")
net.Div(["1", "0"], "out")
for throw_if_fp_exceptions in (True, False):
setThrowIfFpExceptions(throw_if_fp_exceptions)
exception_raised = False
try:
workspace.RunNetOnce(net)
except Exception as e:
exception_raised = True
self.assertEqual(exception_raised, throw_if_fp_exceptions)
if __name__ == '__main__':
unittest.main()