~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to tests/t/key_cache.test

  • Committer: Eric Day
  • Date: 2009-11-10 21:50:22 UTC
  • mto: This revision was merged to the branch mainline in revision 1218.
  • Revision ID: eday@oddments.org-20091110215022-0b2nqmurv7b2l6wo
Duplicated oldlibdrizzle module, one for Drizzle protocol and one for MySQL, per Brian's request from merge proposal. Port options are now --drizzle-protocol-port and --mysql-protocol-port.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#
 
2
# Test of multiple key caches
 
3
#
 
4
--disable_warnings
 
5
drop table if exists t1, t2, t3;
 
6
--enable_warnings
 
7
 
 
8
SET @save_key_buffer=@@key_buffer_size;
 
9
 
 
10
SELECT @@key_buffer_size;
 
11
 
 
12
# Change default key cache size
 
13
SET @@global.key_buffer_size=16*1024*1024;
 
14
 
 
15
# Drop buffer
 
16
SET @@global.key_buffer_size=0;
 
17
# Test double drop
 
18
SET @@global.key_buffer_size=0;
 
19
 
 
20
# Print key buffer with different syntaxes
 
21
SHOW VARIABLES like "key_buffer_size";
 
22
SELECT @@key_buffer_size;
 
23
SELECT @@global.key_buffer_size;
 
24
SELECT @@global.key_buffer_size;
 
25
SELECT @@global.`key_buffer_size`;
 
26
SELECT @@global.`key_buffer_size`;
 
27
SELECT @@key_buffer_size;
 
28
 
 
29
SELECT @@key_buffer_size;
 
30
SELECT @@key_buffer_size;
 
31
 
 
32
SET @@global.key_buffer_size=@save_key_buffer;
 
33
 
 
34
#
 
35
# Errors
 
36
#
 
37
 
 
38
SELECT @@key_buffer_size;
 
39
-- error 1272
 
40
SELECT @@skr.storage_engine="test";
 
41
 
 
42
-- error 1272
 
43
select @@keycache1.key_cache_block_size;
 
44
 
 
45
show status like 'key_blocks_used';
 
46
 
 
47
# Cleanup
 
48
# We don't reset keycache2 as we want to ensure that mysqld will reset it
 
49
set global key_buffer_size=0;
 
50
 
 
51
# Test to set up a too small size for a key cache (bug #2064)
 
52
set global key_buffer_size=100;
 
53
set global key_buffer_size=0;
 
54
 
 
55
# Restore the changed variable value
 
56
-- error 1232
 
57
set global key_cache_block_size= @my_key_cache_block_size;
 
58
 
 
59
#
 
60
# Bug #19079: corrupted index when key_cache_block_size is not multiple of
 
61
#             myisam_block_size
 
62
 
 
63
CREATE temporary TABLE t1(a int NOT NULL AUTO_INCREMENT PRIMARY KEY) ENGINE=MYISAM;
 
64
SET @my_key_cache_block_size= @@global.key_cache_block_size;
 
65
SET GLOBAL key_cache_block_size=1536;
 
66
INSERT INTO t1 VALUES (1);
 
67
SELECT @@key_cache_block_size;
 
68
CHECK TABLE t1;
 
69
DROP TABLE t1;
 
70
 
 
71
CREATE TEMPORARY TABLE t1(a int NOT NULL AUTO_INCREMENT PRIMARY KEY, b int) ENGINE=MYISAM;
 
72
CREATE TEMPORARY TABLE t2(a int NOT NULL AUTO_INCREMENT PRIMARY KEY, b int) ENGINE=MYISAM;
 
73
SET GLOBAL key_cache_block_size=1536;
 
74
INSERT INTO t1 VALUES (1,0);
 
75
INSERT INTO t2(b) SELECT b FROM t1;
 
76
INSERT INTO t1(b) SELECT b FROM t2;
 
77
INSERT INTO t2(b) SELECT b FROM t1;
 
