Testing should follow that workflow :
- First build a MSSQL Server
- Create the server (local, container, VM or azure)
- Create a testing database with a proper user and access privileges
- Run
mssql-tests.py
against that server.
- Next, build a PostgreSQL Server
- Create the server (on your machine, with docker o rVM)
- Compile and install
tds_fdw
extension - Create a testing database and schema with proper user and access privilege
- On that database you'll have first to install
tds_fdw
:CREATE EXTENSION tds_fdw;
- You can run
postgresql_test.py
It may be interesting to build a full setup for debugging purpose and use tests to check if anythong regresses.
For this, you can use --debugging
parameter at postgresql-tests.py
launch time.
The test program will stop just after connection creation and give you the backend PID used for testing. This will allow you to connect gdb in another shell session (gdb --pid=<PID>
). Once connected with gdb, just put breakpoints where you need and run cont
. Then you can press any key in the test shell script to start testing.
Also, in case of test failure, --debugging
will allow to define quite precisely where the script crashed using psycopg2 Diagnostics
class information and will give the corresponding SQL injected in PostgreSQL.
There are two folders where tests are added:
tests/mssql
contains the tests to interact with a MSSQL server usingmssql-tests.py
. Such tests are, normally, used to create stuff required for the PostgreSQL test themselves.tests/postgresql
contains the test to interact with a PostgreSQL server usingpostgresql-tests.py
. Such tests are, normally, used to test thetds_fdw
functionalities.
Each test is made up of two files, with the same name and different extension in this format:
XXX_description
For example: 000_my_test.json
and 000_my_test.sql
.
Rule1: XXX
is used to provide an order to the scripts.
Rule2: If a script creates an item, or adds a row, it must assume that such item or row exists already, and handle it (for example dropping the table before creating it)
Always has the following format:
{
"test_desc" : "<My description>",
"server" : {
"version" : {
"min" : "<Min.Required.Ver>",
"max" : "<Max.Supported.Ver>"
}
}
}
test_desc
can be any arbitrary string describing the test.min
andmax
are version the for matX.W[.Y[.Z]]
for MSSQL and PostgreSQL respectively.min
is mandatory, as minimum7.0.623
for MSSQL (MSSQL 7.0 RTM) and9.2.0
for PostgreSQL.max
is also mandatory, but it can be an empty string if the test supports up to the most recent MSSQL or PostgreSQL version.
You can check the list of versions for MSSQL (format X.Y.Z
and X.Y.W.Z
), PostgreSQL (formats X.Y.Z
and X.Y
), to adjust the min
and max
values as needed.
It is a regular SQL file for one or more queries for either MSSQL or PostgreSQL.
There are several variables that can be used and will be placed by the testing scripts.
For the MSSQL scripts, the values come from the mssql-tests.py
parameters:
@SCHEMANAME
: The MSSQL schema name.
For the PostgreSQL scripts the values come from the postgresql-tests.py
parameters:
@PSCHEMANAME
: The PostgreSQL schema name@PUSER
: The PostgreSQL user@MSERVER
: The MSSQL Server@MPORT
: The MSSQL port@MUSER
: The MSSQL user@MPASSWORD
: The MSSQL password@MDATABASE
: The MSSQL database@MSCHEMANAME
: The MSSQL schema name@TDSVERSION
: The TDS version