summaryrefslogtreecommitdiff
path: root/mysql-test/xml/README
blob: ee1af30db33e0152ee049c133b1c90a7d42edc36 (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
68
69
70
71
72
73
74
This directory contains all of the test cases for the MySQL Test Suite
marked up in XML.

To convert these test cases from XML into 'mysqltest' format, one needs
an XSL translator installed on their system. At MySQL, we use Sablotron
(http://www.gingerall.com/). Once installed, conversion happens with a 
command like this:

	sabcmd xsl/mysqltest.xsl < tests/sel000001.xml > sel000001.test

The file 'sel000001.test' contains the plain text conversion that is
to be fed into the 'mysqltest' program.

Below is an example of a test case marked up in XML; illustrating all
of the XML mark-up currently supported in our 'mysqltest.xsl' stylesheet.

----------------------------------------------------
<?xml version="1.0" standalone="no"?>

<!-- This file is maintained by matt@mysql.com -->

<test name="sel000001">

   <version value="3.22"/>
   <version value="3.23"/>

   <description>This test will monkey around trying to kill mysqld.</description>

   <connect name="Test_Connect1"
            host="MyHostName"
            user="Matt"
            pass="MattPass"
              db="MyDB"
            port="3306"
            sock="MyDB.sock"
    />

    <connection name="Test_Connect1">
       <resultfile name="sel000001.result">
           <sql>SELECT y FROM foo WHERE bar='2'</sql>
        </resultfile>
           <sql>INSERT INTO foo  VALUES (y='2') WHERE bar='1'</sql> 
    </connection>

</test>
----------------------------------------------------


The converted (mysqltest format) output of this source XML file looks
like:

 
----------------------------------------------------
# sel000001
#
# Versions
# --------
#   3.22
#   3.23
#
# Description
# -----------
# This test will monkey around trying to kill mysqld.
#


connect(Test_Connect1, MyHostName, Matt, MattPass, MyDB, 3306, MyDB.sock)

connection Test_Connect1
INSERT INTO foo  VALUES (y='2') WHERE bar='1';
@sel000001.result SELECT y FROM foo WHERE bar='2';
----------------------------------------------------