test_nan_inf.py 2.4 KB
Newer Older
W
WangXi 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
# Copyright (c) 2019 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

import unittest
import os
import sys
import subprocess
P
pangyoki 已提交
19 20 21
import paddle

paddle.enable_static()
W
WangXi 已提交
22 23 24


class TestNanInf(unittest.TestCase):
25

W
WangXi 已提交
26 27 28 29 30 31 32
    def setUp(self):
        self._python_interp = sys.executable
        if os.getenv('WITH_COVERAGE', 'OFF') == 'ON':
            self._python_interp += " -m coverage run --branch -p"

        self.env = os.environ.copy()

33
    def check_nan_inf(self):
W
WangXi 已提交
34 35
        cmd = self._python_interp

36 37 38 39
        proc = subprocess.Popen(cmd.split(" "),
                                stdout=subprocess.PIPE,
                                stderr=subprocess.PIPE,
                                env=self.env)
W
WangXi 已提交
40 41 42 43 44 45 46 47

        out, err = proc.communicate()
        returncode = proc.returncode

        print(out)
        print(err)

        # in python3, type(out+err) is 'bytes', need use encode
48 49 50
        if paddle.fluid.core.is_compiled_with_cuda():
            assert (out + err).find('find nan or inf==='.encode()) != -1
        else:
51 52
            assert (out + err).find(
                'There are `nan` or `inf` in tensor'.encode()) != -1
W
WangXi 已提交
53

54 55 56 57 58 59 60 61
    def test_nan_inf_in_static_mode(self):
        self._python_interp += " check_nan_inf_base.py"
        self.check_nan_inf()

    def test_nan_inf_in_dynamic_mode(self):
        self._python_interp += " check_nan_inf_base_dygraph.py"
        self.check_nan_inf()

W
WangXi 已提交
62 63

class TestNanInfEnv(TestNanInf):
64

W
WangXi 已提交
65 66 67 68 69 70 71 72 73 74 75 76
    def setUp(self):
        super(TestNanInfEnv, self).setUp()
        # windows python have some bug with env, so need use str to pass ci
        # otherwise, "TypeError: environment can only contain strings"
        self.env[str("PADDLE_INF_NAN_SKIP_OP")] = str("mul")
        self.env[str("PADDLE_INF_NAN_SKIP_ROLE")] = str("loss")
        self.env[str("PADDLE_INF_NAN_SKIP_VAR")] = str(
            "elementwise_add:fc_0.tmp_1")


if __name__ == '__main__':
    unittest.main()