Python pymysql.err.OperationalError() Examples
The following are 19
code examples of pymysql.err.OperationalError().
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example.
You may also want to check out all available functions/classes of the module
pymysql.err
, or try the search function
.
Example #1
Source File: mysql.py From greentor with MIT License | 8 votes |
def _read_bytes(self, num_bytes): self._sock.set_readtimeout(self._read_timeout) while True: try: data = self._rfile.read(num_bytes) break except (IOError, OSError) as e: if e.errno == errno.EINTR: continue raise err.OperationalError( 2013, "Lost connection to MySQL server during query (%s)" % (e, )) if len(data) < num_bytes: raise err.OperationalError( 2013, "Lost connection to MySQL server during query") return data
Example #2
Source File: mysql_init.py From monasca-docker with Apache License 2.0 | 6 votes |
def retry(retries=5, delay=2.0, exc_types=(OperationalError, RequestException)): def decorator(func): def f_retry(*args, **kwargs): for i in range(retries): try: return func(*args, **kwargs) except exc_types as exc: if i < retries - 1: logger.info('%s failed (attempt %d of %d)', func.__name__, i + 1, retries) logger.debug('Caught exception, retrying...', exc_info=True) time.sleep(delay) else: logger.exception('Failed after %d attempts', retries) if isinstance(exc, RequestException): logger.debug('Response was: %r', exc.response.text) raise return f_retry return decorator
Example #3
Source File: test_err.py From scalyr-agent-2 with Apache License 2.0 | 5 votes |
def test_raise_mysql_exception(self): data = b"\xff\x15\x04Access denied" with self.assertRaises(err.OperationalError) as cm: err.raise_mysql_exception(data) self.assertEqual(cm.exception.args, (1045, 'Access denied'))
Example #4
Source File: test_load_local.py From aiomysql with MIT License | 5 votes |
def test_error_on_file_read(cursor, table_local_file): with patch.object(builtins, 'open') as open_mocked: m = MagicMock() m.read.side_effect = OperationalError(1024, 'Error reading file') m.close.return_value = None open_mocked.return_value = m with pytest.raises(OperationalError): await cursor.execute("LOAD DATA LOCAL INFILE 'some.txt'" " INTO TABLE test_load_local fields " "terminated by ','")
Example #5
Source File: test_load_local.py From aiomysql with MIT License | 5 votes |
def test_no_file(cursor, table_local_file): # Test load local infile when the file does not exist sql = "LOAD DATA LOCAL INFILE 'no_data.txt'" + \ " INTO TABLE test_load_local fields " + \ "terminated by ','" with pytest.raises(OperationalError): await cursor.execute(sql)
Example #6
Source File: mysql_parser_test.py From mysql_streamer with Apache License 2.0 | 5 votes |
def _wait_for_mysql_ready(container_host, timed_out_seconds=10): DB_NAME = 'test' DB_USER = 'mysql' timed_out = time.time() + timed_out_seconds while time.time() < timed_out: try: return pymysql.connect( host=container_host, user=DB_USER, db=DB_NAME ) except OperationalError: pass raise Exception('Unable to start MySQL db {}'.format(container_host))
Example #7
Source File: connections.py From TorMySQL with MIT License | 5 votes |
def _write_bytes(self, data): try: self._sock.write(data) except (AttributeError, IOError) as e: self._force_close() raise err.OperationalError( CR.CR_SERVER_GONE_ERROR, "MySQL server has gone away (%r)" % (e,))
Example #8
Source File: test_err.py From planespotter with MIT License | 5 votes |
def test_raise_mysql_exception_client_protocol_41(self): data = b"\xff\x15\x04#28000Access denied" with self.assertRaises(err.OperationalError) as cm: err.raise_mysql_exception(data) self.assertEqual(cm.exception.args, (1045, 'Access denied'))
Example #9
Source File: test_err.py From planespotter with MIT License | 5 votes |
def test_raise_mysql_exception(self): data = b"\xff\x15\x04Access denied" with self.assertRaises(err.OperationalError) as cm: err.raise_mysql_exception(data) self.assertEqual(cm.exception.args, (1045, 'Access denied'))
Example #10
Source File: test_err.py From scalyr-agent-2 with Apache License 2.0 | 5 votes |
def test_raise_mysql_exception_client_protocol_41(self): data = b"\xff\x15\x04#28000Access denied" with self.assertRaises(err.OperationalError) as cm: err.raise_mysql_exception(data) self.assertEqual(cm.exception.args, (1045, 'Access denied'))
Example #11
Source File: test_err.py From ServerlessCrawler-VancouverRealState with MIT License | 5 votes |
def test_raise_mysql_exception(self): data = b"\xff\x15\x04Access denied" with self.assertRaises(err.OperationalError) as cm: err.raise_mysql_exception(data) self.assertEqual(cm.exception.args, (1045, 'Access denied'))
Example #12
Source File: test_err.py From aws-servicebroker with Apache License 2.0 | 5 votes |
def test_raise_mysql_exception_client_protocol_41(self): data = b"\xff\x15\x04#28000Access denied" with self.assertRaises(err.OperationalError) as cm: err.raise_mysql_exception(data) self.assertEqual(cm.exception.args, (1045, 'Access denied'))
Example #13
Source File: test_err.py From aws-servicebroker with Apache License 2.0 | 5 votes |
def test_raise_mysql_exception(self): data = b"\xff\x15\x04Access denied" with self.assertRaises(err.OperationalError) as cm: err.raise_mysql_exception(data) self.assertEqual(cm.exception.args, (1045, 'Access denied'))
Example #14
Source File: test_err.py From satori with Apache License 2.0 | 5 votes |
def test_raise_mysql_exception_client_protocol_41(self): data = b"\xff\x15\x04#28000Access denied" with self.assertRaises(err.OperationalError) as cm: err.raise_mysql_exception(data) self.assertEqual(cm.exception.args, (1045, 'Access denied'))
Example #15
Source File: test_err.py From satori with Apache License 2.0 | 5 votes |
def test_raise_mysql_exception(self): data = b"\xff\x15\x04Access denied" with self.assertRaises(err.OperationalError) as cm: err.raise_mysql_exception(data) self.assertEqual(cm.exception.args, (1045, 'Access denied'))
Example #16
Source File: test_err.py From ServerlessCrawler-VancouverRealState with MIT License | 5 votes |
def test_raise_mysql_exception_client_protocol_41(self): data = b"\xff\x15\x04#28000Access denied" with self.assertRaises(err.OperationalError) as cm: err.raise_mysql_exception(data) self.assertEqual(cm.exception.args, (1045, 'Access denied'))
Example #17
Source File: connections.py From TorMySQL with MIT License | 4 votes |
def connect(self): self._closed = False self._loop = platform.current_ioloop() try: if self.unix_socket: self.host_info = "Localhost via UNIX socket" address = self.unix_socket self._secure = True else: self.host_info = "socket %s:%d" % (self.host, self.port) address = (self.host, self.port) sock = platform.IOStream(address, self.bind_address) sock.set_close_callback(self.stream_close_callback) child_gr = greenlet.getcurrent() main = child_gr.parent assert main is not None, "Execut must be running in child greenlet" def connected(future): if (hasattr(future, "_exc_info") and future._exc_info is not None) \ or (hasattr(future, "_exception") and future._exception is not None): child_gr.throw(future.exception()) else: self._sock = sock child_gr.switch() future = sock.connect(address, self.connect_timeout) future.add_done_callback(connected) main.switch() self._rfile = self._sock self._next_seq_id = 0 self._get_server_information() self._request_authentication() if self.sql_mode is not None: c = self.cursor() c.execute("SET sql_mode=%s", (self.sql_mode,)) if self.init_command is not None: c = self.cursor() c.execute(self.init_command) self.commit() if self.autocommit_mode is not None: self.autocommit(self.autocommit_mode) except Exception as e: if self._sock: self._rfile = None self._sock.close() self._sock = None exc = err.OperationalError( 2003, "Can't connect to MySQL server on %s (%r)" % ( self.unix_socket or ("%s:%s" % (self.host, self.port)), e)) # Keep original exception and traceback to investigate error. exc.original_exception = e exc.traceback = traceback.format_exc() raise exc
Example #18
Source File: connections.py From TorMySQL with MIT License | 4 votes |
def _read_bytes(self, num_bytes): if num_bytes <= self._rbuffer_size: self._rbuffer_size -= num_bytes return self._rbuffer.read(num_bytes) if self._rbuffer_size > 0: self._sock._read_buffer = self._rbuffer.read() + self._sock._read_buffer self._sock._read_buffer_size += self._rbuffer_size self._rbuffer_size = 0 if num_bytes <= self._sock._read_buffer_size: data, data_len = self._sock._read_buffer, self._sock._read_buffer_size self._sock._read_buffer = bytearray() self._sock._read_buffer_size = 0 if data_len == num_bytes: return bytes(data) self._rbuffer_size = data_len - num_bytes self._rbuffer = StringIO(data) return self._rbuffer.read(num_bytes) child_gr = greenlet.getcurrent() main = child_gr.parent assert main is not None, "Execut must be running in child greenlet" def read_callback(future): try: data = future.result() if len(data) == num_bytes: return child_gr.switch(bytes(data)) self._rbuffer_size = len(data) - num_bytes self._rbuffer = StringIO(data) return child_gr.switch(self._rbuffer.read(num_bytes)) except Exception as e: self._force_close() return child_gr.throw(err.OperationalError( CR.CR_SERVER_LOST, "Lost connection to MySQL server during query (%s)" % (e,))) try: future = self._sock.read_bytes(num_bytes) future.add_done_callback(read_callback) except (AttributeError, IOError) as e: self._force_close() raise err.OperationalError( CR.CR_SERVER_LOST, "Lost connection to MySQL server during query (%s)" % (e,)) return main.switch()
Example #19
Source File: mysql.py From greentor with MIT License | 4 votes |
def _connect(self, sock=None): try: if sock is None: sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sock = AsyncSocket(sock) sock.set_connecttimeout(self.connect_timeout) sock.connect((self.host, self.port)) sock.set_nodelay(True) self._sock = sock # self._rfile = _makefile(sock, 'rb') self._rfile = sock self._next_seq_id = 0 self._get_server_information() self._request_authentication() if self.sql_mode is not None: c = self.cursor() c.execute("SET sql_mode=%s", (self.sql_mode, )) if self.init_command is not None: c = self.cursor() c.execute(self.init_command) c.close() self.commit() if self.autocommit_mode is not None: self.autocommit(self.autocommit_mode) except BaseException as e: self._rfile = None if sock is not None: try: sock.close() except: pass if isinstance(e, (OSError, IOError, socket.error)): exc = err.OperationalError( 2003, "Can't connect to MySQL server on %r (%s)" % (self.host, e)) # Keep original exception and traceback to investigate error. exc.original_exception = e exc.traceback = traceback.format_exc() if DEBUG: print(exc.traceback) raise exc # If e is neither DatabaseError or IOError, It's a bug. # But raising AssertionError hides original error. # So just reraise it. raise