~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to plugin/innobase/tests/t/innodb-system-table-view.test

[patch 106/129] Merge patch for revision 1915 from InnoDB SVN:
revno: 1915
revision-id: svn-v4:16c675df-0fcb-4bc9-8058-dcc011a37293:branches/zip:6130
parent: svn-v4:16c675df-0fcb-4bc9-8058-dcc011a37293:branches/zip:6126
committer: marko
timestamp: Mon 2009-11-02 09:42:56 +0000
message:
  branches/zip: Free all resources at shutdown. Set pointers to NULL, so
  that Valgrind will not complain about freed data structures that are
  reachable via pointers.  This addresses Bug #45992 and Bug #46656.
  
  This patch is mostly based on changes copied from branches/embedded-1.0,
  mainly c5432, c3439, c3134, c2994, c2978, but also some other code was
  copied.  Some added cleanup code is specific to MySQL/InnoDB.
  
  rb://199 approved by Sunny Bains
modified:
  ChangeLog                      2425@16c675df-0fcb-4bc9-8058-dcc011a37293:branches%2Fzip%2FChangeLog
  btr/btr0sea.c                  2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fbtr%2Fbtr0sea.c
  buf/buf0buf.c                  2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fbuf%2Fbuf0buf.c
  dict/dict0dict.c               2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fdict%2Fdict0dict.c
  fil/fil0fil.c                  2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Ffil%2Ffil0fil.c
  ibuf/ibuf0ibuf.c               2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fibuf%2Fibuf0ibuf.c
  include/btr0sea.h              2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Fbtr0sea.h
  include/dict0dict.h            2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Fdict0dict.h
  include/fil0fil.h              2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Ffil0fil.h
  include/ibuf0ibuf.h            2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Fibuf0ibuf.h
  include/lock0lock.h            2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Flock0lock.h
  include/log0log.h              2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Flog0log.h
  include/log0recv.h             2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Flog0recv.h
  include/mem0mem.h              2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Fmem0mem.h
  include/mem0pool.h             2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Fmem0pool.h
  include/os0file.h              2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Fos0file.h
  include/pars0pars.h            2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Fpars0pars.h
  include/srv0srv.h              2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Fsrv0srv.h
  include/thr0loc.h              2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Fthr0loc.h
  include/trx0i_s.h              1864@16c675df-0fcb-4bc9-8058-dcc011a37293:branches%2Fzip%2Finclude%2Ftrx0i_s.h
  include/trx0purge.h            2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Ftrx0purge.h
  include/trx0rseg.h             2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Ftrx0rseg.h
  include/trx0sys.h              2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Ftrx0sys.h
  include/trx0undo.h             2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Ftrx0undo.h
  include/usr0sess.h             2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Finclude%2Fusr0sess.h
  lock/lock0lock.c               2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Flock%2Flock0lock.c
  log/log0log.c                  2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Flog%2Flog0log.c
  log/log0recv.c                 2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Flog%2Flog0recv.c
  mem/mem0dbg.c                  2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fmem%2Fmem0dbg.c
  mem/mem0pool.c                 2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fmem%2Fmem0pool.c
  os/os0file.c                   2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fos%2Fos0file.c
  os/os0sync.c                   2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fos%2Fos0sync.c
  os/os0thread.c                 2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fos%2Fos0thread.c
  pars/lexyy.c                   2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fpars%2Flexyy.c
  pars/pars0lex.l                2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fpars%2Fpars0lex.l
  que/que0que.c                  2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fque%2Fque0que.c
  srv/srv0srv.c                  2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fsrv%2Fsrv0srv.c
  srv/srv0start.c                2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fsrv%2Fsrv0start.c
  sync/sync0arr.c                2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fsync%2Fsync0arr.c
  sync/sync0sync.c               2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fsync%2Fsync0sync.c
  thr/thr0loc.c                  2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fthr%2Fthr0loc.c
  trx/trx0i_s.c                  1864@16c675df-0fcb-4bc9-8058-dcc011a37293:branches%2Fzip%2Ftrx%2Ftrx0i_s.c
  trx/trx0purge.c                2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Ftrx%2Ftrx0purge.c
  trx/trx0rseg.c                 2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Ftrx%2Ftrx0rseg.c
  trx/trx0sys.c                  2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Ftrx%2Ftrx0sys.c
  trx/trx0undo.c                 2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Ftrx%2Ftrx0undo.c
  usr/usr0sess.c                 2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fusr%2Fusr0sess.c
  ut/ut0mem.c                    2@16c675df-0fcb-4bc9-8058-dcc011a37293:trunk%2Fut%2Fut0mem.c
