summaryrefslogtreecommitdiff
path: root/mysql-test/t/mysqld--help.test
blob: e6499957cd2202705135797383884850c0b74fda (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
#
# mysqld --help
#
--source include/not_embedded.inc
--source include/have_perfschema.inc
--source include/platform.inc

#
# force lower-case-table-names=1 (linux/macosx have different defaults)
# force symbolic-links=0 (valgrind build has a different default)
#

exec $MYSQLD_BOOTSTRAP_CMD --symbolic-links=0 --lower-case-table-names=1 --help --verbose > $MYSQL_TMP_DIR/mysqld--help.txt 2>&1;

# The inline perl code below will copy $MYSQL_TMP_DIR/mysqld--help.txt
# to output, but filter away some variable stuff (e.g. paths).

perl;
  # Variables which we don't want to display in the result file since
  # their paths may vary:
  @skipvars=qw/basedir open-files-limit general-log-file log plugin-dir
               log-slow-queries pid-file slow-query-log-file log-basename
               datadir slave-load-tmpdir tmpdir socket thread-pool-size
               large-files-support lower-case-file-system system-time-zone
               collation-server character-set-server log-tc-size version.*/;

  # Plugins which may or may not be there:
  @plugins=qw/innodb archive blackhole federated partition
              feedback debug temp-pool ssl des-key-file xtradb sequence
              thread-concurrency super-large-pages mutex-deadlock-detector
              connect null-audit aria oqgraph sphinx thread-handling
              test-sql-discovery rpl-semi-sync query-cache-info
              query-response-time metadata-lock-info locales unix-socket
              wsrep file-key-management cracklib-password-check user-variables/;

  # And substitute the content some environment variables with their
  # names:
  @env=qw/MYSQLTEST_VARDIR MYSQL_TEST_DIR MYSQL_CHARSETSDIR MYSQL_SHAREDIR/;

  $re1=join('|', @skipvars, @plugins);
  $re2=join('|', @plugins);
  $skip=0;
  open(F, '<', "$ENV{MYSQL_TMP_DIR}/mysqld--help.txt") or die;
  while (<F>) {
    next if 1../The following groups are read/;
    # formatting, skip line consisting entirely of dashes and blanks
    next if /^[\- ]+\s?$/;
    next if /Value \(after reading options\)/; # skip table header
    next if /^($re1) /;
    next if /^($re2)-/;
    $skip=0 if /^  -/ or /^$/;
    $skip=1 if / --($re2)\b/;
    y!\\!/!;
    s/[ ]+/ /; # squeeze spaces to remove table formatting
    # fixes for 32-bit
    s/\b4294967295\b/18446744073709551615/;
    s/\b2146435072\b/9223372036853727232/;
    s/\b196608\b/262144/;
    s/\b4294963200\b/18446744073709547520/;
    foreach $var (@env) { s/\Q$ENV{$var}\E/$var/ }
    next if /use --skip-(use-)?symbolic-links to disable/; # for valgrind, again
    next if $skip;
    print;
  }
  close F;
EOF