|
1 | 1 | import sys
|
2 | 2 | import unittest
|
3 | 3 | import tarantool
|
| 4 | +from tarantool.error import DatabaseError |
4 | 5 |
|
5 | 6 | from .lib.tarantool_server import TarantoolServer
|
| 7 | +from .lib.skip import skip_or_run_error_extra_info_test |
6 | 8 |
|
7 | 9 | class TestSuite_Request(unittest.TestCase):
|
8 | 10 | @classmethod
|
@@ -325,6 +327,77 @@ def test_14_idempotent_close(self):
|
325 | 327 | con.close()
|
326 | 328 | self.assertEqual(con.is_closed(), True)
|
327 | 329 |
|
| 330 | + @skip_or_run_error_extra_info_test |
| 331 | + def test_14_extra_error_info(self): |
| 332 | + try: |
| 333 | + self.con.eval("not a Lua code") |
| 334 | + except DatabaseError as exc: |
| 335 | + self.assertEqual(exc.extra_info.type, 'LuajitError') |
| 336 | + self.assertRegex(exc.extra_info.file, r'/tarantool') |
| 337 | + self.assertTrue(exc.extra_info.line > 0) |
| 338 | + self.assertEqual(exc.extra_info.message, "eval:1: unexpected symbol near 'not'") |
| 339 | + self.assertEqual(exc.extra_info.errno, 0) |
| 340 | + self.assertEqual(exc.extra_info.errcode, 32) |
| 341 | + self.assertEqual(exc.extra_info.fields, None) |
| 342 | + self.assertEqual(exc.extra_info.prev, None) |
| 343 | + else: |
| 344 | + self.fail('Expected error') |
| 345 | + |
| 346 | + @skip_or_run_error_extra_info_test |
| 347 | + def test_15_extra_error_info_stacked(self): |
| 348 | + try: |
| 349 | + self.con.eval(r""" |
| 350 | + local e1 = box.error.new(box.error.UNKNOWN) |
| 351 | + local e2 = box.error.new(box.error.TIMEOUT) |
| 352 | + e2:set_prev(e1) |
| 353 | + error(e2) |
| 354 | + """) |
| 355 | + except DatabaseError as exc: |
| 356 | + self.assertEqual(exc.extra_info.type, 'ClientError') |
| 357 | + self.assertRegex(exc.extra_info.file, 'eval') |
| 358 | + self.assertEqual(exc.extra_info.line, 3) |
| 359 | + self.assertEqual(exc.extra_info.message, "Timeout exceeded") |
| 360 | + self.assertEqual(exc.extra_info.errno, 0) |
| 361 | + self.assertEqual(exc.extra_info.errcode, 78) |
| 362 | + self.assertEqual(exc.extra_info.fields, None) |
| 363 | + self.assertNotEqual(exc.extra_info.prev, None) |
| 364 | + prev = exc.extra_info.prev |
| 365 | + self.assertEqual(prev.type, 'ClientError') |
| 366 | + self.assertEqual(prev.file, 'eval') |
| 367 | + self.assertEqual(prev.line, 2) |
| 368 | + self.assertEqual(prev.message, "Unknown error") |
| 369 | + self.assertEqual(prev.errno, 0) |
| 370 | + self.assertEqual(prev.errcode, 0) |
| 371 | + self.assertEqual(prev.fields, None) |
| 372 | + else: |
| 373 | + self.fail('Expected error') |
| 374 | + |
| 375 | + @skip_or_run_error_extra_info_test |
| 376 | + def test_16_extra_error_info_fields(self): |
| 377 | + try: |
| 378 | + self.con.eval(""" |
| 379 | + box.schema.func.create('forbidden_function') |
| 380 | + """) |
| 381 | + except DatabaseError as exc: |
| 382 | + self.assertEqual(exc.extra_info.type, 'AccessDeniedError') |
| 383 | + self.assertRegex(exc.extra_info.file, r'/tarantool') |
| 384 | + self.assertTrue(exc.extra_info.line > 0) |
| 385 | + self.assertEqual( |
| 386 | + exc.extra_info.message, |
| 387 | + "Create access to function 'forbidden_function' is denied for user 'test'") |
| 388 | + self.assertEqual(exc.extra_info.errno, 0) |
| 389 | + self.assertEqual(exc.extra_info.errcode, 42) |
| 390 | + self.assertEqual( |
| 391 | + exc.extra_info.fields, |
| 392 | + { |
| 393 | + 'object_type': 'function', |
| 394 | + 'object_name': 'forbidden_function', |
| 395 | + 'access_type': 'Create' |
| 396 | + }) |
| 397 | + self.assertEqual(exc.extra_info.prev, None) |
| 398 | + else: |
| 399 | + self.fail('Expected error') |
| 400 | + |
328 | 401 | @classmethod
|
329 | 402 | def tearDownClass(self):
|
330 | 403 | self.con.close()
|
|
0 commit comments