diff:
=== modified file 'ChangeLog'

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# This is the test for Information Schema System Table View
2
 
# that displays the InnoDB system table content through
3
 
# information schema tables.
4
 
 
5
 
--source include/have_innodb.inc
6
 
 
7
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_TABLES;
8
 
 
9
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_INDEXES;
10
 
 
11
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_COLUMNS;
12
 
 
13
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_FIELDS;
14
 
 
15
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_FOREIGN;
16
 
 
17
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_FOREIGN_COLS;
18
 
 
19
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_TABLESTATS;
20
 
 
21
 
# Create a foreign key constraint, and verify the information
22
 
# in DATA_DICTIONARY.INNODB_SYS_FOREIGN and
23
 
# DATA_DICTIONARY.INNODB_SYS_FOREIGN_COLS
24
 
CREATE TABLE parent (id INT NOT NULL,
25
 
                     PRIMARY KEY (id)) ENGINE=INNODB;
26
 
 
27
 
CREATE TABLE child (id INT, parent_id INT,
28
 
                    INDEX par_ind (parent_id),
29
 
                    CONSTRAINT constraint_test
30
 
                    FOREIGN KEY (parent_id) REFERENCES parent(id)
31
 
                      ON DELETE CASCADE) ENGINE=INNODB;
32
 
 
33
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_FOREIGN;
34
 
 
35
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_FOREIGN_COLS;
36
 
 
37
 
# Insert a row in the table "parent", and see whether that reflected in
38
 
# INNODB_SYS_TABLESTATS
39
 
INSERT INTO parent VALUES(1);
40
 
 
41
 
SELECT name, num_rows, handles_opened
42
 
FROM DATA_DICTIONARY.INNODB_SYS_TABLESTATS
43
 
WHERE name LIKE "%parent";
44
 
 
45
 
SELECT NAME, FLAG, N_COLS, SPACE FROM DATA_DICTIONARY.INNODB_SYS_TABLES;
46
 
 
47
 
SELECT name, n_fields
48
 
from DATA_DICTIONARY.INNODB_SYS_INDEXES
49
 
WHERE table_id In (SELECT table_id from
50
 
        DATA_DICTIONARY.INNODB_SYS_TABLES
51
 
        WHERE name LIKE "%parent%");
52
 
 
53
 
SELECT name, n_fields
54
 
from DATA_DICTIONARY.INNODB_SYS_INDEXES
55
 
WHERE table_id In (SELECT table_id from
56
 
        DATA_DICTIONARY.INNODB_SYS_TABLES
57
 
        WHERE name LIKE "%child%");
58
 
 
59
 
SELECT name, pos, mtype, len
60
 
from DATA_DICTIONARY.INNODB_SYS_COLUMNS
61
 
WHERE table_id In (SELECT table_id from
62
 
        DATA_DICTIONARY.INNODB_SYS_TABLES
63
 
        WHERE name LIKE "%child%");
64
 
 
65
 
DROP TABLE child;
66
 
 
67
 
DROP TABLE parent;
68
 
 
69
 
# Create table with 2 columns in the foreign key constraint
70
 
CREATE TABLE parent (id INT NOT NULL, newid INT NOT NULL,
71
 
                     PRIMARY KEY (id, newid)) ENGINE=INNODB;
72
 
 
73
 
CREATE TABLE child (id INT, parent_id INT,
74
 
                    INDEX par_ind (parent_id),
75
 
                    CONSTRAINT constraint_test
76
 
                    FOREIGN KEY (id, parent_id) REFERENCES parent(id, newid)
77
 
                      ON DELETE CASCADE) ENGINE=INNODB;
78
 
 
79
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_FOREIGN;
80
 
 
81
 
SELECT * FROM DATA_DICTIONARY.INNODB_SYS_FOREIGN_COLS;
82
 
 
83
 
INSERT INTO parent VALUES(1, 9);
84
 
 
85
 
# Nested query will open the table handle twice
86
 
SELECT * FROM parent WHERE id IN (SELECT id FROM parent);
87
 
 
88
 
SELECT name, num_rows, handles_opened
89
 
FROM DATA_DICTIONARY.INNODB_SYS_TABLESTATS
90
 
WHERE name LIKE "%parent";
91
 
 
92
 
DROP TABLE child;
93
 
 
94
 
DROP TABLE parent;