~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to tests/t/key_cache.test

  • Committer: Monty Taylor
  • Date: 2010-02-05 08:11:15 UTC
  • mfrom: (1283 build)
  • mto: (1273.13.43 fix_is)
  • mto: This revision was merged to the branch mainline in revision 1300.
  • Revision ID: mordred@inaugust.com-20100205081115-dr82nvrwv4lvw7sd
Merged trunk.

Show diffs side-by-side

added added

removed removed

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