2014-10-15 18:35:16 -04:00
# (c) 2012-2014, Michael DeHaan <michael.dehaan@gmail.com>
#
# This file is part of Ansible
#
# Ansible is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Ansible is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
2014-10-15 19:25:48 -04:00
# Make coding more python3-ish
from __future__ import ( absolute_import , division , print_function )
__metaclass__ = type
2014-10-21 01:14:30 -04:00
from ansible . compat . tests import unittest
2014-10-15 18:35:16 -04:00
from ansible . parsing . yaml . objects import AnsibleBaseYAMLObject
from ansible . errors import AnsibleError
2014-10-21 01:14:30 -04:00
from ansible . compat . tests import BUILTINS
from ansible . compat . tests . mock import mock_open , patch
2014-10-15 18:35:16 -04:00
class TestErrors ( unittest . TestCase ) :
def setUp ( self ) :
2014-10-23 15:39:27 -05:00
self . message = ' This is the error message '
2015-10-08 10:04:15 -04:00
self . unicode_message = ' This is an error with \xf0 \x9f \x98 \xa8 in it '
2014-10-15 18:35:16 -04:00
2014-10-15 17:59:51 -07:00
self . obj = AnsibleBaseYAMLObject ( )
2014-10-15 18:35:16 -04:00
def tearDown ( self ) :
pass
def test_basic_error ( self ) :
e = AnsibleError ( self . message )
2016-01-19 12:09:04 -05:00
self . assertEqual ( e . message , self . message )
self . assertEqual ( e . __repr__ ( ) , self . message )
2014-10-15 18:35:16 -04:00
2015-10-08 10:04:15 -04:00
def test_basic_unicode_error ( self ) :
e = AnsibleError ( self . unicode_message )
2016-01-19 12:09:04 -05:00
self . assertEqual ( e . message , self . unicode_message )
self . assertEqual ( e . __repr__ ( ) , self . unicode_message )
2015-10-08 10:04:15 -04:00
2014-10-23 15:39:27 -05:00
@patch.object ( AnsibleError , ' _get_error_lines_from_file ' )
2014-10-15 17:59:51 -07:00
def test_error_with_object ( self , mock_method ) :
2015-04-01 14:54:22 -07:00
self . obj . ansible_pos = ( ' foo.yml ' , 1 , 1 )
2014-10-15 18:35:16 -04:00
2014-10-23 15:39:27 -05:00
mock_method . return_value = ( ' this is line 1 \n ' , ' ' )
2014-10-15 17:59:51 -07:00
e = AnsibleError ( self . message , self . obj )
2014-10-15 18:35:16 -04:00
2016-01-19 12:09:04 -05:00
self . assertEqual ( e . message , " This is the error message \n \n The error appears to have been in ' foo.yml ' : line 1, column 1, but may \n be elsewhere in the file depending on the exact syntax problem. \n \n The offending line appears to be: \n \n \n this is line 1 \n ^ here \n " )
2014-10-15 17:59:51 -07:00
2014-10-23 15:39:27 -05:00
def test_get_error_lines_from_file ( self ) :
2014-10-15 17:59:51 -07:00
m = mock_open ( )
m . return_value . readlines . return_value = [ ' this is line 1 \n ' ]
2014-10-21 01:24:09 -04:00
with patch ( ' {0} .open ' . format ( BUILTINS ) , m ) :
2014-10-15 17:59:51 -07:00
# this line will be found in the file
2015-04-01 14:54:22 -07:00
self . obj . ansible_pos = ( ' foo.yml ' , 1 , 1 )
2014-10-15 17:59:51 -07:00
e = AnsibleError ( self . message , self . obj )
2016-01-19 12:09:04 -05:00
self . assertEqual ( e . message , " This is the error message \n \n The error appears to have been in ' foo.yml ' : line 1, column 1, but may \n be elsewhere in the file depending on the exact syntax problem. \n \n The offending line appears to be: \n \n \n this is line 1 \n ^ here \n " )
2014-10-15 17:59:51 -07:00
# this line will not be found, as it is out of the index range
2015-04-01 14:54:22 -07:00
self . obj . ansible_pos = ( ' foo.yml ' , 2 , 1 )
2014-10-15 17:59:51 -07:00
e = AnsibleError ( self . message , self . obj )
2016-01-19 12:09:04 -05:00
self . assertEqual ( e . message , " This is the error message \n \n The error appears to have been in ' foo.yml ' : line 2, column 1, but may \n be elsewhere in the file depending on the exact syntax problem. \n \n (specified line no longer in file, maybe it changed?) " )
2015-04-01 14:54:22 -07:00
2015-10-08 10:04:15 -04:00
m = mock_open ( )
m . return_value . readlines . return_value = [ ' this line has unicode \xf0 \x9f \x98 \xa8 in it! \n ' ]
with patch ( ' {0} .open ' . format ( BUILTINS ) , m ) :
# this line will be found in the file
self . obj . ansible_pos = ( ' foo.yml ' , 1 , 1 )
e = AnsibleError ( self . unicode_message , self . obj )
2016-01-19 12:09:04 -05:00
self . assertEqual ( e . message , " This is an error with \xf0 \x9f \x98 \xa8 in it \n \n The error appears to have been in ' foo.yml ' : line 1, column 1, but may \n be elsewhere in the file depending on the exact syntax problem. \n \n The offending line appears to be: \n \n \n this line has unicode \xf0 \x9f \x98 \xa8 in it! \n ^ here \n " )
2015-10-08 10:04:15 -04:00