Commit 9b897d66 authored by Elena Stepanova's avatar Elena Stepanova

MDEV-12263 Feature: skipped test file

A note about unstable-tests lists in mysql-test/README, RedHat
version of it, and also various changes to bring the file
up-to-date
parent ca948e33
This directory contains a test suite for the MySQL daemon. To run This directory contains test suites for the MariaDB server. To run
the currently existing test cases, simply execute ./mysql-test-run in currently existing test cases, execute ./mysql-test-run in this directory.
this directory. It will fire up the newly built mysqld and test it.
Note that you do not have to have to do "make install", and you could Some tests are known to fail on some platforms or be otherwise unreliable.
actually have a co-existing MySQL installation. The tests will not The file "unstable-tests" contains the list of such tests along with
conflict with it. To run the test suite in a source directory, you a comment for every test.
must do make first. To exclude them from the test run, execute
# ./mysql-test-run --skip-test-list=unstable-tests
All tests must pass. If one or more of them fail on your system, please In general you do not have to have to do "make install", and you can have
read the following manual section for instructions on how to report the a co-existing MariaDB installation, the tests will not conflict with it.
problem: To run the tests in a source directory, you must do "make" first.
In Red Hat distributions, you should run the script as user "mysql".
The user is created with nologin shell, so the best bet is something like
# su -
# cd /usr/share/mysql-test
# su -s /bin/bash mysql -c "./mysql-test-run --skip-test-list=rh-skipped-tests.list"
This will use the installed MariaDB executables, but will run a private copy
of the server process (using data files within /usr/share/mysql-test),
so you need not start the mysqld service beforehand.
"rh-skipped-tests.list" is Red Hat version of unstable-tests list, it
additionally includes tests known to fail specifically on Red Hat builds.
You can omit it if you want to check whether such failures occur for you.
To clean up afterwards, remove the created "var" subdirectory, e.g.
# su -s /bin/bash - mysql -c "rm -rf /usr/share/mysql-test/var"
If one or more tests fail on your system on reasons other than listed
in lists of unstable tests, please read the following manual section
for instructions on how to report the problem:
https://mariadb.com/kb/en/reporting-bugs https://mariadb.com/kb/en/reporting-bugs
If you want to use an already running MySQL server for specific tests, If you want to use an already running MySQL server for specific tests,
use the --extern option to mysql-test-run. Please note that in this mode, use the --extern option to mysql-test-run. Please note that in this mode,
the test suite expects you to provide the names of the tests to run. you are expected to provide names of the tests to run.
For example, here is the command to run the "alias" and "analyze" tests For example, here is the command to run the "alias" and "analyze" tests
with an external server: with an external server:
mysql-test-run --extern socket=/tmp/mysql.sock alias analyze # mysql-test-run --extern socket=/tmp/mysql.sock alias analyze
To match your setup, you might also need to provide --socket, --user, and To match your setup, you might need to provide other relevant options.
other relevant options.
With no test cases named on the command line, mysql-test-run falls back With no test names on the command line, mysql-test-run will attempt
to the normal "non-extern" behavior. The reason for this is that some to execute the default set of tests, which will certainly fail, because
tests cannot run with an external server. many tests cannot run with an external server (they need to control the
options with which the server is started, restart the server during
execution, etc.)
You can create your own test cases. To create a test case, create a new You can create your own test cases. To create a test case, create a new
file in the t subdirectory using a text editor. The file should have a .test file in the t subdirectory using a text editor. The file should have a .test
extension. For example: extension. For example:
xemacs t/test_case_name.test # xemacs t/test_case_name.test
In the file, put a set of SQL statements that create some tables, In the file, put a set of SQL statements that create some tables,
load test data, and run some queries to manipulate it. load test data, and run some queries to manipulate it.
We would appreciate it if you name your test tables t1, t2, t3 ... (to not Your test should begin by dropping the tables you are going to create and
conflict too much with existing tables). end by dropping them again. This ensures that you can run the test over
and over again.
Your test should begin by dropping the tables you are going to create and If you are using mysqltest commands in your test case, you should create
end by dropping them again. This ensures that you can run the test over the result file as follows:
and over again.
If you are using mysqltest commands (like result file names) in your
test case, you should create the result file as follows:
mysql-test-run --record test_case_name # mysql-test-run --record test_case_name
or or
mysqltest --record < t/test_case_name.test # mysqltest --record < t/test_case_name.test
If you only have a simple test cases consisting of SQL statements and If you only have a simple test case consisting of SQL statements and
comments, you can create the test case in one of the following ways: comments, you can create the result file in one of the following ways:
mysql-test-run --record test_case_name # mysql-test-run --record test_case_name
mysql test < t/test_case_name.test > r/test_case_name.result # mysql test < t/test_case_name.test > r/test_case_name.result
mysqltest --record --database test --result-file=r/test_case_name.result < t/test_case_name.test # mysqltest --record --database test --result-file=r/test_case_name.result < t/test_case_name.test
When this is done, take a look at r/test_case_name.result When this is done, take a look at r/test_case_name.result .
- If the result is incorrect, you have found a bug. In this case, you should If the result is incorrect, you have found a bug. In this case, you should
edit the test result to the correct results so that we can verify edit the test result to the correct results so that we can verify that
that the bug is corrected in future releases. the bug is corrected in future releases.
If you want to submit your test case you can send it If you want to submit your test case you can send it
to maria-developers@lists.launchpad.com or attach it to a bug report on to maria-developers@lists.launchpad.net or attach it to a bug report on
http://mariadb.org/jira/. http://mariadb.org/jira/.
If the test case is really big or if it contains 'not public' data, If the test case is really big or if it contains 'not public' data,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment