Fixed mysql reconnect on error
Change-Id: I4bb502b295ee9f5d748bb11eadeae7392235981c
This commit is contained in:
parent
a82a49a1e8
commit
82ae201cc4
1
.gitignore
vendored
1
.gitignore
vendored
@ -10,3 +10,4 @@ ChangeLog
|
|||||||
build
|
build
|
||||||
dist
|
dist
|
||||||
monasca_notification.egg-info
|
monasca_notification.egg-info
|
||||||
|
.*.sw*
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
# Copyright 2015 FUJITSU LIMITED
|
# Copyright 2015 FUJITSU LIMITED
|
||||||
|
# (C) Copyright 2015 Hewlett Packard Enterprise Development Company LP
|
||||||
#
|
#
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
|
# 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
|
# in compliance with the License. You may obtain a copy of the License at
|
||||||
@ -52,11 +53,13 @@ class MysqlRepo(BaseRepo):
|
|||||||
try:
|
try:
|
||||||
if self._mysql is None:
|
if self._mysql is None:
|
||||||
self._connect_to_mysql()
|
self._connect_to_mysql()
|
||||||
|
|
||||||
cur = self._mysql.cursor()
|
cur = self._mysql.cursor()
|
||||||
cur.execute(self._find_alarm_action_sql, (alarm['alarmDefinitionId'], alarm['newState']))
|
cur.execute(self._find_alarm_action_sql, (alarm['alarmDefinitionId'], alarm['newState']))
|
||||||
|
|
||||||
for row in cur:
|
for row in cur:
|
||||||
yield (row[1].lower(), row[0], row[2])
|
yield (row[1].lower(), row[0], row[2])
|
||||||
except MySQLdb.Error as e:
|
except MySQLdb.Error as e:
|
||||||
|
self._mysql = None
|
||||||
log.exception("Couldn't fetch alarms actions %s", e)
|
log.exception("Couldn't fetch alarms actions %s", e)
|
||||||
raise exc.DatabaseException(e)
|
raise exc.DatabaseException(e)
|
||||||
|
58
tests/test_mysql_repo.py
Normal file
58
tests/test_mysql_repo.py
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
# (C) Copyright 2015 Hewlett Packard Enterprise Development Company LP
|
||||||
|
#
|
||||||
|
# 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 mock
|
||||||
|
import unittest
|
||||||
|
|
||||||
|
import MySQLdb
|
||||||
|
|
||||||
|
from monasca_notification.common.repositories import exceptions as exc
|
||||||
|
from monasca_notification.common.repositories.mysql import mysql_repo
|
||||||
|
|
||||||
|
|
||||||
|
class TestMySqlRepo(unittest.TestCase):
|
||||||
|
@mock.patch('monasca_notification.common.repositories.mysql.mysql_repo.MySQLdb')
|
||||||
|
def testReconnect(self, mock_mysql):
|
||||||
|
m = mock.MagicMock()
|
||||||
|
|
||||||
|
m.cursor.side_effect = MySQLdb.Error
|
||||||
|
|
||||||
|
mock_mysql.connect.return_value = m
|
||||||
|
mock_mysql.Error = MySQLdb.Error
|
||||||
|
|
||||||
|
config = {'mysql': {'host': 'foo',
|
||||||
|
'user': 'bar',
|
||||||
|
'passwd': '1',
|
||||||
|
'db': '2'}}
|
||||||
|
|
||||||
|
repo = mysql_repo.MysqlRepo(config)
|
||||||
|
|
||||||
|
alarm = {'alarmDefinitionId': 'foo',
|
||||||
|
'newState': 'bar'}
|
||||||
|
|
||||||
|
def get_notification(repo, alarm):
|
||||||
|
g = repo.fetch_notification(alarm)
|
||||||
|
for x in g:
|
||||||
|
pass
|
||||||
|
|
||||||
|
try:
|
||||||
|
get_notification(repo, alarm)
|
||||||
|
except exc.DatabaseException:
|
||||||
|
try:
|
||||||
|
get_notification(repo, alarm)
|
||||||
|
except Exception:
|
||||||
|
pass
|
||||||
|
|
||||||
|
self.assertEqual(mock_mysql.connect.call_count, 2)
|
Loading…
Reference in New Issue
Block a user