erp5_core_test: Add a test for sqlvar type="nb".
sqlvar type="nb" was broken by sqlvar patch without being noticed, thus test is required. See commit ebdc34d4.
Showing
############################################################################## | |||
# | |||
# Copyright (c) 2002-2023 Nexedi SA and Contributors. All Rights Reserved. | |||
# | |||
# WARNING: This program as such is intended to be used by professional | |||
# programmers who take the whole responsibility of assessing all potential | |||
# consequences resulting from its eventual inadequacies and bugs | |||
# End users who are looking for a ready-to-use solution with commercial | |||
# guarantees and support are strongly adviced to contract a Free Software | |||
# Service Company | |||
# | |||
# This program is Free Software; you can redistribute it and/or | |||
# modify it under the terms of the GNU General Public License | |||
# as published by the Free Software Foundation; either version 2 | |||
# of the License, or (at your option) any later version. | |||
# | |||
# This program 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 General Public License for more details. | |||
# | |||
# You should have received a copy of the GNU General Public License | |||
# along with this program; if not, write to the Free Software | |||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | |||
# | |||
############################################################################## | |||
from Products.ERP5Type.tests.ERP5TypeTestCase import ERP5TypeTestCase | |||
class TestSQLVar(ERP5TypeTestCase): | |||
def test_sqlvar(self): | |||
""" | |||
Make sure that sqlvar patch does not break sqlvar type="nb". | |||
""" | |||
sqlmethod = self.portal.newContent(portal_type='SQL Method', | |||
temp_object=True, | |||
connection_id='erp5_sql_connection', | |||
arguments_src='value', | |||
src='<dtml-sqlvar value type="string">') | |||
self.assertEqual(sqlmethod(value='', src__=1), "''") | |||
self.assertEqual(sqlmethod(value=None, src__=1), 'null') | |||
|
|||
sqlmethod.edit(src='<dtml-sqlvar value type="string" optional>') | |||
self.assertEqual(sqlmethod(value='', src__=1), "''") | |||
self.assertEqual(sqlmethod(value=None, src__=1), 'null') | |||
sqlmethod.edit(src='<dtml-sqlvar value type="nb">') | |||
self.assertRaises(ValueError, sqlmethod, value='', src__=1) | |||
self.assertEqual(sqlmethod(value=None, src__=1), 'null') | |||
sqlmethod.edit(src='<dtml-sqlvar value type="nb" optional>') | |||
self.assertEqual(sqlmethod(value='', src__=1), 'null') | |||
self.assertEqual(sqlmethod(value=None, src__=1), 'null') |