mirror of
https://github.com/pgadmin-org/pgadmin4.git
synced 2025-02-25 18:55:31 -06:00
Ensure all messages are retrieved from the server in the Query Tool. Fixes #3094
This commit is contained in:
committed by
Dave Page
parent
d1ab47c10c
commit
d3c303e455
112
web/pgadmin/tools/sqleditor/tests/test_poll_query_tool.py
Normal file
112
web/pgadmin/tools/sqleditor/tests/test_poll_query_tool.py
Normal file
@@ -0,0 +1,112 @@
|
||||
##########################################################################
|
||||
#
|
||||
# pgAdmin 4 - PostgreSQL Tools
|
||||
#
|
||||
# Copyright (C) 2013 - 2018, The pgAdmin Development Team
|
||||
# This software is released under the PostgreSQL Licence
|
||||
#
|
||||
##########################################################################
|
||||
|
||||
import json
|
||||
|
||||
from pgadmin.browser.server_groups.servers.databases.tests import utils as \
|
||||
database_utils
|
||||
from pgadmin.utils.route import BaseTestGenerator
|
||||
from regression import parent_node_dict
|
||||
from regression.python_test_utils import test_utils as utils
|
||||
|
||||
|
||||
class TestPollQueryTool(BaseTestGenerator):
|
||||
""" This class will test the query tool polling. """
|
||||
scenarios = [
|
||||
('When query tool polling returns messages with result data-set',
|
||||
dict(
|
||||
sql=[
|
||||
"""
|
||||
DROP TABLE IF EXISTS test_for_notices;
|
||||
|
||||
DO $$
|
||||
BEGIN
|
||||
RAISE NOTICE 'Hello, world!';
|
||||
END $$;
|
||||
|
||||
SELECT 'CHECKING POLLING';
|
||||
""",
|
||||
"""
|
||||
DO $$
|
||||
BEGIN
|
||||
FOR i in 1..1000 LOOP
|
||||
RAISE NOTICE 'Count is %', i;
|
||||
END LOOP;
|
||||
END $$;
|
||||
|
||||
SELECT 'CHECKING POLLING FOR LONG MESSAGES';
|
||||
""",
|
||||
"SELECT 'CHECKING POLLING WITHOUT MESSAGES';"
|
||||
],
|
||||
expected_message=['NOTICE: table "test_for_notices" ' +
|
||||
"""does not exist, skipping
|
||||
NOTICE: Hello, world!
|
||||
""",
|
||||
"\n".join(["NOTICE: Count is {0}".format(i)
|
||||
for i in range(1, 1001)]) + "\n",
|
||||
None],
|
||||
expected_result=['CHECKING POLLING',
|
||||
'CHECKING POLLING FOR LONG MESSAGES',
|
||||
'CHECKING POLLING WITHOUT MESSAGES'],
|
||||
print_messages=['2 NOTICES WITH DATASET',
|
||||
'1000 NOTICES WITH DATASET',
|
||||
'NO NOTICE WITH DATASET'
|
||||
]
|
||||
))
|
||||
]
|
||||
|
||||
def runTest(self):
|
||||
""" This function will check messages return by query tool polling. """
|
||||
database_info = parent_node_dict["database"][-1]
|
||||
self.server_id = database_info["server_id"]
|
||||
|
||||
self.db_id = database_info["db_id"]
|
||||
db_con = database_utils.connect_database(self,
|
||||
utils.SERVER_GROUP,
|
||||
self.server_id,
|
||||
self.db_id)
|
||||
if not db_con["info"] == "Database connected.":
|
||||
raise Exception("Could not connect to the database.")
|
||||
|
||||
# Initialize query tool
|
||||
url = '/datagrid/initialize/query_tool/{0}/{1}/{2}'.format(
|
||||
utils.SERVER_GROUP, self.server_id, self.db_id)
|
||||
response = self.tester.post(url)
|
||||
self.assertEquals(response.status_code, 200)
|
||||
|
||||
response_data = json.loads(response.data.decode('utf-8'))
|
||||
self.trans_id = response_data['data']['gridTransId']
|
||||
|
||||
cnt = 0
|
||||
for s in self.sql:
|
||||
print("Executing and polling with: " + self.print_messages[cnt])
|
||||
# Start query tool transaction
|
||||
url = '/sqleditor/query_tool/start/{0}'.format(self.trans_id)
|
||||
response = self.tester.post(url, data=json.dumps({"sql": s}),
|
||||
content_type='html/json')
|
||||
|
||||
self.assertEquals(response.status_code, 200)
|
||||
|
||||
# Query tool polling
|
||||
url = '/sqleditor/poll/{0}'.format(self.trans_id)
|
||||
response = self.tester.get(url)
|
||||
self.assertEquals(response.status_code, 200)
|
||||
response_data = json.loads(response.data.decode('utf-8'))
|
||||
|
||||
# Check the returned messages
|
||||
self.assertEquals(self.expected_message[cnt],
|
||||
response_data['data']['additional_messages'])
|
||||
# Check the output
|
||||
self.assertEquals(self.expected_result[cnt],
|
||||
response_data['data']['result'][0][0])
|
||||
|
||||
cnt += 1
|
||||
|
||||
# Disconnect the database
|
||||
database_utils.disconnect_database(self, self.server_id, self.db_id)
|
Reference in New Issue
Block a user