summaryrefslogtreecommitdiff
path: root/mysql-test
diff options
context:
space:
mode:
Diffstat (limited to 'mysql-test')
-rw-r--r--mysql-test/main/func_json.result14
-rw-r--r--mysql-test/main/func_json.test20
2 files changed, 34 insertions, 0 deletions
diff --git a/mysql-test/main/func_json.result b/mysql-test/main/func_json.result
index 02f044be479..043b2ea375b 100644
--- a/mysql-test/main/func_json.result
+++ b/mysql-test/main/func_json.result
@@ -2348,5 +2348,19 @@ SELECT JSON_OVERLAPS(@json1, @json2);
JSON_OVERLAPS(@json1, @json2)
0
#
+# MDEV-29381: JSON paths containing dashes are reported as
+# syntax errors in procedures
+#
+DROP PROCEDURE IF EXISTS my_proc;
+Warnings:
+Note 1305 PROCEDURE test.my_proc does not exist
+CREATE PROCEDURE my_proc()
+BEGIN
+DECLARE result TEXT;
+SET result = JSON_EXTRACT('{ "my-key": 1 }', '$."my-key"');
+END $$
+CALL my_proc();
+DROP PROCEDURE IF EXISTS my_proc;
+#
# End of 10.9 Test
#
diff --git a/mysql-test/main/func_json.test b/mysql-test/main/func_json.test
index 8123ab4be8a..88d9eb4e775 100644
--- a/mysql-test/main/func_json.test
+++ b/mysql-test/main/func_json.test
@@ -1605,6 +1605,26 @@ SET @json2 = '{"kk":{"k1":"v1","k2":"v2","k3":"v3"}}';
SELECT JSON_OVERLAPS(@json2, @json1);
SELECT JSON_OVERLAPS(@json1, @json2);
+
+--echo #
+--echo # MDEV-29381: JSON paths containing dashes are reported as
+--echo # syntax errors in procedures
+--echo #
+
+DROP PROCEDURE IF EXISTS my_proc;
+
+DELIMITER $$;
+CREATE PROCEDURE my_proc()
+BEGIN
+DECLARE result TEXT;
+SET result = JSON_EXTRACT('{ "my-key": 1 }', '$."my-key"');
+END $$
+DELIMITER ;$$
+
+CALL my_proc();
+
+DROP PROCEDURE IF EXISTS my_proc;
+
--echo #
--echo # End of 10.9 Test
--echo #