summaryrefslogtreecommitdiff
path: root/mysql-test/suite/sys_vars/t/completion_type_func.test
blob: 4f1ebf6700bb347f1f91c57e1e8a4a7af55e8d15 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
############## mysql-test\t\completion_type_func.test #########################
#                                                                              #
# Variable Name: completion_type                                               #
# Scope: GLOBAL & SESSION                                                      #
# Access Type: Dynamic                                                         #
# Data Type: Numeric                                                           #
# Default Value: 0                                                             #
# Valid Values: 0,1 & 2                                                        #
#                                                                              #
#                                                                              #
# Creation Date: 2008-03-07                                                    #
# Author:  Salman Rawala                                                       #
#                                                                              #
# Description: Test Cases of Dynamic System Variable "completion_type"         #
#              that checks functinality of this variable                       #
#                                                                              #
# Reference: http://dev.mysql.com/doc/refman/5.1/en/                           #
#          server-system-variables.html#option_mysqld_completion_type          #
#                                                                              #
################################################################################

--source include/have_innodb.inc

--disable_warnings
drop table if exists t1;
--enable_warnings

#########################
#   Creating new table  #
#########################

--echo ## Creating new table ##
CREATE TABLE t1
(
id INT NOT NULL auto_increment,
PRIMARY KEY (id),
name varchar(30)
) ENGINE = INNODB;

--echo '#--------------------FN_DYNVARS_017_01-------------------------#'
#########################################################
#    Setting initial value of completion_type to zero   # 
#########################################################

--echo ## Creating new connection ##
connect (test_con1,localhost,root,,);
connection test_con1;

INSERT into t1(name) values('Record_1');
SET @@autocommit = 0;
SELECT * from t1;

--echo ## Setting value of variable to 0 ##
SET @@session.completion_type = 0;

--echo ## Here commit & rollback should work normally ##
START TRANSACTION;
SELECT * from t1;
INSERT into t1(name) values('Record_2');
INSERT into t1(name) values('Record_3');
SELECT * from t1;
DELETE FROM t1 where id = 2;
SELECT * from t1;


START TRANSACTION;
SELECT * from t1;
INSERT into t1(name) values('Record_4');
INSERT into t1(name) values('Record_5');
COMMIT;


--echo '#--------------------FN_DYNVARS_017_02-------------------------#'
#########################################################
#    Setting initial value of completion_type to 2      # 
#########################################################

SET @@session.completion_type = 2;

--echo ## Here commit should work as COMMIT RELEASE ##
START TRANSACTION;
SELECT * from t1;
INSERT into t1(name) values('Record_6');
INSERT into t1(name) values('Record_7');
COMMIT;

--echo ## Inserting rows should give error here because connection should ##
--echo ## disconnect after using COMMIT ##
--Error 2006,2013,1053
INSERT into t1(name) values('Record_4');

--echo ## Creating new connection test_con2 ##
connect (test_con2,localhost,root,,);
connection test_con2;
SET @@session.completion_type = 2;

--echo ## Inserting rows and using Rollback which should Rollback & release ##
START TRANSACTION;
SELECT * from t1;
INSERT into t1(name) values('Record_8');
INSERT into t1(name) values('Record_9');
ROLLBACK;

--Error 2006,2013,1053
INSERT into t1(name) values('Record_4');