[MIG] base_external_dbsource: Migration to 14.0

This commit is contained in:
bilbonet
2021-07-13 19:08:14 +02:00
parent 413d42c69c
commit 269949c0ee
4 changed files with 10 additions and 23 deletions

View File

@@ -3,7 +3,7 @@
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{
"name": "External Database Sources",
"version": "13.0.1.0.0",
"version": "14.0.1.0.0",
"category": "Tools",
"author": "Daniel Reis, " "LasLabs, " "Odoo Community Association (OCA)",
"website": "https://github.com/OCA/server-backend",

View File

@@ -1,12 +0,0 @@
# Copyright 2016 LasLabs Inc.
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).
from odoo.exceptions import UserError
class ConnectionFailedError(UserError):
pass
class ConnectionSuccessError(UserError):
pass

View File

@@ -8,8 +8,7 @@ from contextlib import contextmanager
import psycopg2
from odoo import _, api, fields, models, tools
from ..exceptions import ConnectionFailedError, ConnectionSuccessError
from odoo.exceptions import ValidationError
_logger = logging.getLogger(__name__)
@@ -41,7 +40,7 @@ class BaseExternalDbsource(models.Model):
# to allow for override.
PWD_STRING = "PWD=%s;"
name = fields.Char("Datasource name", required=True, size=64)
name = fields.Char("Datasource name", required=True)
conn_string = fields.Text(
"Connection string",
help="""
@@ -59,7 +58,7 @@ class BaseExternalDbsource(models.Model):
""",
)
conn_string_full = fields.Text(readonly=True, compute="_compute_conn_string_full")
password = fields.Char("Password", size=40)
password = fields.Char("Password")
client_cert = fields.Text()
client_key = fields.Text()
ca_certs = fields.Char(help="Path to CA Certs file on server.")
@@ -173,14 +172,15 @@ class BaseExternalDbsource(models.Model):
with self.connection_open():
pass
except Exception as e:
raise ConnectionFailedError(
raise ValidationError(
_("Connection test failed:\n" "Here is what we got instead:\n%s")
% tools.ustr(e)
)
raise ConnectionSuccessError(
raise ValidationError(
_("Connection test succeeded:\n" "Everything seems properly set up!")
)
def remote_browse(self, record_ids, *args, **kwargs):
"""It browses for and returns the records from remote by ID

View File

@@ -5,8 +5,7 @@ import mock
from odoo.sql_db import connection_info_for
from odoo.tests import common
from ..exceptions import ConnectionFailedError, ConnectionSuccessError
from odoo.exceptions import ValidationError
class TestBaseExternalDbsource(common.TransactionCase):
def setUp(self):
@@ -63,14 +62,14 @@ class TestBaseExternalDbsource(common.TransactionCase):
def test_connection_success(self):
""" It should raise for successful connection """
with self.assertRaises(ConnectionSuccessError):
with self.assertRaises(ValidationError):
self.dbsource.connection_test()
def test_connection_fail(self):
""" It should raise for failed/invalid connection """
with mock.patch.object(self.dbsource, "connection_open") as conn:
conn.side_effect = Exception
with self.assertRaises(ConnectionFailedError):
with self.assertRaises(ValidationError):
self.dbsource.connection_test()
def test_connection_open_calls_close(self):