mirror of
https://github.com/MariaDB/server.git
synced 2025-07-30 16:24:05 +03:00
Fix for
Bug#35335 funcs_1: Some tests fail within load_file during pushbuild runs Solution: 1. Move files with input data used in load_file, load data etc. from suite/funcs_1/<whatever> to std_data 2. Use for testsuite funcs_1 the server option --secure-file-priv=<MYSQLTEST_VARDIR> 3. Outfiles have to be stored under MYSQLTEST_VARDIR + changes according to WL#4304 Cleanup in funcs_1 tests - backport of fixes/improvements made in 5.1 to 5.0 The differences between scripts in 5.0 and 5.1 cause much additional and annoying work during any upmerge. - replace error numbers with names - improved comments - improved formatting - Unify storage engine names so that result files for storage engine variants do not differ (some tests) - remove a script no more used (tests are done in other scripts) BitKeeper/deleted/.del-triggers_master.test: Delete: mysql-test/suite/funcs_1/triggers/triggers_master.test mysql-test/std_data/funcs_1/innodb_tb1.txt: Rename: mysql-test/suite/funcs_1/data/innodb_tb1.txt -> mysql-test/std_data/funcs_1/innodb_tb1.txt mysql-test/std_data/funcs_1/innodb_tb2.txt: Rename: mysql-test/suite/funcs_1/data/innodb_tb2.txt -> mysql-test/std_data/funcs_1/innodb_tb2.txt mysql-test/std_data/funcs_1/innodb_tb3.txt: Rename: mysql-test/suite/funcs_1/data/innodb_tb3.txt -> mysql-test/std_data/funcs_1/innodb_tb3.txt mysql-test/std_data/funcs_1/innodb_tb4.txt: Rename: mysql-test/suite/funcs_1/data/innodb_tb4.txt -> mysql-test/std_data/funcs_1/innodb_tb4.txt mysql-test/std_data/funcs_1/memory_tb1.txt: Rename: mysql-test/suite/funcs_1/data/memory_tb1.txt -> mysql-test/std_data/funcs_1/memory_tb1.txt mysql-test/std_data/funcs_1/memory_tb2.txt: Rename: mysql-test/suite/funcs_1/data/memory_tb2.txt -> mysql-test/std_data/funcs_1/memory_tb2.txt mysql-test/std_data/funcs_1/memory_tb3.txt: Rename: mysql-test/suite/funcs_1/data/memory_tb3.txt -> mysql-test/std_data/funcs_1/memory_tb3.txt mysql-test/std_data/funcs_1/memory_tb4.txt: Rename: mysql-test/suite/funcs_1/data/memory_tb4.txt -> mysql-test/std_data/funcs_1/memory_tb4.txt mysql-test/std_data/funcs_1/myisam_tb1.txt: Rename: mysql-test/suite/funcs_1/data/myisam_tb1.txt -> mysql-test/std_data/funcs_1/myisam_tb1.txt mysql-test/std_data/funcs_1/myisam_tb2.txt: Rename: mysql-test/suite/funcs_1/data/myisam_tb2.txt -> mysql-test/std_data/funcs_1/myisam_tb2.txt mysql-test/std_data/funcs_1/myisam_tb3.txt: Rename: mysql-test/suite/funcs_1/data/myisam_tb3.txt -> mysql-test/std_data/funcs_1/myisam_tb3.txt mysql-test/std_data/funcs_1/myisam_tb4.txt: Rename: mysql-test/suite/funcs_1/data/myisam_tb4.txt -> mysql-test/std_data/funcs_1/myisam_tb4.txt mysql-test/std_data/funcs_1/t3.txt: Rename: mysql-test/suite/funcs_1/data/t3.txt -> mysql-test/std_data/funcs_1/t3.txt mysql-test/std_data/funcs_1/t4.txt: Rename: mysql-test/suite/funcs_1/data/t4.txt -> mysql-test/std_data/funcs_1/t4.txt mysql-test/std_data/funcs_1/t7.txt: Rename: mysql-test/suite/funcs_1/data/t7.txt -> mysql-test/std_data/funcs_1/t7.txt mysql-test/std_data/funcs_1/t9.txt: Rename: mysql-test/suite/funcs_1/data/t9.txt -> mysql-test/std_data/funcs_1/t9.txt mysql-test/Makefile.am: Introduce installation of funcs_1 files in std_data. mysql-test/mysql-test-run.pl: The tests within funcs_1 need a server started with --secure-file-priv=<MYSQLTEST_VARDIR> like the main regression tests. mysql-test/suite/funcs_1/README.txt: Extended description mysql-test/suite/funcs_1/datadict/datadict_bug_12777.inc: Cleanup mysql-test/suite/funcs_1/datadict/datadict_load.inc: Cleanup mysql-test/suite/funcs_1/include/innodb_tb1.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/innodb_tb2.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/innodb_tb3.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/innodb_tb4.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/memory_tb1.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/memory_tb2.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/memory_tb3.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/memory_tb4.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/myisam_tb1.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/myisam_tb2.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/myisam_tb3.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/myisam_tb4.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/include/sp_tb.inc: Adjustment to new storage place of infile. mysql-test/suite/funcs_1/r/innodb_func_view.result: Updated results mysql-test/suite/funcs_1/r/innodb_storedproc_02.result: Updated results mysql-test/suite/funcs_1/r/innodb_storedproc_03.result: Updated results mysql-test/suite/funcs_1/r/innodb_storedproc_06.result: Updated results mysql-test/suite/funcs_1/r/innodb_storedproc_07.result: Updated results mysql-test/suite/funcs_1/r/innodb_storedproc_08.result: Updated results mysql-test/suite/funcs_1/r/innodb_storedproc_10.result: Updated results mysql-test/suite/funcs_1/r/innodb_trig_0102.result: Updated results mysql-test/suite/funcs_1/r/innodb_trig_03.result: Updated results mysql-test/suite/funcs_1/r/innodb_trig_0407.result: Updated results mysql-test/suite/funcs_1/r/innodb_trig_08.result: Updated results mysql-test/suite/funcs_1/r/innodb_trig_09.result: Updated results mysql-test/suite/funcs_1/r/innodb_trig_1011ext.result: Updated results mysql-test/suite/funcs_1/r/innodb_trig_frkey.result: Updated results mysql-test/suite/funcs_1/r/innodb_views.result: Updated results mysql-test/suite/funcs_1/r/is_columns_innodb.result: Updated results mysql-test/suite/funcs_1/r/is_columns_memory.result: Updated results mysql-test/suite/funcs_1/r/is_columns_myisam.result: Updated results mysql-test/suite/funcs_1/r/is_columns_ndb.result: Updated results mysql-test/suite/funcs_1/r/is_tables_innodb.result: Updated results mysql-test/suite/funcs_1/r/is_tables_memory.result: Updated results mysql-test/suite/funcs_1/r/is_tables_myisam.result: Updated results mysql-test/suite/funcs_1/r/is_tables_ndb.result: Updated results mysql-test/suite/funcs_1/r/memory_func_view.result: Updated results mysql-test/suite/funcs_1/r/memory_storedproc_02.result: Updated results mysql-test/suite/funcs_1/r/memory_storedproc_03.result: Updated results mysql-test/suite/funcs_1/r/memory_storedproc_06.result: Updated results mysql-test/suite/funcs_1/r/memory_storedproc_07.result: Updated results mysql-test/suite/funcs_1/r/memory_storedproc_08.result: Updated results mysql-test/suite/funcs_1/r/memory_storedproc_10.result: Updated results mysql-test/suite/funcs_1/r/memory_trig_0102.result: Updated results mysql-test/suite/funcs_1/r/memory_trig_03.result: Updated results mysql-test/suite/funcs_1/r/memory_trig_0407.result: Updated results mysql-test/suite/funcs_1/r/memory_trig_08.result: Updated results mysql-test/suite/funcs_1/r/memory_trig_09.result: Updated results mysql-test/suite/funcs_1/r/memory_trig_1011ext.result: Updated results mysql-test/suite/funcs_1/r/memory_views.result: Updated results mysql-test/suite/funcs_1/r/myisam_func_view.result: Updated results mysql-test/suite/funcs_1/r/myisam_storedproc_02.result: Updated results mysql-test/suite/funcs_1/r/myisam_storedproc_03.result: Updated results mysql-test/suite/funcs_1/r/myisam_storedproc_06.result: Updated results mysql-test/suite/funcs_1/r/myisam_storedproc_07.result: Updated results mysql-test/suite/funcs_1/r/myisam_storedproc_08.result: Updated results mysql-test/suite/funcs_1/r/myisam_storedproc_10.result: Updated results mysql-test/suite/funcs_1/r/myisam_trig_0102.result: Updated results mysql-test/suite/funcs_1/r/myisam_trig_03.result: Updated results mysql-test/suite/funcs_1/r/myisam_trig_0407.result: Updated results mysql-test/suite/funcs_1/r/myisam_trig_08.result: Updated results mysql-test/suite/funcs_1/r/myisam_trig_09.result: Updated results mysql-test/suite/funcs_1/r/myisam_trig_1011ext.result: Updated results mysql-test/suite/funcs_1/r/myisam_views.result: Updated results mysql-test/suite/funcs_1/storedproc/cleanup_sp_tb.inc: "--echo" instead of SQL command. mysql-test/suite/funcs_1/storedproc/load_sp_tb.inc: Adjustment to new storage place of infile + correct formatting. mysql-test/suite/funcs_1/storedproc/storedproc_02.inc: Backport from 5.1 + correct formatting. mysql-test/suite/funcs_1/storedproc/storedproc_03.inc: Minor improvements + correct formatting. mysql-test/suite/funcs_1/storedproc/storedproc_06.inc: Backport from 5.1 + correct formatting mysql-test/suite/funcs_1/storedproc/storedproc_10.inc: Backport from 5.1. + correct formatting mysql-test/suite/funcs_1/t/innodb_trig_0407.test: Cleanup mysql-test/suite/funcs_1/t/is_basics_mixed.test: Adjustment to new storage place of outfile. mysql-test/suite/funcs_1/t/memory_storedproc_02.test: Cleanup mysql-test/suite/funcs_1/t/memory_storedproc_03.test: Cleanup mysql-test/suite/funcs_1/t/memory_storedproc_06.test: Cleanup mysql-test/suite/funcs_1/t/memory_storedproc_07.test: Cleanup mysql-test/suite/funcs_1/t/memory_storedproc_08.test: Cleanup mysql-test/suite/funcs_1/t/memory_storedproc_10.test: Cleanup mysql-test/suite/funcs_1/t/myisam_storedproc_02.test: Cleanup mysql-test/suite/funcs_1/t/myisam_storedproc_03.test: Cleanup mysql-test/suite/funcs_1/t/myisam_storedproc_06.test: Cleanup mysql-test/suite/funcs_1/t/myisam_storedproc_07.test: Cleanup mysql-test/suite/funcs_1/t/myisam_storedproc_08.test: Cleanup mysql-test/suite/funcs_1/t/myisam_storedproc_10.test: Cleanup mysql-test/suite/funcs_1/triggers/trig_frkey2.inc: Cleanup mysql-test/suite/funcs_1/triggers/triggers_0102.inc: Cleanup mysql-test/suite/funcs_1/triggers/triggers_03.inc: Backport from 5.1 mysql-test/suite/funcs_1/triggers/triggers_0407.inc: Backport from 5.1 mysql-test/suite/funcs_1/triggers/triggers_08.inc: Backport from 5.1 mysql-test/suite/funcs_1/triggers/triggers_09.inc: Backport from 5.1 mysql-test/suite/funcs_1/triggers/triggers_1011ext.inc: Backport from 5.1 mysql-test/suite/funcs_1/views/func_view.inc: Backport from 5.1 mysql-test/suite/funcs_1/views/views_master.inc: Cleanup mysql-test/std_data/funcs_1/load_file.txt: New BitKeeper file ``mysql-test/std_data/funcs_1/load_file.txt''
This commit is contained in:
@ -1,17 +1,17 @@
|
||||
#################################################################
|
||||
# This file inclde tests that address the foreign key cases of
|
||||
# the following requirements since they are specific to innodb.
|
||||
# Other test cases for these requirements are included in the
|
||||
# This file inclde tests that address the foreign key cases of
|
||||
# the following requirements since they are specific to innodb.
|
||||
# Other test cases for these requirements are included in the
|
||||
# triggers_master.test file.
|
||||
#################################################################
|
||||
|
||||
--disable_abort_on_error
|
||||
|
||||
# OBN - The following tests are disabled until triggers are supported with forign
|
||||
# keys in innodb (foreign keys tests dispabled - bug 11472)
|
||||
# keys in innodb (foreign keys tests dispabled - bug 11472)
|
||||
#################################################################################
|
||||
#Section x.x.x.3
|
||||
# Test case: Similar to 3.5.10.5 but with ten tables to see if multiple triggers
|
||||
# Test case: Similar to 3.5.10.5 but with ten tables to see if multiple triggers
|
||||
# can be executed at once
|
||||
let $message= Testcase x.x.x.3:;
|
||||
--source include/show_msg.inc
|
||||
@ -21,58 +21,58 @@ let $message= Testcase x.x.x.3:;
|
||||
--enable_warnings
|
||||
|
||||
eval CREATE TABLE t0 (col1 char(50)) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t1 (id INT NOT NULL, col1 char(50),
|
||||
eval CREATE TABLE t1 (id INT NOT NULL, col1 char(50),
|
||||
PRIMARY KEY (id)) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t2 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t2 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t3 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t3 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t4 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t4 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t5 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t5 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t6 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t6 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t7 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t7 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t8 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t8 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t9 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t9 (id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t10(id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t10(id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t11(id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t11(id INT PRIMARY KEY, f_id INT, INDEX par_ind
|
||||
(f_id), col1 char(50), FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=$engine_type;
|
||||
|
||||
create trigger tr1 after update on t2 for each row
|
||||
create trigger tr1 after update on t2 for each row
|
||||
insert into t0 values ('tr_t2');
|
||||
create trigger tr2 after update on t3 for each row
|
||||
create trigger tr2 after update on t3 for each row
|
||||
insert into t0 values ('tr_t3');
|
||||
create trigger tr3 after update on t4 for each row
|
||||
create trigger tr3 after update on t4 for each row
|
||||
insert into t0 values ('tr_t4');
|
||||
create trigger tr3 after update on t5 for each row
|
||||
create trigger tr3 after update on t5 for each row
|
||||
insert into t0 values ('tr_t5');
|
||||
create trigger tr4 after update on t6 for each row
|
||||
create trigger tr4 after update on t6 for each row
|
||||
insert into t0 values ('tr_t6');
|
||||
create trigger tr5 after update on t7 for each row
|
||||
create trigger tr5 after update on t7 for each row
|
||||
insert into t0 values ('tr_t7');
|
||||
create trigger tr5 after update on t8 for each row
|
||||
create trigger tr5 after update on t8 for each row
|
||||
insert into t0 values ('tr_t8');
|
||||
create trigger tr6 after update on t9 for each row
|
||||
create trigger tr6 after update on t9 for each row
|
||||
insert into t0 values ('tr_t9');
|
||||
create trigger tr7 after update on t10 for each row
|
||||
create trigger tr7 after update on t10 for each row
|
||||
insert into t0 values ('tr_t10');
|
||||
create trigger tr8 after update on t11 for each row
|
||||
create trigger tr8 after update on t11 for each row
|
||||
insert into t0 values ('tr_t11');
|
||||
|
||||
insert into t1 values (1,'Department A');
|
||||
@ -134,10 +134,10 @@ let $message= Testcase x.x.x.3:;
|
||||
|
||||
|
||||
#Section 3.5.10.5
|
||||
# Test case: Ensure that every trigger that should be activated by every possible
|
||||
# type of implicit update of its subject table (e.g. a FOREIGN KEY SET
|
||||
# DEFAULT action or an UPDATE of a view based on the subject table)
|
||||
# is indeed activated correctly.
|
||||
# Test case: Ensure that every trigger that should be activated by every possible
|
||||
# type of implicit update of its subject table (e.g. a FOREIGN KEY SET
|
||||
# DEFAULT action or an UPDATE of a view based on the subject table)
|
||||
# is indeed activated correctly.
|
||||
let $message= Testcase 3.5.10.5 (foreign keys):;
|
||||
--source include/show_msg.inc
|
||||
|
||||
@ -146,11 +146,11 @@ let $message= Testcase 3.5.10.5 (foreign keys):;
|
||||
DROP TABLE IF EXISTS t1, t2;
|
||||
--enable_warnings
|
||||
|
||||
eval CREATE TABLE t1 (id INT NOT NULL, col1 char(50),
|
||||
eval CREATE TABLE t1 (id INT NOT NULL, col1 char(50),
|
||||
PRIMARY KEY (id)) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t2 (id INT PRIMARY KEY, f_id INT,
|
||||
INDEX par_ind (f_id), col1 char(50),
|
||||
FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t2 (id INT PRIMARY KEY, f_id INT,
|
||||
INDEX par_ind (f_id), col1 char(50),
|
||||
FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE SET NULL ON UPDATE CASCADE) ENGINE=$engine_type;
|
||||
create trigger tr_t2 after update on t2
|
||||
for each row set @counter=@counter+1;
|
||||
@ -191,9 +191,9 @@ let $message= Testcase 3.5.10.5 (foreign keys):;
|
||||
|
||||
|
||||
#Section 3.5.10.6
|
||||
# Test case: Ensure that every trigger that should be activated by every possible
|
||||
# type of implicit deletion from its subject table (e.g. a FOREIGN KEY
|
||||
# CASCADE action or a DELETE from a view based on the subject table)
|
||||
# Test case: Ensure that every trigger that should be activated by every possible
|
||||
# type of implicit deletion from its subject table (e.g. a FOREIGN KEY
|
||||
# CASCADE action or a DELETE from a view based on the subject table)
|
||||
# is indeed activated correctly.
|
||||
let $message= Testcase 3.5.10.6 (foreign keys):;
|
||||
--source include/show_msg.inc
|
||||
@ -202,11 +202,11 @@ let $message= Testcase 3.5.10.6 (foreign keys):;
|
||||
DROP TABLE IF EXISTS t1, t2;
|
||||
--enable_warnings
|
||||
|
||||
eval CREATE TABLE t1 (id INT NOT NULL, col1 char(50),
|
||||
eval CREATE TABLE t1 (id INT NOT NULL, col1 char(50),
|
||||
PRIMARY KEY (id)) ENGINE=$engine_type;
|
||||
eval CREATE TABLE t2 (id INT PRIMARY KEY, f_id INT,
|
||||
INDEX par_ind (f_id), col1 char(50),
|
||||
FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
eval CREATE TABLE t2 (id INT PRIMARY KEY, f_id INT,
|
||||
INDEX par_ind (f_id), col1 char(50),
|
||||
FOREIGN KEY (f_id) REFERENCES t1(id)
|
||||
ON DELETE CASCADE) ENGINE=$engine_type;
|
||||
|
||||
create trigger tr_t2 before delete on t2
|
||||
|
@ -1,7 +1,7 @@
|
||||
#======================================================================
|
||||
#
|
||||
# Trigger Tests
|
||||
# (test case numbering refer to requirement document TP v1.1)
|
||||
# Trigger Tests
|
||||
# (test case numbering refer to requirement document TP v1.1)
|
||||
#======================================================================
|
||||
|
||||
# OBM - ToDo
|
||||
@ -20,37 +20,37 @@
|
||||
# Testcase: Ensure that all clauses that should be supported are supported.
|
||||
let $message= Testcase: 3.5.1.1:;
|
||||
--source include/show_msg.inc
|
||||
# OBN - This test case tests basic trigger definition and execution
|
||||
# OBN - This test case tests basic trigger definition and execution
|
||||
# of INSERT/UPDATE/DELETE actions and BEFORE/AFTER timings.
|
||||
# As such it covers the equirements in sections 3.5.6.1, 3.5.6.2,
|
||||
# As such it covers the equirements in sections 3.5.6.1, 3.5.6.2,
|
||||
# 3.5.6.4, 3.5.6.5, 3.5.7.1, 3.5.7.2, 3.5.7.3, 3.5.7.17 below.
|
||||
# - Note currently as a result of limitations with locking tables in
|
||||
# - Note currently as a result of limitations with locking tables in
|
||||
# triggers, a specifc lockingof the tables is done.
|
||||
# Once fixed, the locking and alias referances should be removed
|
||||
|
||||
use test;
|
||||
# Trigger Definition
|
||||
Create trigger trg1_1 BEFORE INSERT
|
||||
Create trigger trg1_1 BEFORE INSERT
|
||||
on tb3 for each row set @test_before = 2, new.f142 = @test_before;
|
||||
Create trigger trg1_2 AFTER INSERT
|
||||
Create trigger trg1_2 AFTER INSERT
|
||||
on tb3 for each row set @test_after = 6;
|
||||
Create trigger trg1_4 BEFORE UPDATE
|
||||
on tb3 for each row set @test_before = 27,
|
||||
new.f142 = @test_before,
|
||||
Create trigger trg1_4 BEFORE UPDATE
|
||||
on tb3 for each row set @test_before = 27,
|
||||
new.f142 = @test_before,
|
||||
new.f122 = 'Before Update Trigger';
|
||||
Create trigger trg1_3 AFTER UPDATE
|
||||
Create trigger trg1_3 AFTER UPDATE
|
||||
on tb3 for each row set @test_after = '15';
|
||||
Create trigger trg1_5 BEFORE DELETE on tb3 for each row
|
||||
select count(*) into @test_before from tb3 as tr_tb3
|
||||
Create trigger trg1_5 BEFORE DELETE on tb3 for each row
|
||||
select count(*) into @test_before from tb3 as tr_tb3
|
||||
where f121 = 'Test 3.5.1.1';
|
||||
Create trigger trg1_6 AFTER DELETE on tb3 for each row
|
||||
select count(*) into @test_after from tb3 as tr_tb3
|
||||
Create trigger trg1_6 AFTER DELETE on tb3 for each row
|
||||
select count(*) into @test_after from tb3 as tr_tb3
|
||||
where f121 = 'Test 3.5.1.1';
|
||||
# Trigger Execution Insert (before and after)
|
||||
set @test_before = 1;
|
||||
set @test_after = 5;
|
||||
select @test_before, @test_after;
|
||||
Insert into tb3 (f121, f122, f142, f144, f134)
|
||||
Insert into tb3 (f121, f122, f142, f144, f134)
|
||||
values ('Test 3.5.1.1', 'First Row', @test_before, @test_after, 1);
|
||||
select f121, f122, f142, f144, f134 from tb3 where f121 = 'Test 3.5.1.1';
|
||||
select @test_before, @test_after;
|
||||
@ -59,15 +59,15 @@ use test;
|
||||
set @test_before = 18;
|
||||
set @test_after = 8;
|
||||
select @test_before, @test_after;
|
||||
Update tb3 set tb3.f122 = 'Update',
|
||||
tb3.f142 = @test_before,
|
||||
tb3.f144 = @test_after
|
||||
Update tb3 set tb3.f122 = 'Update',
|
||||
tb3.f142 = @test_before,
|
||||
tb3.f144 = @test_after
|
||||
where tb3.f121 = 'Test 3.5.1.1';
|
||||
select f121, f122, f142, f144, f134 from tb3 where f121 = 'Test 3.5.1.1';
|
||||
select @test_before, @test_after;
|
||||
|
||||
# Trigger Execution Delete (before and after)
|
||||
Insert into tb3 (f121, f122, f142, f144, f134)
|
||||
Insert into tb3 (f121, f122, f142, f144, f134)
|
||||
values ('Test 3.5.1.1', 'Second Row', 5, 6, 2);
|
||||
set @test_before = 0;
|
||||
set @test_after = 0;
|
||||
@ -79,35 +79,35 @@ use test;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg1_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg1_2;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg1_3;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg1_4;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg1_5;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg1_6;
|
||||
--enable_warnings
|
||||
delete from tb3 where f121='Test 3.5.1.1';
|
||||
--enable_warnings
|
||||
|
||||
#Section 3.5.1.2
|
||||
# Testcase: Ensure that all clauses that should not be supported are disallowed
|
||||
# with an appropriate error message.
|
||||
# Testcase: Ensure that all clauses that should not be supported are disallowed
|
||||
# with an appropriate error message.
|
||||
let $message= Testcase: 3.5.1.2:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
--error 1064
|
||||
Create trigger trg_1 after insert
|
||||
--error ER_PARSE_ERROR
|
||||
Create trigger trg_1 after insert
|
||||
on tb3 for each statement set @x= 1;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg_1;
|
||||
--enable_warnings
|
||||
|
||||
@ -116,66 +116,66 @@ let $message= Testcase: 3.5.1.2:;
|
||||
# Testcase: Ensure that all supported clauses are supported only in the correct order.
|
||||
let $message= Testcase 3.5.1.3:;
|
||||
--source include/show_msg.inc
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER trg3_1 on tb3 BEFORE INSERT for each row set new.f120 = 't';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE trg3_2 TRIGGER AFTER INSERT on tb3 for each row set new.f120 = 's';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER trg3_3 Before DELETE on tb3 set @ret1 = 'test' for each row;
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER trg3_4 DELETE AFTER on tb3 set @ret1 = 'test' for each row;
|
||||
|
||||
--error 1064
|
||||
CREATE for each row TRIGGER trg3_5 AFTER UPDATE on tb3 set @ret1 = 'test';
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE for each row TRIGGER trg3_5 AFTER UPDATE on tb3 set @ret1 = 'test';
|
||||
|
||||
#Cleanup
|
||||
# OBN - Although none of the above should have been created we should do a cleanup
|
||||
# since if they have been created, not dropping them will affect following
|
||||
# tests.
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg3_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg3_2;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg3_3;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg3_4;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg3_5;
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.1.4
|
||||
# Testcase: Ensure that an appropriate error message is returned if a clause
|
||||
# Testcase: Ensure that an appropriate error message is returned if a clause
|
||||
# is out-of-order in an SQL statement.
|
||||
# OBN - FIXME - Missing 3.5.1.4 need to add
|
||||
|
||||
#Section 3.5.1.5
|
||||
# Testcase: Ensure that all clauses that are defined to be mandatory are indeed
|
||||
# Testcase: Ensure that all clauses that are defined to be mandatory are indeed
|
||||
# required to be mandatory by the MySQL server and tools
|
||||
let $message= Testcase: 3.5.1.5:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER trg4_1 AFTER on tb3 for each row set new.f120 = 'e';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER trg4_2 INSERT on tb3 for each set row new.f120 = 'f';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER trg4_3 BEFORE INSERT tb3 for each row set new.f120 = 'g';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER trg4_4 AFTER UPDATE on tb3 for each set new.f120 = 'g';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE trg4_5 AFTER DELETE on tb3 for each set new.f120 = 'g';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER trg4_6 BEFORE DELETE for each row set new.f120 = 'g';
|
||||
|
||||
#Cleanup
|
||||
@ -183,19 +183,19 @@ let $message= Testcase: 3.5.1.5:;
|
||||
# since if they have been created, not dropping them will affect following
|
||||
# tests.
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4_2;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4_3;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4_4;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4_5;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4_6;
|
||||
--enable_warnings
|
||||
--enable_warnings
|
||||
|
||||
#Section 3.5.1.6
|
||||
# Testcase: Ensure that any clauses that are defined to be optional are indeed
|
||||
@ -204,15 +204,15 @@ let $message= Testcase 3.5.1.6: - Need to fix;
|
||||
--source include/show_msg.inc
|
||||
# OBN - FIXME - Missing 3.5.1.6 need to add
|
||||
|
||||
#Section 3.5.1.7
|
||||
# Testcase: Ensure that all valid, fully-qualified, and non-qualified,
|
||||
#Section 3.5.1.7
|
||||
# Testcase: Ensure that all valid, fully-qualified, and non-qualified,
|
||||
# trigger names are accepted, at creation time.
|
||||
let $message= Testcase 3.5.1.7: - need to fix;
|
||||
--source include/show_msg.inc
|
||||
|
||||
drop table if exists t1;
|
||||
eval create table t1 (f1 int, f2 char(25),f3 int) engine=$engine_type;
|
||||
CREATE TRIGGER trg5_1 BEFORE INSERT on test.t1
|
||||
CREATE TRIGGER trg5_1 BEFORE INSERT on test.t1
|
||||
for each row set new.f3 = '14';
|
||||
CREATE TRIGGER trg_abcdefghijklmnopqrstuvwxyz1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
||||
BEFORE UPDATE on test.t1 for each row set new.f3 = '42';
|
||||
@ -221,39 +221,39 @@ let $message= Testcase 3.5.1.7: - need to fix;
|
||||
select * from t1;
|
||||
update t1 set f2='update 3.5.1.7';
|
||||
select * from t1;
|
||||
select trigger_name from information_schema.triggers;
|
||||
select trigger_name from information_schema.triggers order by trigger_name;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
--disable_warnings
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg5_1;
|
||||
# The above trigger should be dropped since the name was trimmed.
|
||||
drop trigger trg_abcdefghijklmnopqrstuvwxyz1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ;
|
||||
drop table t1;
|
||||
|
||||
#Section 3.5.1.8
|
||||
# Testcase: Ensure that any invalid trigger name is never accepted, and that an
|
||||
# Testcase: Ensure that any invalid trigger name is never accepted, and that an
|
||||
# appropriate error message is returned when the name is rejected.
|
||||
let $message= Testcase 3.5.1.8:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER trg12* before insert on tb3 for each row set new.f120 = 't';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER trigger before insert on tb3 for each row set new.f120 = 't';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER 100 before insert on tb3 for each row set new.f120 = 't';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER @@view before insert on tb3 for each row set new.f120 = 't';
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
CREATE TRIGGER @name before insert on tb3 for each row set new.f120 = 't';
|
||||
|
||||
--error 1435
|
||||
CREATE TRIGGER tb3.trg6_1 BEFORE INSERT on test.tb3
|
||||
--error ER_TRG_IN_WRONG_SCHEMA
|
||||
CREATE TRIGGER tb3.trg6_1 BEFORE INSERT on test.tb3
|
||||
for each row set new.f120 ='X';
|
||||
|
||||
--disable_warnings
|
||||
@ -265,29 +265,29 @@ let $message= Testcase 3.5.1.8:;
|
||||
|
||||
# Can't create a trigger in a different database
|
||||
use test;
|
||||
--error 1146
|
||||
CREATE TRIGGER trig_db.trg6_2 AFTER INSERT on tb3
|
||||
--error ER_NO_SUCH_TABLE
|
||||
CREATE TRIGGER trig_db.trg6_2 AFTER INSERT on tb3
|
||||
for each row set @ret_trg6_2 = 5;
|
||||
|
||||
# Can't create a trigger refrencing a table in a different db
|
||||
use trig_db;
|
||||
--error 1435
|
||||
CREATE TRIGGER trg6_3 AFTER INSERT on test.tb3
|
||||
--error ER_TRG_IN_WRONG_SCHEMA
|
||||
CREATE TRIGGER trg6_3 AFTER INSERT on test.tb3
|
||||
for each row set @ret_trg6_3 = 18;
|
||||
|
||||
use test;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop database trig_db;
|
||||
# OBN - Although none of the above should have been created we should do a cleanup
|
||||
# since if they have been created, not dropping them will affect following
|
||||
# tests.
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg6_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg6_3;
|
||||
--enable_warnings
|
||||
--enable_warnings
|
||||
|
||||
#Section 3.5.1.9
|
||||
#Testcase: Ensure that a reference to a non-existent trigger is rejected with
|
||||
@ -297,41 +297,41 @@ let $message= Testcase 3.5.1.9:(cannot be inplemented at this point);
|
||||
|
||||
|
||||
#Section 3.5.1.10
|
||||
#Testcase: Ensure that it is not possible to create two triggers with the same name on
|
||||
#Testcase: Ensure that it is not possible to create two triggers with the same name on
|
||||
# the same table
|
||||
let $message= Testcase 3.5.1.10:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
CREATE TRIGGER trg7_1 BEFORE UPDATE on tb3 for each row set new.f120 ='X';
|
||||
|
||||
--error 1359
|
||||
--error ER_TRG_ALREADY_EXISTS
|
||||
CREATE TRIGGER trg7_1 AFTER INSERT on tb3 for each row set @x ='Y';
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
--disable_warnings
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg7_1;
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.1.?
|
||||
# Testcase: Ensure that it is not possible to create two or more triggers with
|
||||
#Section 3.5.1.?
|
||||
# Testcase: Ensure that it is not possible to create two or more triggers with
|
||||
# the same name, provided each is associated with a different table.
|
||||
let $message= Testcase 3.5.1.?:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop table if exists t1;
|
||||
drop table if exists t2;
|
||||
--enable_warnings
|
||||
eval create table t1 (f1 char(50), f2 integer) engine = $engine_type;
|
||||
eval create table t2 (f1 char(50), f2 integer) engine = $engine_type;
|
||||
|
||||
create trigger trig before insert on t1
|
||||
create trigger trig before insert on t1
|
||||
for each row set new.f1 ='trig t1';
|
||||
|
||||
--error 1359
|
||||
create trigger trig before update on t2
|
||||
--error ER_TRG_ALREADY_EXISTS
|
||||
create trigger trig before update on t2
|
||||
for each row set new.f1 ='trig t2';
|
||||
|
||||
insert into t1 value ('insert to t1',1);
|
||||
@ -343,16 +343,16 @@ let $message= Testcase 3.5.1.?:;
|
||||
select * from t2;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop table t1;
|
||||
drop table t2;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trig;
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.1.11
|
||||
# Testcase: Ensure that it is possible to create two or more triggers with
|
||||
#Section 3.5.1.11
|
||||
# Testcase: Ensure that it is possible to create two or more triggers with
|
||||
# the same name, provided each resides in a different database
|
||||
let $message= Testcase 3.5.1.11:;
|
||||
--source include/show_msg.inc
|
||||
@ -367,15 +367,15 @@ let $message= Testcase 3.5.1.11:;
|
||||
create database trig_db3;
|
||||
use trig_db1;
|
||||
eval create table t1 (f1 char(50), f2 integer) engine = $engine_type;
|
||||
create trigger trig before insert on t1
|
||||
create trigger trig before insert on t1
|
||||
for each row set new.f1 ='trig1', @test_var1='trig1';
|
||||
use trig_db2;
|
||||
eval create table t2 (f1 char(50), f2 integer) engine = $engine_type;
|
||||
create trigger trig before insert on t2
|
||||
create trigger trig before insert on t2
|
||||
for each row set new.f1 ='trig2', @test_var2='trig2';
|
||||
use trig_db3;
|
||||
eval create table t1 (f1 char(50), f2 integer) engine = $engine_type;
|
||||
create trigger trig before insert on t1
|
||||
create trigger trig before insert on t1
|
||||
for each row set new.f1 ='trig3', @test_var3='trig3';
|
||||
|
||||
set @test_var1= '', @test_var2= '', @test_var3= '';
|
||||
@ -385,14 +385,14 @@ let $message= Testcase 3.5.1.11:;
|
||||
insert into trig_db2.t2 (f1,f2) values ('insert to db2 t2 from db1',3);
|
||||
insert into trig_db3.t1 (f1,f2) values ('insert to db3 t1 from db1',4);
|
||||
select @test_var1, @test_var2, @test_var3;
|
||||
select * from t1;
|
||||
select * from t1 order by f2;
|
||||
select * from trig_db2.t2;
|
||||
select * from trig_db3.t1;
|
||||
select * from t1;
|
||||
select * from t1 order by f2;
|
||||
use test;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop database trig_db1;
|
||||
drop database trig_db2;
|
||||
drop database trig_db3;
|
||||
@ -403,16 +403,16 @@ let $message= Testcase 3.5.1.11:;
|
||||
# Check for the global nature of Triggers #
|
||||
###########################################
|
||||
|
||||
#Section 3.5.2.1
|
||||
# Test case: Ensure that if a trigger created without a qualifying database
|
||||
#Section 3.5.2.1
|
||||
# Test case: Ensure that if a trigger created without a qualifying database
|
||||
# name belongs to the database in use at creation time.
|
||||
#Section 3.5.2.2
|
||||
# Test case: Ensure that if a trigger created with a qualifying database name
|
||||
#Section 3.5.2.2
|
||||
# Test case: Ensure that if a trigger created with a qualifying database name
|
||||
# belongs to the database specified.
|
||||
#Section 3.5.2.3
|
||||
# Test case: Ensure that if a trigger created with a qualifying database name
|
||||
# does not belong to the database in use at creation time unless
|
||||
# the qualifying database name identifies the database that is
|
||||
#Section 3.5.2.3
|
||||
# Test case: Ensure that if a trigger created with a qualifying database name
|
||||
# does not belong to the database in use at creation time unless
|
||||
# the qualifying database name identifies the database that is
|
||||
# also in use at creation time.
|
||||
let $message= Testcase 3.5.2.1/2/3:;
|
||||
--source include/show_msg.inc
|
||||
@ -427,14 +427,14 @@ let $message= Testcase 3.5.2.1/2/3:;
|
||||
use trig_db1;
|
||||
eval create table t1 (f1 char(50), f2 integer) engine = $engine_type;
|
||||
eval create table trig_db2.t1 (f1 char(50), f2 integer) engine = $engine_type;
|
||||
create trigger trig1_b before insert on t1
|
||||
create trigger trig1_b before insert on t1
|
||||
for each row set @test_var1='trig1_b';
|
||||
create trigger trig_db1.trig1_a after insert on t1
|
||||
create trigger trig_db1.trig1_a after insert on t1
|
||||
for each row set @test_var2='trig1_a';
|
||||
create trigger trig_db2.trig2 before insert on trig_db2.t1
|
||||
create trigger trig_db2.trig2 before insert on trig_db2.t1
|
||||
for each row set @test_var3='trig2';
|
||||
select trigger_schema, trigger_name, event_object_table
|
||||
from information_schema.triggers;
|
||||
from information_schema.triggers order by trigger_name;
|
||||
|
||||
set @test_var1= '', @test_var2= '', @test_var3= '';
|
||||
insert into t1 (f1,f2) values ('insert to db1 t1 from db1',352);
|
||||
@ -442,6 +442,6 @@ let $message= Testcase 3.5.2.1/2/3:;
|
||||
select @test_var1, @test_var2, @test_var3;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop database trig_db1;
|
||||
drop database trig_db2;
|
||||
|
@ -63,14 +63,14 @@ let $message= Testcase 3.5.3.2:;
|
||||
select current_user;
|
||||
use priv_db;
|
||||
|
||||
--error 1227
|
||||
--error ER_SPECIFIC_ACCESS_DENIED_ERROR
|
||||
create trigger trg1_1 before INSERT on t1 for each row
|
||||
set new.f1 = 'trig 3.5.3.2_1-no';
|
||||
|
||||
connection default;
|
||||
use priv_db;
|
||||
insert into t1 (f1) values ('insert 3.5.3.2-no');
|
||||
select f1 from t1;
|
||||
select f1 from t1 order by f1;
|
||||
|
||||
connection yes_privs;
|
||||
select current_user;
|
||||
@ -83,29 +83,27 @@ let $message= Testcase 3.5.3.2:;
|
||||
select current_user;
|
||||
use priv_db;
|
||||
|
||||
# Added following the fix to bug 5861
|
||||
--error 1143
|
||||
--error ER_COLUMNACCESS_DENIED_ERROR
|
||||
insert into t1 (f1) values ('insert 3.5.3.2-yes');
|
||||
select f1 from t1;
|
||||
grant UPDATE on priv_db.t1 to test_yesprivs@localhost;
|
||||
let $message= note: once 15166 is fixed a similar case for SELECT needs to be added;
|
||||
--source include/show_msg.inc
|
||||
select f1 from t1 order by f1;
|
||||
|
||||
grant UPDATE on priv_db.t1 to test_yesprivs@localhost;
|
||||
insert into t1 (f1) values ('insert 3.5.3.2-yes');
|
||||
select f1 from t1 order by f1;
|
||||
|
||||
insert into t1 (f1) values ('insert 3.5.3.2-yes');
|
||||
select f1 from t1;
|
||||
let $message= Testcase 3.5.3.6:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
connection no_privs;
|
||||
use priv_db;
|
||||
|
||||
--error 1227
|
||||
--error ER_SPECIFIC_ACCESS_DENIED_ERROR
|
||||
drop trigger trg1_2;
|
||||
|
||||
connection default;
|
||||
use priv_db;
|
||||
insert into t1 (f1) values ('insert 3.5.3.6-yes');
|
||||
select f1 from t1;
|
||||
select f1 from t1 order by f1;
|
||||
|
||||
connection yes_privs;
|
||||
use priv_db;
|
||||
@ -115,12 +113,12 @@ let $message= Testcase 3.5.3.6:;
|
||||
connection default;
|
||||
use priv_db;
|
||||
insert into t1 (f1) values ('insert 3.5.3.6-no');
|
||||
select f1 from t1;
|
||||
select f1 from t1 order by f1;
|
||||
|
||||
# Cleanup
|
||||
--disable_warnings
|
||||
connection default;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg1_2;
|
||||
disconnect no_privs;
|
||||
disconnect yes_privs;
|
||||
@ -131,8 +129,6 @@ let $message= Testcase 3.5.3.6:;
|
||||
# Test case: Ensure that use of the construct "SET NEW. <column name> = <value>"
|
||||
# fails at CREATE TRIGGER time, if the current user does not have the
|
||||
# UPDATE privilege on the column specified
|
||||
# Note: As a result of bug 8884 the triggers are actually created.
|
||||
# Disabled because of bug 8884
|
||||
|
||||
# --- 3.5.3.7a - Privs set on a global level
|
||||
let $message=Testcase 3.5.3.7a:;
|
||||
@ -156,18 +152,15 @@ let $message=Testcase 3.5.3.7a:;
|
||||
select current_user;
|
||||
use priv_db;
|
||||
show grants;
|
||||
select f1 from t1;
|
||||
select f1 from t1 order by f1;
|
||||
|
||||
let $message= Trigger create disabled - should fail - Bug 8884;
|
||||
--source include/show_msg.inc
|
||||
# --error 1227
|
||||
# create trigger trg4a_1 before INSERT on t1 for each row
|
||||
# set new.f1 = 'trig 3.5.3.7-1a';
|
||||
create trigger trg4a_1 before INSERT on t1 for each row
|
||||
set new.f1 = 'trig 3.5.3.7-1a';
|
||||
|
||||
connection default;
|
||||
--error ER_COLUMNACCESS_DENIED_ERROR
|
||||
insert into t1 (f1) values ('insert 3.5.3.7-1a');
|
||||
select f1 from t1;
|
||||
--error 0, 1360
|
||||
select f1 from t1 order by f1;
|
||||
drop trigger trg4a_1;
|
||||
|
||||
connection yes_privs_424a;
|
||||
@ -179,14 +172,8 @@ let $message= Trigger create disabled - should fail - Bug 8884;
|
||||
|
||||
connection default;
|
||||
|
||||
|
||||
# Added to bypass bug 15166
|
||||
let $message= SELECT priv added to bypass bug 15166;
|
||||
--source include/show_msg.inc
|
||||
grant SELECT on *.* to test_yesprivs@localhost;
|
||||
|
||||
insert into t1 (f1) values ('insert 3.5.3.7-2b');
|
||||
select f1 from t1;
|
||||
select f1 from t1 order by f1;
|
||||
|
||||
# Cleanup
|
||||
--disable_warnings
|
||||
@ -220,18 +207,14 @@ let $message= Testcase 3.5.3.7b:;
|
||||
show grants;
|
||||
use priv_db;
|
||||
|
||||
let $message= Trigger create disabled - should fail - Bug 8884;
|
||||
--source include/show_msg.inc
|
||||
# --error 1227
|
||||
# create trigger trg4b_1 before UPDATE on t1 for each row
|
||||
# set new.f1 = 'trig 3.5.3.7-1b';
|
||||
create trigger trg4b_1 before UPDATE on t1 for each row
|
||||
set new.f1 = 'trig 3.5.3.7-1b';
|
||||
|
||||
connection default;
|
||||
insert into t1 (f1) values ('insert 3.5.3.7-1b');
|
||||
select f1 from t1;
|
||||
select f1 from t1 order by f1;
|
||||
update t1 set f1 = 'update 3.5.3.7-1b' where f1 = 'insert 3.5.3.7-1b';
|
||||
select f1 from t1;
|
||||
--error 0, 1360
|
||||
select f1 from t1 order by f1;
|
||||
drop trigger trg4b_1;
|
||||
|
||||
connection yes_privs_424b;
|
||||
@ -242,15 +225,10 @@ let $message= Trigger create disabled - should fail - Bug 8884;
|
||||
|
||||
connection default;
|
||||
|
||||
# Added to bypass bug 15166
|
||||
let $message= SELECT priv added to bypass bug 15166;
|
||||
--source include/show_msg.inc
|
||||
grant SELECT on priv_db.* to test_yesprivs@localhost;
|
||||
|
||||
insert into t1 (f1) values ('insert 3.5.3.7-2b');
|
||||
select f1 from t1;
|
||||
select f1 from t1 order by f1;
|
||||
update t1 set f1 = 'update 3.5.3.7-2b' where f1 = 'insert 3.5.3.7-2b';
|
||||
select f1 from t1;
|
||||
select f1 from t1 order by f1;
|
||||
# Cleanup
|
||||
--disable_warnings
|
||||
drop trigger trg4b_2;
|
||||
@ -283,16 +261,12 @@ let $message= Testcase 3.5.3.7c;
|
||||
show grants;
|
||||
use priv_db;
|
||||
|
||||
let $message= Trigger create disabled - should fail - Bug 8884;
|
||||
--source include/show_msg.inc
|
||||
# --error 1227
|
||||
# create trigger trg4c_1 before INSERT on t1 for each row
|
||||
# set new.f1 = 'trig 3.5.3.7-1c';
|
||||
create trigger trg4c_1 before INSERT on t1 for each row
|
||||
set new.f1 = 'trig 3.5.3.7-1c';
|
||||
|
||||
connection default;
|
||||
insert into t1 (f1) values ('insert 3.5.3.7-1c');
|
||||
select f1 from t1;
|
||||
--error 0, 1360
|
||||
select f1 from t1 order by f1;
|
||||
drop trigger trg4c_1;
|
||||
|
||||
connection yes_privs_424c;
|
||||
@ -303,13 +277,8 @@ let $message= Trigger create disabled - should fail - Bug 8884;
|
||||
|
||||
connection default;
|
||||
|
||||
# Added to bypass bug 15166
|
||||
let $message= SELECT priv added to bypass bug 15166;
|
||||
--source include/show_msg.inc
|
||||
grant SELECT on priv_db.t1 to test_yesprivs@localhost;
|
||||
|
||||
insert into t1 (f1) values ('insert 3.5.3.7-2c');
|
||||
select f1 from t1;
|
||||
select f1 from t1 order by f1;
|
||||
|
||||
# Cleanup
|
||||
--disable_warnings
|
||||
@ -344,16 +313,12 @@ let $message= Testcase 3.5.3.7d:;
|
||||
connection no_privs_424d;
|
||||
show grants;
|
||||
use priv_db;
|
||||
let $message= Trigger create disabled - should fail - Bug 8884;
|
||||
--source include/show_msg.inc
|
||||
# --error 1227
|
||||
# create trigger trg4d_1 before INSERT on t1 for each row
|
||||
# set new.f1 = 'trig 3.5.3.7-1d';
|
||||
create trigger trg4d_1 before INSERT on t1 for each row
|
||||
set new.f1 = 'trig 3.5.3.7-1d';
|
||||
|
||||
connection default;
|
||||
insert into t1 (f1) values ('insert 3.5.3.7-1d');
|
||||
select f1 from t1;
|
||||
--error 0, 1360
|
||||
select f1 from t1 order by f1;
|
||||
drop trigger trg4d_1;
|
||||
|
||||
connection yes_privs_424d;
|
||||
@ -364,13 +329,8 @@ let $message= Trigger create disabled - should fail - Bug 8884;
|
||||
|
||||
connection default;
|
||||
|
||||
# Added to bypass bug 15166
|
||||
let $message= SELECT priv added to bypass bug 15166;
|
||||
--source include/show_msg.inc
|
||||
grant SELECT (f1) on priv_db.t1 to test_yesprivs@localhost;
|
||||
|
||||
insert into t1 (f1) values ('insert 3.5.3.7-2d');
|
||||
select f1 from t1;
|
||||
select f1 from t1 order by f1;
|
||||
|
||||
# Cleanup
|
||||
--disable_warnings
|
||||
@ -408,18 +368,14 @@ let $message= Testcase 3.5.3.8a:;
|
||||
use priv_db;
|
||||
show grants;
|
||||
|
||||
let $message= Trigger create disabled - should fail - Bug 8887;
|
||||
--source include/show_msg.inc
|
||||
# --error 1227
|
||||
# create trigger trg5a_1 before INSERT on t1 for each row
|
||||
# set @test_var = new.f1;
|
||||
create trigger trg5a_1 before INSERT on t1 for each row
|
||||
set @test_var = new.f1;
|
||||
|
||||
connection default;
|
||||
set @test_var = 'before trig 3.5.3.8-1a';
|
||||
select @test_var;
|
||||
insert into t1 (f1) values ('insert 3.5.3.8-1a');
|
||||
select @test_var;
|
||||
--error 0, 1360
|
||||
drop trigger trg5a_1;
|
||||
|
||||
connection yes_privs_425a;
|
||||
@ -433,11 +389,6 @@ let $message= Trigger create disabled - should fail - Bug 8887;
|
||||
set @test_var= 'before trig 3.5.3.8-2a';
|
||||
select @test_var;
|
||||
|
||||
# Added to bypass bug 15166
|
||||
let $message= UPDATE priv added to bypass bug 15166;
|
||||
--source include/show_msg.inc
|
||||
grant UPDATE on *.* to test_yesprivs@localhost;
|
||||
|
||||
insert into t1 (f1) values ('insert 3.5.3.8-2a');
|
||||
select @test_var;
|
||||
|
||||
@ -473,11 +424,8 @@ let $message= Testcase: 3.5.3.8b;
|
||||
show grants;
|
||||
use priv_db;
|
||||
|
||||
let $message= Trigger create disabled - should fail - Bug 8887;
|
||||
--source include/show_msg.inc
|
||||
# --error 1227
|
||||
# create trigger trg5b_1 before UPDATE on t1 for each row
|
||||
# set @test_var= new.f1;
|
||||
create trigger trg5b_1 before UPDATE on t1 for each row
|
||||
set @test_var= new.f1;
|
||||
|
||||
connection default;
|
||||
set @test_var= 'before trig 3.5.3.8-1b';
|
||||
@ -485,7 +433,6 @@ let $message= Trigger create disabled - should fail - Bug 8887;
|
||||
select @test_var;
|
||||
update t1 set f1= 'update 3.5.3.8-1b' where f1 = 'insert 3.5.3.8-1b';
|
||||
select @test_var;
|
||||
--error 0, 1360
|
||||
drop trigger trg5b_1;
|
||||
|
||||
connection yes_privs_425b;
|
||||
@ -499,11 +446,6 @@ let $message= Trigger create disabled - should fail - Bug 8887;
|
||||
insert into t1 (f1) values ('insert 3.5.3.8-2b');
|
||||
select @test_var;
|
||||
|
||||
# Added to bypass bug 15166
|
||||
let $message= UPDATE priv added to bypass bug 15166;
|
||||
--source include/show_msg.inc
|
||||
grant UPDATE on priv_db.* to test_yesprivs@localhost;
|
||||
|
||||
update t1 set f1= 'update 3.5.3.8-2b' where f1 = 'insert 3.5.3.8-2b';
|
||||
select @test_var;
|
||||
# Cleanup
|
||||
@ -538,17 +480,13 @@ let $message= Testcase 3.5.3.8c:;
|
||||
show grants;
|
||||
use priv_db;
|
||||
|
||||
let $message= Trigger create disabled - should fail - Bug 8887;
|
||||
--source include/show_msg.inc
|
||||
# --error 1227
|
||||
# create trigger trg5c_1 before INSERT on t1 for each row
|
||||
# set @test_var= new.f1;
|
||||
create trigger trg5c_1 before INSERT on t1 for each row
|
||||
set @test_var= new.f1;
|
||||
|
||||
connection default;
|
||||
set @test_var= 'before trig 3.5.3.8-1c';
|
||||
insert into t1 (f1) values ('insert 3.5.3.8-1c');
|
||||
select @test_var;
|
||||
--error 0, 1360
|
||||
drop trigger trg5c_1;
|
||||
|
||||
connection yes_privs_425c;
|
||||
@ -560,11 +498,6 @@ let $message= Trigger create disabled - should fail - Bug 8887;
|
||||
connection default;
|
||||
set @test_var='before trig 3.5.3.8-2c';
|
||||
|
||||
# Added to bypass bug 15166
|
||||
let $message= UPDATE priv added to bypass bug 15166;
|
||||
--source include/show_msg.inc
|
||||
grant UPDATE on priv_db.t1 to test_yesprivs@localhost;
|
||||
|
||||
insert into t1 (f1) values ('insert 3.5.3.8-2c');
|
||||
select @test_var;
|
||||
# Cleanup
|
||||
@ -598,17 +531,13 @@ let $message=Testcase: 3.5.3.8d:;
|
||||
connection no_privs_425d;
|
||||
show grants;
|
||||
use priv_db;
|
||||
let $message= Trigger create disabled - should fail - Bug 8887;
|
||||
--source include/show_msg.inc
|
||||
# --error 1227
|
||||
# create trigger trg5d_1 before INSERT on t1 for each row
|
||||
# set @test_var= new.f1;
|
||||
create trigger trg5d_1 before INSERT on t1 for each row
|
||||
set @test_var= new.f1;
|
||||
|
||||
connection default;
|
||||
set @test_var='before trig 3.5.3.8-1d';
|
||||
insert into t1 (f1) values ('insert 3.5.3.8-1d');
|
||||
select @test_var;
|
||||
--error 0, 1360
|
||||
drop trigger trg5d_1;
|
||||
|
||||
connection yes_privs_425d;
|
||||
@ -620,11 +549,6 @@ let $message= Trigger create disabled - should fail - Bug 8887;
|
||||
connection default;
|
||||
set @test_var='before trig 3.5.3.8-2d';
|
||||
|
||||
# Added to bypass bug 15166
|
||||
let $message= UPDATE priv added to bypass bug 15166;
|
||||
--source include/show_msg.inc
|
||||
grant UPDATE (f1) on priv_db.t1 to test_yesprivs@localhost;
|
||||
|
||||
insert into t1 (f1) values ('insert 3.5.3.8-2d');
|
||||
select @test_var;
|
||||
|
||||
@ -633,8 +557,7 @@ let $message= UPDATE priv added to bypass bug 15166;
|
||||
drop trigger trg5d_2;
|
||||
--enable_warnings
|
||||
|
||||
# --- 3.5.3.x - additional tests following the fix to bug 5861 / WL 2818
|
||||
# to test for trigger definer privs in the case of trigger
|
||||
# --- 3.5.3.x to test for trigger definer privs in the case of trigger
|
||||
# actions (insert/update/delete/select) performed on other
|
||||
# tables.
|
||||
let $message=Testcase: 3.5.3.x:;
|
||||
@ -671,8 +594,8 @@ let $message=Testcase: 3.5.3.x:;
|
||||
revoke SELECT on priv_db.t2 from test_yesprivs@localhost;
|
||||
grant INSERT on priv_db.t2 to test_yesprivs@localhost;
|
||||
insert into t1 (f1) values (4);
|
||||
select f1 from t1;
|
||||
select f2 from t2;
|
||||
select f1 from t1 order by f1;
|
||||
select f2 from t2 order by f2;
|
||||
|
||||
connection yes_353x;
|
||||
use priv_db;
|
||||
@ -687,8 +610,8 @@ let $message=Testcase: 3.5.3.x:;
|
||||
revoke INSERT on priv_db.t2 from test_yesprivs@localhost;
|
||||
grant UPDATE on priv_db.t2 to test_yesprivs@localhost;
|
||||
insert into t1 (f1) values (2);
|
||||
select f1 from t1;
|
||||
select f2 from t2;
|
||||
select f1 from t1 order by f1;
|
||||
select f2 from t2 order by f2;
|
||||
|
||||
connection yes_353x;
|
||||
use priv_db;
|
||||
@ -703,8 +626,8 @@ let $message=Testcase: 3.5.3.x:;
|
||||
revoke UPDATE on priv_db.t2 from test_yesprivs@localhost;
|
||||
grant SELECT on priv_db.t2 to test_yesprivs@localhost;
|
||||
insert into t1 (f1) values (1);
|
||||
select f1 from t1;
|
||||
select f2 from t2;
|
||||
select f1 from t1 order by f1;
|
||||
select f2 from t2 order by f2;
|
||||
select @aaa;
|
||||
|
||||
connection yes_353x;
|
||||
@ -720,8 +643,8 @@ let $message=Testcase: 3.5.3.x:;
|
||||
revoke SELECT on priv_db.t2 from test_yesprivs@localhost;
|
||||
grant DELETE on priv_db.t2 to test_yesprivs@localhost;
|
||||
insert into t1 (f1) values (1);
|
||||
select f1 from t1;
|
||||
select f2 from t2;
|
||||
select f1 from t1 order by f1;
|
||||
select f2 from t2 order by f2;
|
||||
|
||||
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#======================================================================
|
||||
#
|
||||
# Trigger Tests
|
||||
# (test case numbering refer to requirement document TP v1.1)
|
||||
# Trigger Tests
|
||||
# (test case numbering refer to requirement document TP v1.1)
|
||||
#======================================================================
|
||||
|
||||
--disable_abort_on_error
|
||||
@ -46,32 +46,32 @@ let $message= Testcase 3.5.4.1:;
|
||||
eval create table t1 (f1 char(30)) engine=$engine_type;
|
||||
grant INSERT, SELECT on db_drop.t1 to test_general;
|
||||
Use db_drop;
|
||||
Create trigger trg1 BEFORE INSERT on t1
|
||||
Create trigger trg1 BEFORE INSERT on t1
|
||||
for each row set new.f1='Trigger 3.5.4.1';
|
||||
connection con1_general;
|
||||
Use db_drop;
|
||||
Insert into t1 values ('Insert error 3.5.4.1');
|
||||
Select * from t1;
|
||||
Select * from t1 order by f1;
|
||||
connection con1_super;
|
||||
drop trigger trg1;
|
||||
select trigger_schema, trigger_name, event_object_table
|
||||
from information_schema.triggers;
|
||||
from information_schema.triggers order by trigger_name;
|
||||
connection con1_general;
|
||||
Insert into t1 values ('Insert no trigger 3.5.4.1');
|
||||
Select * from t1;
|
||||
Select * from t1 order by f1;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
connection con1_super;
|
||||
--disable_warnings
|
||||
--error 0,1360
|
||||
drop trigger trg1;
|
||||
--error 0,ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg1;
|
||||
drop database if exists db_drop;
|
||||
revoke ALL PRIVILEGES, GRANT OPTION FROM 'test_general'@'localhost';
|
||||
--enable_warnings
|
||||
|
||||
#Section 3.5.4.2
|
||||
# Test case: Ensure that DROP TRIGGER <trigger name> fails, with an appropriate error
|
||||
# Test case: Ensure that DROP TRIGGER <trigger name> fails, with an appropriate error
|
||||
# message, if the trigger name does not exist.
|
||||
let $message= Testcase 3.5.4.2:;
|
||||
--source include/show_msg.inc
|
||||
@ -83,16 +83,16 @@ let $message= Testcase 3.5.4.2:;
|
||||
drop table if exists t1_432 ;
|
||||
--enable_warnings
|
||||
eval create table t1_432 (f1 char (30)) engine=$engine_type;
|
||||
--error 1360
|
||||
--error ER_TRG_DOES_NOT_EXIST
|
||||
Drop trigger tr_does_not_exit;
|
||||
#cleanup
|
||||
#cleanup
|
||||
--disable_warnings
|
||||
drop table if exists t1_432 ;
|
||||
drop database if exists db_drop2;
|
||||
--enable_warnings
|
||||
|
||||
#Section 3.5.4.3
|
||||
# Test case: Ensure that DROP TRIGGER <trigger name> fails, with an appropriate
|
||||
# Test case: Ensure that DROP TRIGGER <trigger name> fails, with an appropriate
|
||||
# error message, if <trigger name> is not a qualified name.
|
||||
let $message= Testcase 3.5.4.3:;
|
||||
--source include/show_msg.inc
|
||||
@ -107,33 +107,33 @@ let $message= Testcase 3.5.4.3:;
|
||||
eval create table t1_433 (f1 char (30)) engine=$engine_type;
|
||||
eval create table t1_433a (f1a char (5)) engine=$engine_type;
|
||||
|
||||
CREATE TRIGGER trg3 BEFORE INSERT on t1_433 for each row
|
||||
CREATE TRIGGER trg3 BEFORE INSERT on t1_433 for each row
|
||||
set new.f1 = 'Trigger 3.5.4.3';
|
||||
|
||||
# Using table
|
||||
--error 1064
|
||||
# Using table
|
||||
--error ER_PARSE_ERROR
|
||||
Drop trigger t1.433.trg3;
|
||||
|
||||
# Using database.table
|
||||
--error 1064
|
||||
# Using database.table
|
||||
--error ER_PARSE_ERROR
|
||||
Drop trigger db_drop3.t1.433.trg3;
|
||||
|
||||
# wrong database
|
||||
--error 1360
|
||||
--error ER_TRG_DOES_NOT_EXIST
|
||||
Drop trigger mysql.trg3;
|
||||
|
||||
# database does not exist
|
||||
--error 1360
|
||||
--error ER_TRG_DOES_NOT_EXIST
|
||||
Drop trigger tbx.trg3;
|
||||
|
||||
#cleanup
|
||||
#cleanup
|
||||
Drop trigger db_drop3.trg3;
|
||||
drop table if exists t1_433;
|
||||
drop table if exists t1_433a;
|
||||
drop database if exists db_drop3;
|
||||
|
||||
#Section 3.5.4.4
|
||||
# Test case: Ensure that when a database is dropped, all triggers created within
|
||||
# Test case: Ensure that when a database is dropped, all triggers created within
|
||||
# that database are also cleanly dropped.
|
||||
let $message= Testcase 3.5.4.4:;
|
||||
--source include/show_msg.inc
|
||||
@ -143,7 +143,7 @@ let $message= Testcase 3.5.4.4:;
|
||||
Use db_drop4;
|
||||
eval create table t1 (f1 char(30)) engine=$engine_type;
|
||||
grant INSERT, SELECT on db_drop4.t1 to test_general;
|
||||
Create trigger trg4 BEFORE INSERT on t1
|
||||
Create trigger trg4 BEFORE INSERT on t1
|
||||
for each row set new.f1='Trigger 3.5.4.4';
|
||||
connection con1_general;
|
||||
Use db_drop4;
|
||||
@ -166,14 +166,14 @@ let $message= Testcase 3.5.4.4:;
|
||||
#Cleanup
|
||||
connection con1_super;
|
||||
--disable_warnings
|
||||
--error 1360
|
||||
drop trigger trg4;
|
||||
--error ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4;
|
||||
drop database if exists db_drop4;
|
||||
--enable_warnings
|
||||
revoke ALL PRIVILEGES, GRANT OPTION FROM 'test_general'@'localhost';
|
||||
|
||||
#Section 3.5.4.5
|
||||
# Test case: Ensure that when a table is dropped, all triggers for which it is the
|
||||
# Test case: Ensure that when a table is dropped, all triggers for which it is the
|
||||
# subject table are also cleanly dropped.
|
||||
let $message= Testcase 3.5.4.5:;
|
||||
--source include/show_msg.inc
|
||||
@ -183,7 +183,7 @@ let $message= Testcase 3.5.4.5:;
|
||||
Use db_drop5;
|
||||
eval create table t1 (f1 char(50)) engine=$engine_type;
|
||||
grant INSERT, SELECT on t1 to test_general;
|
||||
Create trigger trg5 BEFORE INSERT on t1
|
||||
Create trigger trg5 BEFORE INSERT on t1
|
||||
for each row set new.f1='Trigger 3.5.4.5';
|
||||
connection con1_general;
|
||||
Use db_drop5;
|
||||
@ -204,8 +204,8 @@ let $message= Testcase 3.5.4.5:;
|
||||
#Cleanup
|
||||
connection con1_super;
|
||||
--disable_warnings
|
||||
--error 1360
|
||||
drop trigger trg5;
|
||||
--error ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg5;
|
||||
drop database if exists db_drop5;
|
||||
--enable_warnings
|
||||
revoke ALL PRIVILEGES, GRANT OPTION FROM 'test_general'@'localhost';
|
||||
@ -223,55 +223,55 @@ let $message= Testcase 3.5.5:;
|
||||
use test;
|
||||
|
||||
#Section 3.5.5.1
|
||||
# Test case: Ensure that, if CREATE TRIGGER is executed with a non-existent
|
||||
# Test case: Ensure that, if CREATE TRIGGER is executed with a non-existent
|
||||
# subject table, the statement fails with an appropriate error message.
|
||||
let $message= Testcase 3.5.5.1:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
--error 1146
|
||||
--error ER_NO_SUCH_TABLE
|
||||
Create trigger trg1 before INSERT on t100 for each row set new.f2=1000;
|
||||
|
||||
|
||||
#Section 3.5.5.2
|
||||
# Test case: Ensure that, if CREATE TRIGGER is executed with a temporary table
|
||||
# Test case: Ensure that, if CREATE TRIGGER is executed with a temporary table
|
||||
# as the subject table, the statement fails with an appropriate error message.
|
||||
let $message= Testcase 3.5.5.2:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
Create temporary table t1_temp (f1 bigint signed, f2 bigint unsigned);
|
||||
|
||||
--error 1361
|
||||
Create trigger trg2 before INSERT
|
||||
--error ER_TRG_ON_VIEW_OR_TEMP_TABLE
|
||||
Create trigger trg2 before INSERT
|
||||
on t1_temp for each row set new.f2=9999;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop table t1_temp;
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.5.3
|
||||
# Test case: Ensure that, if CREATE TRIGGER is executed with a view as the subject
|
||||
# Test case: Ensure that, if CREATE TRIGGER is executed with a view as the subject
|
||||
# table, the statement fails with an appropriate error message.
|
||||
let $message= Testcase 3.5.5.3:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
Create view vw3 as select f118 from tb3;
|
||||
|
||||
# OBN Not sure why the server is returning error 1347
|
||||
--error 1347
|
||||
Create trigger trg3 before INSERT
|
||||
# OBN Not sure why the server is returning error ER_WRONG_OBJECT
|
||||
--error ER_WRONG_OBJECT
|
||||
Create trigger trg3 before INSERT
|
||||
on vw3 for each row set new.f118='s';
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop view vw3;
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.5.4
|
||||
# Test case: Ensure that, if CREATE TRIGGER is executed with a table that resides
|
||||
# in a different database than in which the trigger will reside, the
|
||||
# Test case: Ensure that, if CREATE TRIGGER is executed with a table that resides
|
||||
# in a different database than in which the trigger will reside, the
|
||||
# statement fails with an appropriate error message; that is, ensure that
|
||||
# the trigger and its subject table must reside in the same database.
|
||||
let $message= Testcase 3.5.5.4:;
|
||||
@ -283,7 +283,7 @@ let $message= Testcase 3.5.5.4:;
|
||||
use dbtest_two;
|
||||
eval create table t2 (f1 char(15)) engine=$engine_type;
|
||||
use dbtest_one;
|
||||
--error 1435
|
||||
--error ER_TRG_IN_WRONG_SCHEMA
|
||||
create trigger trg4 before INSERT
|
||||
on dbtest_two.t2 for each row set new.f1='trig 3.5.5.4';
|
||||
grant INSERT, SELECT on dbtest_two.t2 to test_general;
|
||||
@ -294,11 +294,11 @@ let $message= Testcase 3.5.5.4:;
|
||||
Select * from t2;
|
||||
use dbtest_one;
|
||||
Insert into dbtest_two.t2 values ('2nd Insert 3.5.5.4');
|
||||
Select * from dbtest_two.t2;
|
||||
Select * from dbtest_two.t2 order by f1;
|
||||
|
||||
#Cleanup
|
||||
connection con1_super;
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
revoke ALL PRIVILEGES, GRANT OPTION FROM 'test_general'@'localhost';
|
||||
DROP DATABASE if exists dbtest_one;
|
||||
drop database if EXISTS dbtest_two;
|
||||
@ -316,7 +316,7 @@ let $message= Testcase 3.5.6:;
|
||||
use test;
|
||||
|
||||
#Section 3.5.6.1
|
||||
# Test case: Ensure that a trigger definition can specify a trigger action time of BEFORE.
|
||||
# Test case: Ensure that a trigger definition can specify a trigger action time of BEFORE.
|
||||
# See section 3.5.1.1
|
||||
let $message= Testcase 3.5.6.1 (see Testcase 3.5.1.1);
|
||||
--source include/show_msg.inc
|
||||
@ -328,37 +328,37 @@ let $message= Testcase 3.5.6.2 (see Testcase 3.5.1.1);
|
||||
--source include/show_msg.inc
|
||||
|
||||
#Section 3.5.6.3
|
||||
# Test case: Ensure that a trigger definition that specifies a trigger action
|
||||
# time that is not either BEFORE or AFTER fails, with an appropriate
|
||||
# Test case: Ensure that a trigger definition that specifies a trigger action
|
||||
# time that is not either BEFORE or AFTER fails, with an appropriate
|
||||
# error message, at CREATE TRIGGER time.
|
||||
let $message= Testcase 3.5.6.3:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
Create trigger trg3_1 DURING UPDATE on tb3 for each row set new.f132=25;
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
Create trigger trg3_2 TIME INSERT on tb3 for each row set new.f132=15;
|
||||
|
||||
#Cleanup
|
||||
#Cleanup
|
||||
# OBN - Although none of the above should have been created we should do a cleanup
|
||||
# since if they have been created, not dropping them will affect following
|
||||
# tests.
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger tb3.trg3_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger tb3.trg3_2;
|
||||
--enable_warnings
|
||||
|
||||
#Section 3.5.6.4
|
||||
# Test case: Ensure that a trigger defined with a trigger action time of BEFORE
|
||||
# always executes its triggered action immediately before the trigger event.
|
||||
# Test case: Ensure that a trigger defined with a trigger action time of BEFORE
|
||||
# always executes its triggered action immediately before the trigger event.
|
||||
# See section 3.5.1.1
|
||||
let $message= Testcase 3.5.6.4 (see Testcase 3.5.1.1);
|
||||
--source include/show_msg.inc
|
||||
|
||||
#Section 3.5.6.5
|
||||
# Test case: Ensure that a trigger defined with a trigger action time of AFTER
|
||||
# Test case: Ensure that a trigger defined with a trigger action time of AFTER
|
||||
# always executes its triggered action immediately after the trigger event.
|
||||
let $message= Testcase 3.5.6.5 (see Testcase 3.5.1.1);
|
||||
--source include/show_msg.inc
|
||||
@ -384,40 +384,40 @@ let $message= Testcase 3.5.7.3 (see Testcase 3.5.1.1);
|
||||
--source include/show_msg.inc
|
||||
|
||||
#Section 3.5.7.4
|
||||
# Test case: Ensure that a trigger definition that specifies a trigger event that
|
||||
# is not either INSERT, UPDATE or DELETE fails, with an appropriate error
|
||||
# Test case: Ensure that a trigger definition that specifies a trigger event that
|
||||
# is not either INSERT, UPDATE or DELETE fails, with an appropriate error
|
||||
# message, at CREATE TRIGGER time.
|
||||
let $message= Testcase 3.5.7.4:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
Create trigger trg4_1 BEFORE SELECT on tb3 for each row set new.f132=5;
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
Create trigger trg4_2 AFTER VALUE on tb3 for each row set new.f132=1;
|
||||
|
||||
#Cleanup
|
||||
#Cleanup
|
||||
# OBN - Although none of the above should have been created we should do a cleanup
|
||||
# since if they have been created, not dropping them will affect following
|
||||
# tests.
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger tb3.trg4_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger tb3.trg4_2;
|
||||
--enable_warnings
|
||||
|
||||
#Section 3.5.7.5 / 3.5.7.6
|
||||
# Test case: Ensure that it is not possible to create multiple BEFORE INSERT triggers
|
||||
#Section 3.5.7.5 / 3.5.7.6
|
||||
# Test case: Ensure that it is not possible to create multiple BEFORE INSERT triggers
|
||||
# on the same table, even if the triggers have different names / different
|
||||
# triggered actions.
|
||||
let $message= Testcase 3.5.7.5 / 3.5.7.6:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
Create trigger trg5_1 BEFORE INSERT
|
||||
Create trigger trg5_1 BEFORE INSERT
|
||||
on tb3 for each row set new.f122='Trigger1 3.5.7.5/6';
|
||||
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg5_2 BEFORE INSERT
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg5_2 BEFORE INSERT
|
||||
on tb3 for each row set new.f122='Trigger2 3.5.7.5';
|
||||
|
||||
Insert into tb3 (f121,f122) values ('Test 3.5.7.5/6','Insert 3.5.7.5');
|
||||
@ -426,27 +426,27 @@ let $message= Testcase 3.5.7.5 / 3.5.7.6:;
|
||||
Select f121,f122 from tb3 where f121='Test 3.5.7.5/6';
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg5_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg5_2;
|
||||
delete from tb3 where f121='Test 3.5.7.5/6';
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.7.7 / 3.5.7.8
|
||||
# Test case: Ensure that it is not possible to create multiple AFTER INSERT triggers
|
||||
#Section 3.5.7.7 / 3.5.7.8
|
||||
# Test case: Ensure that it is not possible to create multiple AFTER INSERT triggers
|
||||
# on the same table, even if the triggers have different names / different
|
||||
# triggered actions.
|
||||
let $message= Testcase 3.5.7.7 / 3.5.7.8:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
set @test_var='Before trig 3.5.7.7';
|
||||
Create trigger trg6_1 AFTER INSERT
|
||||
Create trigger trg6_1 AFTER INSERT
|
||||
on tb3 for each row set @test_var='Trigger1 3.5.7.7/8';
|
||||
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg6_2 AFTER INSERT
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg6_2 AFTER INSERT
|
||||
on tb3 for each row set @test_var='Trigger2 3.5.7.7';
|
||||
|
||||
select @test_var;
|
||||
@ -458,26 +458,26 @@ let $message= Testcase 3.5.7.7 / 3.5.7.8:;
|
||||
select @test_var;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg6_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg6_2;
|
||||
delete from tb3 where f121='Test 3.5.7.7/8';
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.7.9 / 3.5.7.10
|
||||
# Test case: Ensure that it is not possible to create multiple BEFORE UPDATE triggers
|
||||
# on the same table, even if the triggers have different names / different
|
||||
# Test case: Ensure that it is not possible to create multiple BEFORE UPDATE triggers
|
||||
# on the same table, even if the triggers have different names / different
|
||||
# triggered actions.
|
||||
let $message= Testcase 3.5.7.9/10:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
Create trigger trg7_1 BEFORE UPDATE
|
||||
Create trigger trg7_1 BEFORE UPDATE
|
||||
on tb3 for each row set new.f122='Trigger1 3.5.7.9/10';
|
||||
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg7_2 BEFORE UPDATE
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg7_2 BEFORE UPDATE
|
||||
on tb3 for each row set new.f122='Trigger2 3.5.7.9';
|
||||
|
||||
Insert into tb3 (f121,f122) values ('Test 3.5.7.9/10','Insert 3.5.7.9');
|
||||
@ -486,25 +486,25 @@ let $message= Testcase 3.5.7.9/10:;
|
||||
Select f121,f122 from tb3 where f121='Test 3.5.7.9/10';
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg7_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg7_2;
|
||||
delete from tb3 where f121='Test 3.5.7.9/10';
|
||||
|
||||
#Section 3.5.7.11 / 3.5.7.12
|
||||
# Test case: Ensure that it is not possible to create multiple AFTER UPDATE triggers
|
||||
# Test case: Ensure that it is not possible to create multiple AFTER UPDATE triggers
|
||||
# on the same table, even if the triggers have different names / different
|
||||
# triggered actions.
|
||||
# triggered actions.
|
||||
let $message= Testcase 3.5.7.11/12:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
set @test_var='Before trig 3.5.7.11';
|
||||
Create trigger trg8_1 AFTER UPDATE
|
||||
Create trigger trg8_1 AFTER UPDATE
|
||||
on tb3 for each row set @test_var='Trigger 3.5.7.11/12';
|
||||
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg8_2 AFTER UPDATE
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg8_2 AFTER UPDATE
|
||||
on tb3 for each row set @test_var='Trigger2 3.5.7.11';
|
||||
|
||||
|
||||
@ -518,25 +518,25 @@ let $message= Testcase 3.5.7.11/12:;
|
||||
delete from tb3 where f121='Test 3.5.7.11/12';
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg8_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg8_2;
|
||||
delete from tb3 where f121='Test 3.5.7.11/12';
|
||||
|
||||
#Section 3.5.7.13 / 3.5.7.14
|
||||
# Test case: Ensure that it is not possible to create multiple BEFORE DELETE triggers
|
||||
# Test case: Ensure that it is not possible to create multiple BEFORE DELETE triggers
|
||||
# on the same table, even if the triggers have different names / different
|
||||
# triggered actions.
|
||||
let $message= Testcase 3.5.7.13/14:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
set @test_var=1;
|
||||
Create trigger trg9_1 BEFORE DELETE
|
||||
Create trigger trg9_1 BEFORE DELETE
|
||||
on tb3 for each row set @test_var=@test_var+1;
|
||||
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg9_2 BEFORE DELETE
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg9_2 BEFORE DELETE
|
||||
on tb3 for each row set @test_var=@test_var+10;
|
||||
|
||||
select @test_var;
|
||||
@ -550,29 +550,29 @@ let $message= Testcase 3.5.7.13/14:;
|
||||
select @test_var;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg9_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg9_2;
|
||||
delete from tb3 where f121='Test 3.5.7.13/14';
|
||||
|
||||
#Section 3.5.7.15 / 3.5.7.16
|
||||
# Test case: Ensure that it is not possible to create multiple AFTER DELETE triggers
|
||||
# on the same table, even if the triggers have different names / different
|
||||
# Test case: Ensure that it is not possible to create multiple AFTER DELETE triggers
|
||||
# on the same table, even if the triggers have different names / different
|
||||
# triggered actions.
|
||||
let $message= Testcase 3.5.7.15/16:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
set @test_var=1;
|
||||
Create trigger trg_3_406010_1 AFTER DELETE
|
||||
Create trigger trg_3_406010_1 AFTER DELETE
|
||||
on tb3 for each row set @test_var=@test_var+5;
|
||||
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg_3_406010_2 AFTER DELETE
|
||||
--error ER_NOT_SUPPORTED_YET
|
||||
Create trigger trg_3_406010_2 AFTER DELETE
|
||||
on tb3 for each row set @test_var=@test_var+50;
|
||||
|
||||
--error 1359
|
||||
Create trigger trg_3_406010_1 AFTER INSERT
|
||||
--error ER_TRG_ALREADY_EXISTS
|
||||
Create trigger trg_3_406010_1 AFTER INSERT
|
||||
on tb3 for each row set @test_var=@test_var+1;
|
||||
|
||||
select @test_var;
|
||||
@ -586,18 +586,18 @@ let $message= Testcase 3.5.7.15/16:;
|
||||
select @test_var;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg_3_406010_1;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg_3_406010_2;
|
||||
delete from tb3 where f121='Test 3.5.7.15/16';
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.7.17
|
||||
# Test case: Ensure that it is possible to have a BEFORE INSERT, an AFTER INSERT,
|
||||
# a BEFORE UPDATE, an AFTER UPDATE, a BEFORE DELETE, and an AFTER DELETE
|
||||
# trigger on the same table; that is, ensure that every persistent base
|
||||
# Test case: Ensure that it is possible to have a BEFORE INSERT, an AFTER INSERT,
|
||||
# a BEFORE UPDATE, an AFTER UPDATE, a BEFORE DELETE, and an AFTER DELETE
|
||||
# trigger on the same table; that is, ensure that every persistent base
|
||||
# table may be the subject table for exactly six triggers
|
||||
let $message= Testcase 3.5.7.17 (see Testcase 3.5.1.1);
|
||||
--source include/show_msg.inc
|
||||
|
@ -1,7 +1,7 @@
|
||||
#======================================================================
|
||||
#
|
||||
# Trigger Tests
|
||||
# (test case numbering refer to requirement document TP v1.1)
|
||||
# Trigger Tests
|
||||
# (test case numbering refer to requirement document TP v1.1)
|
||||
#======================================================================
|
||||
|
||||
# General setup for Trigger tests
|
||||
@ -29,22 +29,20 @@ let $message= Testcase: 3.5:;
|
||||
#################################
|
||||
|
||||
#Section 3.5.8.1
|
||||
# Testcase: Ensure that the triggered action of every trigger always executes
|
||||
# Testcase: Ensure that the triggered action of every trigger always executes
|
||||
# correctly and the results in all expected changes made to the database
|
||||
let $message= Testcase 3.5.8.1: (implied in previous tests);
|
||||
--source include/show_msg.inc
|
||||
|
||||
# OBN - FIXME - Missing 3.5.8.1 need to add
|
||||
|
||||
#Section 3.5.8.2
|
||||
# Testcase: Ensure that the triggered actions of every trigger never results
|
||||
# Testcase: Ensure that the triggered actions of every trigger never results
|
||||
# in an unexpected change made to the database.
|
||||
let $message= Testcase 3.5.8.2: (implied in previous tests);
|
||||
--source include/show_msg.inc
|
||||
|
||||
|
||||
#Section 3.5.8.3 / 3.5.8.4
|
||||
#Test case: Ensure that the triggered action can any valid SQL statement / set
|
||||
#Test case: Ensure that the triggered action can any valid SQL statement / set
|
||||
# of valid SQL statements, provided the statements are written within
|
||||
# a BEGIN/END compound statement construct
|
||||
# OBN - At this point the tests focuses on the the INSERT/UPDATE/DELETE SQL statements
|
||||
@ -58,17 +56,17 @@ let $message= Testcase 3.5.8.3/4:;
|
||||
grant SELECT, INSERT, UPDATE, DELETE on db_test.* to test_general;
|
||||
grant LOCK TABLES on db_test.* to test_general;
|
||||
Use db_test;
|
||||
eval create table t1_i (
|
||||
eval create table t1_i (
|
||||
i120 char ascii not null DEFAULT b'101',
|
||||
i136 smallint zerofill not null DEFAULT 999,
|
||||
i144 int zerofill not null DEFAULT 99999,
|
||||
i163 decimal (63,30)) engine=$engine_type;
|
||||
eval create table t1_u (
|
||||
eval create table t1_u (
|
||||
u120 char ascii not null DEFAULT b'101',
|
||||
u136 smallint zerofill not null DEFAULT 999,
|
||||
u144 int zerofill not null DEFAULT 99999,
|
||||
u163 decimal (63,30)) engine=$engine_type;
|
||||
eval create table t1_d (
|
||||
eval create table t1_d (
|
||||
d120 char ascii not null DEFAULT b'101',
|
||||
d136 smallint zerofill not null DEFAULT 999,
|
||||
d144 int zerofill not null DEFAULT 99999,
|
||||
@ -93,26 +91,29 @@ let $message= 3.5.8.4 - multiple SQL;
|
||||
delimiter //;
|
||||
Create trigger trg1 AFTER INSERT on tb3 for each row
|
||||
BEGIN
|
||||
insert into db_test.t1_i
|
||||
insert into db_test.t1_i
|
||||
values (new.f120, new.f136, new.f144, new.f163);
|
||||
update db_test.t1_u
|
||||
update db_test.t1_u
|
||||
set u144=new.f144, u163=new.f163
|
||||
where u136=new.f136;
|
||||
where u136=new.f136;
|
||||
delete from db_test.t1_d where d136= new.f136;
|
||||
select sum(db_test.t1_u.u163) into @test_var from db_test.t1_u
|
||||
where u136= new.f136;
|
||||
END//
|
||||
select sum(db_test.t1_u.u163) into @test_var from db_test.t1_u
|
||||
where u136= new.f136;
|
||||
END//
|
||||
delimiter ;//
|
||||
|
||||
# Test trigger execution - multiple SQL
|
||||
connection con2_general;
|
||||
Use test;
|
||||
set @test_var=0;
|
||||
Insert into tb3 (f120, f122, f136, f144, f163)
|
||||
Insert into tb3 (f120, f122, f136, f144, f163)
|
||||
values ('1', 'Test 3.5.8.4', 222, 23456, 1.05);
|
||||
Select f120, f122, f136, f144, f163 from tb3 where f122= 'Test 3.5.8.4';
|
||||
--sorted_result
|
||||
select * from db_test.t1_i;
|
||||
--sorted_result
|
||||
select * from db_test.t1_u;
|
||||
--sorted_result
|
||||
select * from db_test.t1_d;
|
||||
select @test_var;
|
||||
|
||||
@ -121,16 +122,22 @@ let $message= 3.5.8.4 - single SQL - insert;
|
||||
--source include/show_msg.inc
|
||||
# Trigger definition - single SQL Insert
|
||||
connection con2_super;
|
||||
delimiter //;
|
||||
Create trigger trg2 BEFORE UPDATE on tb3 for each row
|
||||
insert into db_test.t1_i
|
||||
BEGIN
|
||||
insert into db_test.t1_i
|
||||
values (new.f120, new.f136, new.f144, new.f163);
|
||||
END//
|
||||
delimiter ;//
|
||||
|
||||
# Trigger exeution - single SQL Insert
|
||||
connection con2_general;
|
||||
Select f120, f122, f136, f144, f163 from tb3 where f122 like 'Test 3.5.8.4%';
|
||||
select * from db_test.t1_i order by i120;
|
||||
update tb3 set f120='I', f122='Test 3.5.8.4-Single Insert'
|
||||
where f122='Test 3.5.8.4';
|
||||
Select f120, f122, f136, f144, f163 from tb3 where f122 like 'Test 3.5.8.4%';
|
||||
select * from db_test.t1_i;
|
||||
select * from db_test.t1_i order by i120;
|
||||
|
||||
|
||||
let $message= 3.5.8.4 - single SQL - update;
|
||||
@ -139,16 +146,16 @@ let $message= 3.5.8.4 - single SQL - update;
|
||||
connection con2_super;
|
||||
drop trigger trg2;
|
||||
Create trigger trg3 BEFORE UPDATE on tb3 for each row
|
||||
update db_test.t1_u
|
||||
update db_test.t1_u
|
||||
set u120=new.f120
|
||||
where u136=new.f136;
|
||||
where u136=new.f136;
|
||||
|
||||
# Trigger exeution - single SQL - update;
|
||||
connection con2_general;
|
||||
update tb3 set f120='U', f122='Test 3.5.8.4-Single Update'
|
||||
where f122='Test 3.5.8.4-Single Insert';
|
||||
Select f120, f122, f136, f144, f163 from tb3 where f122 like 'Test 3.5.8.4%';
|
||||
select * from db_test.t1_u;
|
||||
select * from db_test.t1_u order by u120;
|
||||
|
||||
|
||||
let $message= 3.5.8.3/4 - single SQL - delete;
|
||||
@ -162,12 +169,12 @@ let $message= 3.5.8.3/4 - single SQL - delete;
|
||||
# Trigger exeution - single SQL delete
|
||||
connection con2_general;
|
||||
#lock tables tb3 write, db_test.t1_i write, db_test.t1_u write, db_test.t1_d write;
|
||||
update tb3 set f120='D', f136=444,
|
||||
update tb3 set f120='D', f136=444,
|
||||
f122='Test 3.5.8.4-Single Delete'
|
||||
where f122='Test 3.5.8.4-Single Update';
|
||||
#unlock tables;
|
||||
Select f120, f122, f136, f144, f163 from tb3 where f122 like 'Test 3.5.8.4%';
|
||||
select * from db_test.t1_d;
|
||||
select * from db_test.t1_d order by d120;
|
||||
|
||||
|
||||
let $message= 3.5.8.3/4 - single SQL - select;
|
||||
@ -176,13 +183,13 @@ let $message= 3.5.8.3/4 - single SQL - select;
|
||||
connection con2_super;
|
||||
drop trigger trg4;
|
||||
Create trigger trg5 AFTER UPDATE on tb3 for each row
|
||||
select sum(db_test.t1_u.u163) into @test_var from db_test.t1_u
|
||||
where u136= new.f136;
|
||||
select sum(db_test.t1_u.u163) into @test_var from db_test.t1_u
|
||||
where u136= new.f136;
|
||||
|
||||
# Trigger exeution - single SQL select
|
||||
connection con2_general;
|
||||
set @test_var=0;
|
||||
update tb3 set f120='S', f136=111,
|
||||
update tb3 set f120='S', f136=111,
|
||||
f122='Test 3.5.8.4-Single Select'
|
||||
where f122='Test 3.5.8.4-Single Delete';
|
||||
Select f120, f122, f136, f144, f163 from tb3 where f122 like 'Test 3.5.8.4%';
|
||||
@ -190,7 +197,7 @@ let $message= 3.5.8.3/4 - single SQL - select;
|
||||
|
||||
#Cleanup
|
||||
connection default;
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg1;
|
||||
drop trigger trg5;
|
||||
drop database if exists db_test;
|
||||
@ -200,8 +207,8 @@ let $message= 3.5.8.3/4 - single SQL - select;
|
||||
|
||||
|
||||
#Section 3.5.8.5 (IF)
|
||||
# Test case: Ensure that the stored procedure-specific flow control statement like IF
|
||||
# works correctly when it is a part of the triggered action portion of a
|
||||
# Test case: Ensure that the stored procedure-specific flow control statement like IF
|
||||
# works correctly when it is a part of the triggered action portion of a
|
||||
# trigger definition.
|
||||
let $message= Testcase 3.5.8.5 (IF):;
|
||||
--source include/show_msg.inc
|
||||
@ -219,7 +226,7 @@ let $message= Testcase 3.5.8.5 (IF):;
|
||||
|
||||
IF (new.f120='4') and (new.f136=10) then
|
||||
set @test_var2='2nd if', new.f120='d';
|
||||
ELSE
|
||||
ELSE
|
||||
set @test_var2='2nd else', new.f120='D';
|
||||
END IF;
|
||||
END//
|
||||
@ -227,50 +234,50 @@ let $message= Testcase 3.5.8.5 (IF):;
|
||||
|
||||
set @test_var='Empty', @test_var2=0;
|
||||
Insert into tb3 (f120, f122, f136) values ('1', 'Test 3.5.8.5-if', 101);
|
||||
select f120, f122, f136, @test_var, @test_var2
|
||||
from tb3 where f122 = 'Test 3.5.8.5-if';
|
||||
select f120, f122, f136, @test_var, @test_var2
|
||||
from tb3 where f122 = 'Test 3.5.8.5-if' order by f136;
|
||||
Insert into tb3 (f120, f122, f136) values ('2', 'Test 3.5.8.5-if', 102);
|
||||
select f120, f122, f136, @test_var, @test_var2
|
||||
from tb3 where f122 = 'Test 3.5.8.5-if';
|
||||
select f120, f122, f136, @test_var, @test_var2
|
||||
from tb3 where f122 = 'Test 3.5.8.5-if' order by f136;
|
||||
Insert into tb3 (f120, f122, f136) values ('3', 'Test 3.5.8.5-if', 10);
|
||||
select f120, f122, f136, @test_var, @test_var2
|
||||
from tb3 where f122 = 'Test 3.5.8.5-if';
|
||||
select f120, f122, f136, @test_var, @test_var2
|
||||
from tb3 where f122 = 'Test 3.5.8.5-if' order by f136;
|
||||
Insert into tb3 (f120, f122, f136) values ('3', 'Test 3.5.8.5-if', 103);
|
||||
select f120, f122, f136, @test_var, @test_var2
|
||||
from tb3 where f122 = 'Test 3.5.8.5-if';
|
||||
select f120, f122, f136, @test_var, @test_var2
|
||||
from tb3 where f122 = 'Test 3.5.8.5-if' order by f136;
|
||||
|
||||
delimiter //;
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
create trigger trg3 before update on tb3 for each row
|
||||
BEGIN
|
||||
ELSEIF new.f120='2' then
|
||||
END IF;
|
||||
END//
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg3//
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
create trigger trg4 before update on tb3 for each row
|
||||
BEGIN
|
||||
IF (new.f120='4') and (new.f136=10) then
|
||||
set @test_var2='2nd if', new.f120='d';
|
||||
ELSE
|
||||
ELSE
|
||||
set @test_var2='2nd else', new.f120='D';
|
||||
END//
|
||||
delimiter ;//
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg2;
|
||||
delete from tb3 where f121='Test 3.5.8.5-if';
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.8.5 (CASE)
|
||||
# Test case: Ensure that the stored procedure-specific flow control statement
|
||||
# like CASE works correctly when it is a part of the triggered action
|
||||
# Test case: Ensure that the stored procedure-specific flow control statement
|
||||
# like CASE works correctly when it is a part of the triggered action
|
||||
# portion of a trigger definition.
|
||||
let $message= Testcase 3.5.8.5-case:;
|
||||
--source include/show_msg.inc
|
||||
@ -310,34 +317,34 @@ let $message= Testcase 3.5.8.5-case:;
|
||||
delimiter ;//
|
||||
|
||||
set @test_var='Empty';
|
||||
Insert into tb3 (f120, f122, f136, f144)
|
||||
Insert into tb3 (f120, f122, f136, f144)
|
||||
values ('a', 'Test 3.5.8.5-case', 5, 7);
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case';
|
||||
Insert into tb3 (f120, f122, f136, f144)
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case' order by f120,f136;
|
||||
Insert into tb3 (f120, f122, f136, f144)
|
||||
values ('b', 'Test 3.5.8.5-case', 71,16);
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case';
|
||||
Insert into tb3 (f120, f122, f136, f144)
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case' order by f120,f136;
|
||||
Insert into tb3 (f120, f122, f136, f144)
|
||||
values ('c', 'Test 3.5.8.5-case', 80,1);
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case';
|
||||
Insert into tb3 (f120, f122, f136)
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case' order by f120,f136;
|
||||
Insert into tb3 (f120, f122, f136)
|
||||
values ('d', 'Test 3.5.8.5-case', 152);
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case';
|
||||
Insert into tb3 (f120, f122, f136, f144)
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case' order by f120,f136;
|
||||
Insert into tb3 (f120, f122, f136, f144)
|
||||
values ('e', 'Test 3.5.8.5-case', 200, 8);
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case';
|
||||
--error 0, 1339
|
||||
Insert into tb3 (f120, f122, f136, f144)
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case' order by f120,f136;
|
||||
--error 0, ER_SP_CASE_NOT_FOUND
|
||||
Insert into tb3 (f120, f122, f136, f144)
|
||||
values ('f', 'Test 3.5.8.5-case', 100, 8);
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case';
|
||||
select f120, f122, f136, f144, @test_var
|
||||
from tb3 where f122 = 'Test 3.5.8.5-case' order by f120,f136;
|
||||
|
||||
delimiter //;
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
create trigger trg3a before update on tb3 for each row
|
||||
BEGIN
|
||||
CASE
|
||||
@ -345,11 +352,11 @@ let $message= Testcase 3.5.8.5-case:;
|
||||
END//
|
||||
delimiter ;//
|
||||
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg3a;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg3;
|
||||
delete from tb3 where f121='Test 3.5.8.5-case';
|
||||
--enable_warnings
|
||||
@ -363,53 +370,53 @@ let $message= Testcase 3.5.8.5-loop/leave:;
|
||||
|
||||
delimiter //;
|
||||
Create trigger trg4 after insert on tb3 for each row
|
||||
BEGIN
|
||||
BEGIN
|
||||
set @counter=0, @flag='Initial';
|
||||
Label1: loop
|
||||
Label1: loop
|
||||
if new.f136<new.f144 then
|
||||
set @counter='Nothing to loop';
|
||||
leave Label1;
|
||||
leave Label1;
|
||||
else
|
||||
set @counter=@counter+1;
|
||||
if new.f136=new.f144+@counter then
|
||||
set @counter=concat(@counter, ' loops');
|
||||
leave Label1;
|
||||
end if;
|
||||
end if;
|
||||
iterate label1;
|
||||
end if;
|
||||
end if;
|
||||
iterate label1;
|
||||
set @flag='Final';
|
||||
END loop Label1;
|
||||
END loop Label1;
|
||||
END//
|
||||
delimiter ;//
|
||||
Insert into tb3 (f122, f136, f144)
|
||||
Insert into tb3 (f122, f136, f144)
|
||||
values ('Test 3.5.8.5-loop', 2, 8);
|
||||
select @counter, @flag;
|
||||
Insert into tb3 (f122, f136, f144)
|
||||
Insert into tb3 (f122, f136, f144)
|
||||
values ('Test 3.5.8.5-loop', 11, 8);
|
||||
select @counter, @flag;
|
||||
|
||||
|
||||
delimiter //;
|
||||
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
Create trigger trg4_2 after update on tb3 for each row
|
||||
BEGIN
|
||||
Label1: loop
|
||||
BEGIN
|
||||
Label1: loop
|
||||
set @counter=@counter+1;
|
||||
END;
|
||||
END;
|
||||
END//
|
||||
delimiter ;//
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4_2;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg4;
|
||||
delete from tb3 where f122='Test 3.5.8.5-loop';
|
||||
--enable_warnings
|
||||
|
||||
#Section 3.5.8.5 (REPEAT ITERATE)
|
||||
#Testcase: Ensure that the stored procedure-specific flow control statements
|
||||
#Testcase: Ensure that the stored procedure-specific flow control statements
|
||||
# like REPEAT work correctly when they are part of the triggered action
|
||||
# portion of a trigger definition.
|
||||
let $message= Testcase 3.5.8.5-repeat:;
|
||||
@ -418,108 +425,122 @@ let $message= Testcase 3.5.8.5-repeat:;
|
||||
delimiter //;
|
||||
Create trigger trg6 after insert on tb3 for each row
|
||||
BEGIN
|
||||
rp_label: REPEAT
|
||||
SET @counter1 = @counter1 + 1;
|
||||
rp_label: REPEAT
|
||||
SET @counter1 = @counter1 + 1;
|
||||
IF (@counter1 MOD 2 = 0) THEN ITERATE rp_label;
|
||||
END IF;
|
||||
SET @counter2 = @counter2 + 1;
|
||||
SET @counter2 = @counter2 + 1;
|
||||
UNTIL @counter1> new.f136 END REPEAT rp_label;
|
||||
END//
|
||||
delimiter ;//
|
||||
|
||||
set @counter1= 0, @counter2= 0;
|
||||
Insert into tb3 (f122, f136)
|
||||
Insert into tb3 (f122, f136)
|
||||
values ('Test 3.5.8.5-repeat', 13);
|
||||
select @counter1, @counter2;
|
||||
|
||||
|
||||
delimiter //;
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
Create trigger trg6_2 after update on tb3 for each row
|
||||
BEGIN
|
||||
REPEAT
|
||||
SET @counter2 = @counter2 + 1;
|
||||
REPEAT
|
||||
SET @counter2 = @counter2 + 1;
|
||||
END//
|
||||
delimiter ;//
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg6;
|
||||
delete from tb3 where f122='Test 3.5.8.5-repeat';
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.8.5 (WHILE)
|
||||
# Test case: Ensure that the stored procedure-specific flow control
|
||||
# statements WHILE, work correctly when they are part of
|
||||
# Test case: Ensure that the stored procedure-specific flow control
|
||||
# statements WHILE, work correctly when they are part of
|
||||
# the triggered action portion of a trigger definition.
|
||||
let $message= Testcase 3.5.8.5-while:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
delimiter //;
|
||||
Create trigger trg7 after insert on tb3 for each row
|
||||
wl_label: WHILE @counter1 < new.f136 DO
|
||||
SET @counter1 = @counter1 + 1;
|
||||
wl_label: WHILE @counter1 < new.f136 DO
|
||||
SET @counter1 = @counter1 + 1;
|
||||
IF (@counter1 MOD 2 = 0) THEN ITERATE wl_label;
|
||||
END IF;
|
||||
SET @counter2 = @counter2 + 1;
|
||||
SET @counter2 = @counter2 + 1;
|
||||
END WHILE wl_label//
|
||||
delimiter ;//
|
||||
|
||||
set @counter1= 0, @counter2= 0;
|
||||
Insert into tb3 (f122, f136)
|
||||
Insert into tb3 (f122, f136)
|
||||
values ('Test 3.5.8.5-while', 7);
|
||||
select @counter1, @counter2;
|
||||
delimiter //;
|
||||
--error 1064
|
||||
--error ER_PARSE_ERROR
|
||||
Create trigger trg7_2 after update on tb3 for each row
|
||||
BEGIN
|
||||
WHILE @counter1 < new.f136
|
||||
SET @counter1 = @counter1 + 1;
|
||||
WHILE @counter1 < new.f136
|
||||
SET @counter1 = @counter1 + 1;
|
||||
END//
|
||||
delimiter ;//
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
delete from tb3 where f122='Test 3.5.8.5-while';
|
||||
drop trigger trg7;
|
||||
--enable_warnings
|
||||
|
||||
#Section 3.5.8.6
|
||||
# Test case: Ensure that a trigger definition that includes a CALL to a stored
|
||||
# procedure fails, at CREATE TRIGGER time, with an appropriate error
|
||||
# message
|
||||
# OBN - requirement void since allowed
|
||||
# Fails due to Bug 9909 the bug allows the trigger to be created
|
||||
# and fails in execution time
|
||||
# Test case: Ensure that a trigger definition that includes a CALL to a stored
|
||||
# procedure fails, at CREATE TRIGGER time, with an appropriate error
|
||||
# message. Not more valid requirement.
|
||||
let $message= Testcase 3.5.8.6: (requirement void);
|
||||
--source include/show_msg.inc
|
||||
delimiter //;
|
||||
CREATE PROCEDURE sp_01 () BEGIN set @v1=1; END//
|
||||
|
||||
CREATE TRIGGER trg8_1 BEFORE UPDATE ON tb3 FOR EACH ROW
|
||||
BEGIN
|
||||
CALL sp_01 ();
|
||||
END//
|
||||
delimiter ;//
|
||||
Insert into tb3 (f120, f122, f136) values ('6', 'Test 3.5.8.6-insert', 101);
|
||||
update tb3 set f120='S', f136=111,
|
||||
f122='Test 3.5.8.6-tr8_1'
|
||||
where f122='Test 3.5.8.6-insert';
|
||||
select f120, f122
|
||||
from tb3 where f122 like 'Test 3.5.8.6%' order by f120;
|
||||
DROP TRIGGER trg8_1;
|
||||
DROP PROCEDURE sp_01;
|
||||
|
||||
|
||||
#Section 3.5.8.7
|
||||
# Test case: Ensure that a trigger definition that includes a
|
||||
# transaction-delimiting statement (e.g. COMMIT,
|
||||
# ROLLBACK, START TRANSACTION) fails, at CREATE TRIGGER
|
||||
# Test case: Ensure that a trigger definition that includes a
|
||||
# transaction-delimiting statement (e.g. COMMIT,
|
||||
# ROLLBACK, START TRANSACTION) fails, at CREATE TRIGGER
|
||||
# time, with an appropriate error message.
|
||||
# OBN - Fails due to Bug ____
|
||||
let $message= Testcase 3.5.8.7: (Disabled as a result of bug _____);
|
||||
let $message= Testcase 3.5.8.7;
|
||||
--source include/show_msg.inc
|
||||
|
||||
delimiter //;
|
||||
--error ER_COMMIT_NOT_ALLOWED_IN_SF_OR_TRG
|
||||
Create trigger trg9_1 before update on tb3 for each row
|
||||
BEGIN
|
||||
Start transaction;
|
||||
Set new.f120='U';
|
||||
Commit;
|
||||
END//
|
||||
|
||||
# --error 1314
|
||||
# Create trigger trg9_1 before update on tb3 for each row
|
||||
# BEGIN
|
||||
# Start transaction;
|
||||
# Set new.f120='U';
|
||||
# Commit;
|
||||
# END;
|
||||
|
||||
# --error 1314
|
||||
# Create trigger trg9_2 before delete on tb3 for each row
|
||||
# BEGIN
|
||||
# Start transaction;
|
||||
# Set @var2=old.f120;
|
||||
# Rollback;
|
||||
# END;
|
||||
--error ER_COMMIT_NOT_ALLOWED_IN_SF_OR_TRG
|
||||
Create trigger trg9_2 before delete on tb3 for each row
|
||||
BEGIN
|
||||
Start transaction;
|
||||
Set @var2=old.f120;
|
||||
Rollback;
|
||||
END//
|
||||
delimiter ;//
|
||||
|
||||
|
||||
# Cleanup section 3.5
|
||||
|
@ -1,7 +1,7 @@
|
||||
#======================================================================
|
||||
#
|
||||
# Trigger Tests
|
||||
# (test case numbering refer to requirement document TP v1.1)
|
||||
# Trigger Tests
|
||||
# (test case numbering refer to requirement document TP v1.1)
|
||||
#======================================================================
|
||||
|
||||
|
||||
@ -11,15 +11,15 @@
|
||||
#################################
|
||||
|
||||
#Section 3.5.9.1
|
||||
#Test case: Ensure that every trigger executes its triggered action on each row
|
||||
#Test case: Ensure that every trigger executes its triggered action on each row
|
||||
# that meets the conditions stated in the trigger definition.
|
||||
#Section 3.5.9.2
|
||||
#Testcase: Ensure that a trigger never executes its triggered action on any row
|
||||
#Testcase: Ensure that a trigger never executes its triggered action on any row
|
||||
# that doesn't meet the conditions stated in the trigger definition.
|
||||
let $message= Testcase 3.5.9.1/2:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
Create trigger trg1 BEFORE UPDATE on tb3 for each row
|
||||
Create trigger trg1 BEFORE UPDATE on tb3 for each row
|
||||
set new.f142 = 94087, @counter=@counter+1;
|
||||
--disable_query_log
|
||||
select count(*) as TotalRows from tb3;
|
||||
@ -29,22 +29,22 @@ let $message= Testcase 3.5.9.1/2:;
|
||||
--enable_query_log
|
||||
set @counter=0;
|
||||
Update tb3 Set f142='1' where f130<100;
|
||||
select count(*) as ExpectedChanged, @counter as TrigCounter
|
||||
select count(*) as ExpectedChanged, @counter as TrigCounter
|
||||
from tb3 where f142=94087;
|
||||
select count(*) as ExpectedNotChange from tb3
|
||||
select count(*) as ExpectedNotChange from tb3
|
||||
where f130<100 and f142<>94087;
|
||||
select count(*) as NonExpectedChanged from tb3
|
||||
select count(*) as NonExpectedChanged from tb3
|
||||
where f130>=130 and f142=94087;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg1;
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.9.3
|
||||
#Test case: Ensure that a reference to OLD.<column name> always correctly refers
|
||||
# to the values of the specified column of the subject table before a
|
||||
#Test case: Ensure that a reference to OLD.<column name> always correctly refers
|
||||
# to the values of the specified column of the subject table before a
|
||||
# data row is updated or deleted.
|
||||
let $message= Testcase 3.5.9.3:;
|
||||
--source include/show_msg.inc
|
||||
@ -71,46 +71,46 @@ let $message= Testcase 3.5.9.3:;
|
||||
|
||||
|
||||
--disable_query_log
|
||||
set @tr_var_b4_118=0, @tr_var_b4_121=0, @tr_var_b4_122=0,
|
||||
set @tr_var_b4_118=0, @tr_var_b4_121=0, @tr_var_b4_122=0,
|
||||
@tr_var_b4_136=0, @tr_var_b4_163=0;
|
||||
set @tr_var_af_118=0, @tr_var_af_121=0, @tr_var_af_122=0,
|
||||
set @tr_var_af_118=0, @tr_var_af_121=0, @tr_var_af_122=0,
|
||||
@tr_var_af_136=0, @tr_var_af_163=0;
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
@tr_var_b4_136, @tr_var_b4_163;
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
@tr_var_af_136, @tr_var_af_163;
|
||||
--enable_query_log
|
||||
|
||||
Insert into tb3 (f122, f136, f163)
|
||||
Insert into tb3 (f122, f136, f163)
|
||||
values ('Test 3.5.9.3', 7, 123.17);
|
||||
Update tb3 Set f136=8 where f122='Test 3.5.9.3';
|
||||
|
||||
select f118, f121, f122, f136, f163 from tb3 where f122='Test 3.5.9.3';
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
select f118, f121, f122, f136, f163 from tb3 where f122='Test 3.5.9.3' order by f136;
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
@tr_var_b4_136, @tr_var_b4_163;
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
@tr_var_af_136, @tr_var_af_163;
|
||||
|
||||
--disable_query_log
|
||||
set @tr_var_b4_118=0, @tr_var_b4_121=0, @tr_var_b4_122=0,
|
||||
set @tr_var_b4_118=0, @tr_var_b4_121=0, @tr_var_b4_122=0,
|
||||
@tr_var_b4_136=0, @tr_var_b4_163=0;
|
||||
set @tr_var_af_118=0, @tr_var_af_121=0, @tr_var_af_122=0,
|
||||
set @tr_var_af_118=0, @tr_var_af_121=0, @tr_var_af_122=0,
|
||||
@tr_var_af_136=0, @tr_var_af_163=0;
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
@tr_var_b4_136, @tr_var_b4_163;
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
@tr_var_af_136, @tr_var_af_163;
|
||||
--enable_query_log
|
||||
|
||||
delete from tb3 where f122='Test 3.5.9.3';
|
||||
|
||||
select f118, f121, f122, f136, f163 from tb3 where f122='Test 3.5.9.3';
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
select f118, f121, f122, f136, f163 from tb3 where f122='Test 3.5.9.3' order by f136;
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
@tr_var_b4_136, @tr_var_b4_163;
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
@tr_var_af_136, @tr_var_af_163;
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg2_a;
|
||||
drop trigger trg2_b;
|
||||
drop trigger trg2_c;
|
||||
@ -118,8 +118,8 @@ let $message= Testcase 3.5.9.3:;
|
||||
--enable_warnings
|
||||
|
||||
#Section 3.5.9.4
|
||||
#Test case: Ensure that a reference to NEW.<column name> always correctly refers
|
||||
# to the values of the specified column of the subject table after an
|
||||
#Test case: Ensure that a reference to NEW.<column name> always correctly refers
|
||||
# to the values of the specified column of the subject table after an
|
||||
# existing data row has been updated or a new data row has been inserted.
|
||||
let $message= Testcase 3.5.9.4:;
|
||||
--source include/show_msg.inc
|
||||
@ -145,48 +145,48 @@ let $message= Testcase 3.5.9.4:;
|
||||
@tr_var_af_151=new.f151, @tr_var_af_163=new.f163;
|
||||
|
||||
--disable_query_log
|
||||
set @tr_var_b4_118=0, @tr_var_b4_121=0, @tr_var_b4_122=0,
|
||||
set @tr_var_b4_118=0, @tr_var_b4_121=0, @tr_var_b4_122=0,
|
||||
@tr_var_b4_136=0, @tr_var_b4_151=0, @tr_var_b4_163=0;
|
||||
set @tr_var_af_118=0, @tr_var_af_121=0, @tr_var_af_122=0,
|
||||
set @tr_var_af_118=0, @tr_var_af_121=0, @tr_var_af_122=0,
|
||||
@tr_var_af_136=0, @tr_var_af_151=0, @tr_var_af_163=0;
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
@tr_var_b4_136, @tr_var_b4_151, @tr_var_b4_163;
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
@tr_var_af_136, @tr_var_af_151, @tr_var_af_163;
|
||||
--enable_query_log
|
||||
|
||||
Insert into tb3 (f122, f136, f151, f163)
|
||||
Insert into tb3 (f122, f136, f151, f163)
|
||||
values ('Test 3.5.9.4', 7, DEFAULT, 995.24);
|
||||
|
||||
select f118, f121, f122, f136, f151, f163 from tb3
|
||||
where f122 like 'Test 3.5.9.4%';
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
select f118, f121, f122, f136, f151, f163 from tb3
|
||||
where f122 like 'Test 3.5.9.4%' order by f163;
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
@tr_var_b4_136, @tr_var_b4_151, @tr_var_b4_163;
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
@tr_var_af_136, @tr_var_af_151, @tr_var_af_163;
|
||||
|
||||
--disable_query_log
|
||||
set @tr_var_b4_118=0, @tr_var_b4_121=0, @tr_var_b4_122=0,
|
||||
set @tr_var_b4_118=0, @tr_var_b4_121=0, @tr_var_b4_122=0,
|
||||
@tr_var_b4_136=0, @tr_var_b4_151=0, @tr_var_b4_163=0;
|
||||
set @tr_var_af_118=0, @tr_var_af_121=0, @tr_var_af_122=0,
|
||||
set @tr_var_af_118=0, @tr_var_af_121=0, @tr_var_af_122=0,
|
||||
@tr_var_af_136=0, @tr_var_af_151=0, @tr_var_af_163=0;
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
@tr_var_b4_136, @tr_var_b4_151, @tr_var_b4_163;
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
@tr_var_af_136, @tr_var_af_151, @tr_var_af_163;
|
||||
--enable_query_log
|
||||
|
||||
Update tb3 Set f122='Test 3.5.9.4-trig', f136=NULL, f151=DEFAULT, f163=NULL
|
||||
where f122='Test 3.5.9.4';
|
||||
|
||||
select f118, f121, f122, f136, f151, f163 from tb3
|
||||
where f122 like 'Test 3.5.9.4-trig';
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
select f118, f121, f122, f136, f151, f163 from tb3
|
||||
where f122 like 'Test 3.5.9.4-trig' order by f163;
|
||||
select @tr_var_b4_118, @tr_var_b4_121, @tr_var_b4_122,
|
||||
@tr_var_b4_136, @tr_var_b4_151, @tr_var_b4_163;
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
select @tr_var_af_118, @tr_var_af_121, @tr_var_af_122,
|
||||
@tr_var_af_136, @tr_var_af_151, @tr_var_af_163;
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--disable_warnings
|
||||
drop trigger trg3_a;
|
||||
drop trigger trg3_b;
|
||||
drop trigger trg3_c;
|
||||
@ -196,121 +196,119 @@ let $message= Testcase 3.5.9.4:;
|
||||
|
||||
|
||||
#Section 3.5.9.5
|
||||
# Test case: Ensure that the definition of an INSERT trigger can include a
|
||||
# Test case: Ensure that the definition of an INSERT trigger can include a
|
||||
# reference to NEW. <Column name>.
|
||||
let $message= Testcase 3.5.9.5: (implied in previous tests);
|
||||
--source include/show_msg.inc
|
||||
|
||||
#Section 3.5.9.6
|
||||
# Test case: Ensure that the definition of an INSERT trigger cannot include
|
||||
# Test case: Ensure that the definition of an INSERT trigger cannot include
|
||||
# a reference to OLD. <Column name>.
|
||||
let $message= Testcase 3.5.9.6:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
--error 1363
|
||||
--error ER_TRG_NO_SUCH_ROW_IN_TRG
|
||||
create trigger trg4a before insert on tb3 for each row
|
||||
set @temp1= old.f120;
|
||||
--error 1362
|
||||
--error ER_TRG_CANT_CHANGE_ROW
|
||||
create trigger trg4b after insert on tb3 for each row
|
||||
set old.f120= 'test';
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
--disable_warnings
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4a;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg4b;
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.9.7
|
||||
# Test case: Ensure that the definition of an UPDATE trigger can include a
|
||||
# Test case: Ensure that the definition of an UPDATE trigger can include a
|
||||
# reference to NEW. <Column name>.
|
||||
let $message= Testcase 3.5.9.7: (implied in previous tests);
|
||||
--source include/show_msg.inc
|
||||
|
||||
#Section 3.5.9.8
|
||||
# Test case: Ensure that the definition of an UPDATE trigger cannot include a
|
||||
# Test case: Ensure that the definition of an UPDATE trigger cannot include a
|
||||
# reference to OLD. <Column name>.
|
||||
let $message= Testcase 3.5.9.8: (implied in previous tests);
|
||||
--source include/show_msg.inc
|
||||
|
||||
#Section 3.5.9.9
|
||||
# Test case: Ensure that the definition of a DELETE trigger cannot include a
|
||||
# Test case: Ensure that the definition of a DELETE trigger cannot include a
|
||||
# reference to NEW.<column name>.
|
||||
let $message= Testcase 3.5.9.9:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
--error 1363
|
||||
--error ER_TRG_NO_SUCH_ROW_IN_TRG
|
||||
create trigger trg5a before DELETE on tb3 for each row
|
||||
set @temp1=new.f122;
|
||||
--error 1363
|
||||
--error ER_TRG_NO_SUCH_ROW_IN_TRG
|
||||
create trigger trg5b after DELETE on tb3 for each row
|
||||
set new.f122='test';
|
||||
let $message= The above returns the wrong error, should be error 1362 (Bug 11648)
|
||||
--source include/show_msg.inc
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
--disable_warnings
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg5a;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg5b;
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.9.10
|
||||
# Test case: Ensure that the definition of a DELETE trigger can include a reference
|
||||
# Test case: Ensure that the definition of a DELETE trigger can include a reference
|
||||
# to OLD.<column name>.
|
||||
let $message= Testcase 3.5.9.10: (implied in previous tests);
|
||||
--source include/show_msg.inc
|
||||
|
||||
|
||||
#Section 3.5.9.11
|
||||
# Testcase: Ensure that trigger definition that includes a referance to
|
||||
# NEW.<colunm name> fails with an appropriate error message,
|
||||
# Testcase: Ensure that trigger definition that includes a referance to
|
||||
# NEW.<colunm name> fails with an appropriate error message,
|
||||
# at CREATE TRIGGER time, if the trigger event in not INSERT or UPDATE
|
||||
let $message= Testcase 3.5.9.11: covered by 3.5.9.9;
|
||||
--source include/show_msg.inc
|
||||
|
||||
|
||||
#Section 3.5.9.12
|
||||
# Testcase: Ensure that trigger definition that includes a referance to
|
||||
# OLD.<column name> fails with an appropriate error message, at
|
||||
# Testcase: Ensure that trigger definition that includes a referance to
|
||||
# OLD.<column name> fails with an appropriate error message, at
|
||||
# CREATE TRIGGER time, if the trigger event is not DELETE or UPDATE
|
||||
let $message= Testcase 3.5.9.12: covered by 3.5.9.6;
|
||||
--source include/show_msg.inc
|
||||
|
||||
|
||||
#Section 3.5.9.13
|
||||
# Test case: Ensure that all references to OLD. <Column name> are read-only,
|
||||
# Test case: Ensure that all references to OLD. <Column name> are read-only,
|
||||
# that is, that they cannot be used to modify a data row.
|
||||
let $message= Testcase 3.5.9.13:;
|
||||
--source include/show_msg.inc
|
||||
|
||||
--error 1362
|
||||
--error ER_TRG_CANT_CHANGE_ROW
|
||||
create trigger trg6a before UPDATE on tb3 for each row
|
||||
set old.f118='C', new.f118='U';
|
||||
--error 1362
|
||||
--error ER_TRG_CANT_CHANGE_ROW
|
||||
create trigger trg6b after INSERT on tb3 for each row
|
||||
set old.f136=163, new.f118='U';
|
||||
--error 1362
|
||||
--error ER_TRG_CANT_CHANGE_ROW
|
||||
create trigger trg6c after UPDATE on tb3 for each row
|
||||
set old.f136=NULL;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
--error 0, 1360
|
||||
--disable_warnings
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg6a;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg6b;
|
||||
--error 0, 1360
|
||||
--error 0, ER_TRG_DOES_NOT_EXIST
|
||||
drop trigger trg6c;
|
||||
--enable_warnings
|
||||
|
||||
|
||||
#Section 3.5.9.14
|
||||
# Test case: Ensure that all references to NEW. <Column name> may be used both to
|
||||
# Test case: Ensure that all references to NEW. <Column name> may be used both to
|
||||
# read a data row and to modify a data row
|
||||
let $message= Testcase 3.5.9.14: (implied in previous tests);
|
||||
--source include/show_msg.inc
|
||||
|
@ -48,7 +48,7 @@ let $message= Testcase 3.5.10.1/2/3:;
|
||||
Insert into vw11 (f122, f151) values ('Test 3.5.10.1/2/3', 2);
|
||||
Insert into vw11 (f122, f151) values ('Not in View', 3);
|
||||
select f121, f122, f151, f163
|
||||
from tb3 where f122 like 'Test 3.5.10.1/2/3%';
|
||||
from tb3 where f122 like 'Test 3.5.10.1/2/3%' order by f151;
|
||||
select f121, f122, f151, f163 from vw11;
|
||||
select f121, f122, f151, f163
|
||||
from tb3 where f122 like 'Not in View';
|
||||
@ -56,7 +56,7 @@ let $message= Testcase 3.5.10.1/2/3:;
|
||||
#Section 3.5.10.2
|
||||
Update vw11 set f163=1;
|
||||
select f121, f122, f151, f163 from tb3
|
||||
where f122 like 'Test 3.5.10.1/2/3%';
|
||||
where f122 like 'Test 3.5.10.1/2/3%' order by f151;
|
||||
select f121, f122, f151, f163 from vw11;
|
||||
|
||||
#Section 3.5.10.3
|
||||
@ -64,7 +64,7 @@ let $message= Testcase 3.5.10.1/2/3:;
|
||||
Select @test_var as 'before delete';
|
||||
delete from vw11 where f151=1;
|
||||
select f121, f122, f151, f163 from tb3
|
||||
where f122 like 'Test 3.5.10.1/2/3%';
|
||||
where f122 like 'Test 3.5.10.1/2/3%' order by f151;
|
||||
select f121, f122, f151, f163 from vw11;
|
||||
Select @test_var as 'after delete';
|
||||
|
||||
@ -94,11 +94,11 @@ let $message= Testcase 3.5.10.4:;
|
||||
|
||||
set @counter= 0;
|
||||
select @counter as 'Rows Loaded Before';
|
||||
--replace_result $MYSQL_TEST_DIR MYSQL_TEST_DIR
|
||||
eval load data infile '$MYSQL_TEST_DIR/suite/funcs_1/data/t9.txt' into table tb_load;
|
||||
--replace_result $MYSQLTEST_VARDIR <MYSQLTEST_VARDIR>
|
||||
eval load data infile '$MYSQLTEST_VARDIR/std_data_ln/funcs_1/t9.txt' into table tb_load;
|
||||
|
||||
select @counter as 'Rows Loaded After';
|
||||
Select * from tb_load limit 10;
|
||||
Select * from tb_load order by f1 limit 10;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
@ -157,7 +157,7 @@ let $message= Testcase 3.5.10.extra:;
|
||||
|
||||
set @counter=0;
|
||||
select @counter;
|
||||
--error 1329
|
||||
--error ER_SP_FETCH_NO_DATA
|
||||
call trig_sp();
|
||||
select @counter;
|
||||
select count(*) from tb3;
|
||||
@ -233,7 +233,7 @@ let $message= Testcase y.y.y.2: Check for triggers starting triggers;
|
||||
#lock tables t1 write, t2_1 write, t2_2 write, t2_3 write, t2_4 write, t3 write;
|
||||
insert into t1 values (1);
|
||||
#unlock tables;
|
||||
select * from t3;
|
||||
select * from t3 order by f1;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
@ -271,13 +271,13 @@ let $message= Testcase y.y.y.3: Circular trigger reference;
|
||||
create trigger tr4 after insert on t4
|
||||
for each row insert into t1 (f1) values (new.f4+1);
|
||||
|
||||
# OBN See bug 11896
|
||||
--error 1442
|
||||
# Bug#11896 Partial locking in case of recursive trigger definittions
|
||||
--error ER_CANT_UPDATE_USED_TABLE_IN_SF_OR_TRG
|
||||
insert into t1 values (1);
|
||||
select * from t1;
|
||||
select * from t2;
|
||||
select * from t3;
|
||||
select * from t4;
|
||||
select * from t1 order by f1;
|
||||
select * from t2 order by f2;
|
||||
select * from t3 order by f3;
|
||||
select * from t4 order by f4;
|
||||
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
@ -294,7 +294,7 @@ let $message= Testcase y.y.y.3: Circular trigger reference;
|
||||
|
||||
#Section y.y.y.4
|
||||
# Testcase: create recursive trigger/storedprocedures conditions
|
||||
let $message= Testcase y.y.y.4: Recursive trigger/SP references (disabled bug 11889);
|
||||
let $message= Testcase y.y.y.4: Recursive trigger/SP references;
|
||||
--source include/show_msg.inc
|
||||
|
||||
set @sql_mode='traditional';
|
||||
@ -327,7 +327,7 @@ set @sql_mode='traditional';
|
||||
|
||||
set @counter=0;
|
||||
select @counter;
|
||||
--error 1456
|
||||
--error ER_SP_RECURSION_LIMIT
|
||||
call trig_sp();
|
||||
select @counter;
|
||||
select count(*) from tb3;
|
||||
@ -337,7 +337,7 @@ set @sql_mode='traditional';
|
||||
set @@max_sp_recursion_depth= 10;
|
||||
set @counter=0;
|
||||
select @counter;
|
||||
--error 1442
|
||||
--error ER_CANT_UPDATE_USED_TABLE_IN_SF_OR_TRG
|
||||
call trig_sp();
|
||||
select @counter;
|
||||
select count(*) from tb3;
|
||||
@ -381,12 +381,12 @@ let $message= Testcase y.y.y.5: Roleback of nested trigger references;
|
||||
|
||||
set autocommit=0;
|
||||
start transaction;
|
||||
--error 1264
|
||||
--error ER_WARN_DATA_OUT_OF_RANGE
|
||||
insert into t1 values (1);
|
||||
commit;
|
||||
select * from t1;
|
||||
select * from t2;
|
||||
select * from t3;
|
||||
select * from t1 order by f1;
|
||||
select * from t2 order by f2;
|
||||
select * from t3 order by f3;
|
||||
#unlock tables;
|
||||
#Cleanup
|
||||
--disable_warnings
|
||||
|
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user