2015-12-16 15:00:52 +03:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
# test_errcodes.py - unit test for psycopg2.errcodes module
|
|
|
|
#
|
2019-02-17 04:34:52 +03:00
|
|
|
# Copyright (C) 2015-2019 Daniele Varrazzo <daniele.varrazzo@gmail.com>
|
2020-01-18 00:10:44 +03:00
|
|
|
# Copyright (C) 2020 The Psycopg Team
|
2015-12-16 15:00:52 +03:00
|
|
|
#
|
|
|
|
# psycopg2 is free software: you can redistribute it and/or modify it
|
|
|
|
# under the terms of the GNU Lesser General Public License as published
|
|
|
|
# by the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# In addition, as a special exception, the copyright holders give
|
|
|
|
# permission to link this program with the OpenSSL library (or with
|
|
|
|
# modified versions of OpenSSL that use the same license as OpenSSL),
|
|
|
|
# and distribute linked combinations including the two.
|
|
|
|
#
|
|
|
|
# You must obey the GNU Lesser General Public License in all respects for
|
|
|
|
# all of the code used other than OpenSSL.
|
|
|
|
#
|
|
|
|
# psycopg2 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 Lesser General Public
|
|
|
|
# License for more details.
|
|
|
|
|
2017-12-02 04:59:53 +03:00
|
|
|
import unittest
|
2017-12-04 05:47:19 +03:00
|
|
|
from .testutils import ConnectingTestCase, slow, reload
|
2015-12-16 15:00:52 +03:00
|
|
|
|
|
|
|
from threading import Thread
|
|
|
|
from psycopg2 import errorcodes
|
|
|
|
|
2016-10-11 02:10:53 +03:00
|
|
|
|
2015-12-16 15:00:52 +03:00
|
|
|
class ErrocodeTests(ConnectingTestCase):
|
2017-02-02 04:53:50 +03:00
|
|
|
@slow
|
2015-12-16 15:00:52 +03:00
|
|
|
def test_lookup_threadsafe(self):
|
|
|
|
|
|
|
|
# Increase if it does not fail with KeyError
|
|
|
|
MAX_CYCLES = 2000
|
|
|
|
|
|
|
|
errs = []
|
2016-10-11 02:10:53 +03:00
|
|
|
|
2015-12-16 15:00:52 +03:00
|
|
|
def f(pg_code='40001'):
|
|
|
|
try:
|
|
|
|
errorcodes.lookup(pg_code)
|
2017-11-21 07:00:35 +03:00
|
|
|
except Exception as e:
|
2015-12-16 15:00:52 +03:00
|
|
|
errs.append(e)
|
|
|
|
|
2017-12-04 05:47:19 +03:00
|
|
|
for __ in range(MAX_CYCLES):
|
2015-12-16 15:00:52 +03:00
|
|
|
reload(errorcodes)
|
|
|
|
(t1, t2) = (Thread(target=f), Thread(target=f))
|
|
|
|
(t1.start(), t2.start())
|
|
|
|
(t1.join(), t2.join())
|
|
|
|
|
|
|
|
if errs:
|
|
|
|
self.fail(
|
2020-11-17 22:37:42 +03:00
|
|
|
"raised {} errors in {} cycles (first is {} {})".format(
|
2015-12-16 15:00:52 +03:00
|
|
|
len(errs), MAX_CYCLES,
|
|
|
|
errs[0].__class__.__name__, errs[0]))
|
|
|
|
|
2020-09-05 22:09:07 +03:00
|
|
|
def test_ambiguous_names(self):
|
|
|
|
self.assertEqual(
|
|
|
|
errorcodes.lookup('2F004'), "READING_SQL_DATA_NOT_PERMITTED")
|
|
|
|
self.assertEqual(
|
|
|
|
errorcodes.lookup('38004'), "READING_SQL_DATA_NOT_PERMITTED")
|
|
|
|
self.assertEqual(errorcodes.READING_SQL_DATA_NOT_PERMITTED, '38004')
|
|
|
|
self.assertEqual(errorcodes.READING_SQL_DATA_NOT_PERMITTED_, '2F004')
|
|
|
|
|
2015-12-16 15:00:52 +03:00
|
|
|
|
|
|
|
def test_suite():
|
|
|
|
return unittest.TestLoader().loadTestsFromName(__name__)
|
|
|
|
|
2018-10-23 02:39:14 +03:00
|
|
|
|
2015-12-16 15:00:52 +03:00
|
|
|
if __name__ == "__main__":
|
|
|
|
unittest.main()
|