78
INSERT INTO t1(b) SELECT b FROM t2;
 
79
INSERT INTO t2(b) SELECT b FROM t1;
 
80
INSERT INTO t1(b) SELECT b FROM t2;
 
81
INSERT INTO t2(b) SELECT b FROM t1;
 
82
INSERT INTO t1(b) SELECT b FROM t2;
 
83
INSERT INTO t2(b) SELECT b FROM t1;
 
84
INSERT INTO t1(b) SELECT b FROM t2;
 
85
INSERT INTO t2(b) SELECT b FROM t1;
 
86
INSERT INTO t1(b) SELECT b FROM t2;
 
87
INSERT INTO t2(b) SELECT b FROM t1;
 
88
INSERT INTO t1(b) SELECT b FROM t2;
 
89
INSERT INTO t2(b) SELECT b FROM t1;
 
90
INSERT INTO t1(b) SELECT b FROM t2;
 
91
INSERT INTO t2(b) SELECT b FROM t1;
 
92
INSERT INTO t1(b) SELECT b FROM t2;
 
93
SELECT COUNT(*) FROM t1;
 
94
SELECT @@key_cache_block_size;
 
95
CHECK TABLE t1;
 
96
DROP TABLE t1,t2;
 
97
# Restore changed variables
 
98
set global key_cache_block_size= @my_key_cache_block_size;
 
99
 
 
100
#
 
101
# Bug#10473 - Can't set 'key_buffer_size' system variable to ZERO
 
102
# (One cannot drop the default key cache.)
 
103
#
 
104
set @@global.key_buffer_size=0;
 
105
select @@global.key_buffer_size;
 
106
 
 
107
#
 
108
# Bug#28478 - Improper key_cache_block_size corrupts MyISAM tables
 
109
#
 
110
SET @bug28478_key_cache_block_size= @@global.key_cache_block_size;
 
111
SET GLOBAL key_cache_block_size= 1536;
 
112
CREATE TEMPORARY TABLE t1 (
 
113
  id BIGINT NOT NULL AUTO_INCREMENT PRIMARY KEY,
 
114
  c1 CHAR(50),
 
115
  c2 CHAR(50),
 
116
  c3 CHAR(50),
 
117
  KEY(c1, c2, c3)
 
118
  ) ENGINE= MyISAM;
 
119
INSERT INTO t1 (c1, c2, c3) VALUES
 
120
  ('a', 'b', 'c'), ('b', 'c', 'd'), ('c', 'd', 'e'), ('d', 'e', 'f'),
 
121
  ('e', 'f', 'g'), ('f', 'g', 'h'), ('g', 'h', 'i'), ('h', 'i', 'j'),
 
122
  ('i', 'j', 'k'), ('j', 'k', 'l'), ('k', 'l', 'm'), ('l', 'm', 'n'),
 
123
  ('m', 'n', 'o'), ('n', 'o', 'p'), ('o', 'p', 'q'), ('p', 'q', 'r'),
 
124
  ('q', 'r', 's'), ('r', 's', 't'), ('s', 't', 'u'), ('t', 'u', 'v'),
 
125
  ('u', 'v', 'w'), ('v', 'w', 'x'), ('w', 'x', 'y'), ('x', 'y', 'z');
 
126
CREATE TABLE t2 AS SELECT * FROM t1;
 
127
INSERT INTO t1 (c1, c2, c3) SELECT c1, c2, c3 from t2;
 
128
INSERT INTO t1 (c1, c2, c3) SELECT c1, c2, c3 from t2;
 
129
INSERT INTO t1 (c1, c2, c3) SELECT c1, c2, c3 from t2;
 
130
CHECK TABLE t1;
 
131
SHOW VARIABLES LIKE 'key_cache_block_size';
 
132
SET GLOBAL key_cache_block_size= @bug28478_key_cache_block_size;
 
133
DROP TABLE t1,t2;
 
134
 
 
135
# End of 4.1 tests