File: general_log_func.test

package info (click to toggle)
mariadb 1%3A11.8.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, trixie
  • size: 765,428 kB
  • sloc: ansic: 2,382,827; cpp: 1,803,532; asm: 378,315; perl: 63,176; sh: 46,496; pascal: 40,776; java: 39,363; yacc: 20,428; python: 19,506; sql: 17,864; xml: 12,463; ruby: 8,544; makefile: 6,059; cs: 5,855; ada: 1,700; lex: 1,193; javascript: 1,039; objc: 80; tcl: 73; awk: 46; php: 22
file content (102 lines) | stat: -rw-r--r-- 4,108 bytes parent folder | download | duplicates (17)
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
################# mysql-test\t\general_log_func.test ###########################
#                                                                              #
# Variable Name: general_log                                                   #
# Scope: GLOBAL                                                                #
# Access Type: Dynamic                                                         #
# Data Type: Boolean                                                           #
# Default Value: OFF                                                           #
# Valid Values: ON, OFF                                                        #
#                                                                              #
#                                                                              #
# Creation Date: 2008-03-17                                                    #
# Author:  Salman Rawala                                                       #
#                                                                              #
# Description: Test Cases of Dynamic System Variable "general_log"             #
#              that checks functionality of this variable                      #
#                                                                              #
# Reference: http://dev.mysql.com/doc/refman/5.1/en/                           #
#    server-system-variables.html#option_mysqld_general_log                    #
#                                                                              #
################################################################################


--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)
);

--echo '#--------------------FN_DYNVARS_018_01-------------------------#'
####################################################################
#    Setting initial value of general_log to OFF and verifying
#    its behavior
####################################################################

--echo ## Setting initial value of variable to OFF ##
SET @@global.general_log = OFF;
SELECT @@general_log;

let $MYSQLD_LOGFILE= `select @@global.general_log_file`;

#
# truncate the existing log - it could be larger than max_allowed_packet
# and that would cause load_file() below to fail
#
--remove_file $MYSQLD_LOGFILE
flush logs;
SET @@global.general_log = ON;
flush logs;
SET @@global.general_log = OFF;

--copy_file $MYSQLD_LOGFILE $MYSQLD_LOGFILE.copy

--echo ## Inserting some Records & Verifying output in log ##
INSERT into t1(name) values('Record_1');
INSERT into t1(name) values('Record_2');

--echo ## There should be no difference, case should pass ##
--diff_files $MYSQLD_LOGFILE $MYSQLD_LOGFILE.copy
--remove_file $MYSQLD_LOGFILE.copy

--echo '#--------------------FN_DYNVARS_018_01-------------------------#'
####################################################################
#    Setting initial value of general_log to ON and verifying
#    its behavior
####################################################################

--echo ## Setting initial value of variable to OFF ##
SET @@global.general_log = ON;
SELECT @@general_log;

--copy_file $MYSQLD_LOGFILE $MYSQLD_LOGFILE.copy
--chmod 0777 $MYSQLD_LOGFILE.copy

--echo ## Inserting some Records & Verifying output in log ##
INSERT into t1(name) values('Record_3');
INSERT into t1(name) values('Record_4');

--copy_file $MYSQLD_LOGFILE $MYSQLD_LOGFILE.orig
--chmod 0777 $MYSQLD_LOGFILE.orig

--echo ## old log is a proper prefix of the new log ##
--replace_result $MYSQLD_LOGFILE MYSQLD_LOGFILE
eval SET @orig_file= load_file('$MYSQLD_LOGFILE.orig');
--replace_result $MYSQLD_LOGFILE MYSQLD_LOGFILE
eval SET @copy_file= load_file('$MYSQLD_LOGFILE.copy');
SELECT @orig_file > @copy_file, left(@orig_file, length(@copy_file)) = @copy_file;
--remove_file $MYSQLD_LOGFILE.copy
--remove_file $MYSQLD_LOGFILE.orig

--echo ## Dropping tables ##
DROP TABLE t1;