fpc/tests/utils
2025-03-09 10:55:49 +01:00
..
avx * patch by lag programming to replace bitcnt by popcnt, resolves #40962 2024-10-22 22:54:57 +02:00
dosbox Add DosExitCode to DosError shl 16 to set ExitCode value in utils/dosbox/exitcode.pas program 2024-11-06 22:21:22 +00:00
macos
testsuite * Correction for creating maps 2025-03-09 10:55:49 +01:00
unittests * Reworked testsuite database 2025-01-25 20:29:31 +01:00
variants
bench.pp
concat.pp
createlst.pp
dbadd.lpi * Reworked testsuite database 2025-01-25 20:29:31 +01:00
dbadd.lpr * Reworked testsuite database 2025-01-25 20:29:31 +01:00
dbdigest.lpi * Reworked testsuite database 2025-01-25 20:29:31 +01:00
dbdigest.pp Add help for -Q/--sql option 2025-03-04 21:04:43 +00:00
digest.pp * Reworked testsuite database 2025-01-25 20:29:31 +01:00
digestanalyst.pas * Try to handle mixed separation/output lines 2025-03-02 12:13:56 +01:00
dotest.pp * fix dotest.pp after the wasi->wasip1 rename and the addition of wasip1threads 2025-02-28 15:12:21 +02:00
drop_testsuite.sql * Reworked testsuite database 2025-01-25 20:29:31 +01:00
fail.pp Allow to pass antoher exitcode to fail utility by command line first parameter 2024-08-30 22:57:56 +02:00
fptime.pp
fpts2junit.pp fpts2junit: prevent double entries in junit xml (in test log are double entries, one for compiles, one for runs) 2021-08-06 17:41:51 +01:00
gparmake.pp Use seplog name for separate chunck output file 2024-08-30 22:57:57 +02:00
libtar.pas
Makefile * regen makefiles 2025-02-28 15:12:20 +02:00
Makefile.fpc * Reworked testsuite database 2025-01-25 20:29:31 +01:00
prepup.pp
README.md * threadlist -> tasklist 2025-03-02 11:48:52 +01:00
redir.pp Add try/except block inside try/finally block in ExecuteRedir function 2024-10-01 14:03:01 -07:00
testfail.pp
testsuite.sql * Make CPU/OS/Version fields longer 2025-03-09 10:55:49 +01:00
tsdb.pp Add missing SQL queries 2025-03-04 21:58:50 +00:00
tsstring.pp * Reworked testsuite database 2025-01-25 20:29:31 +01:00
tstypes.pp * Remove extra spaces in field names 2025-03-02 11:44:03 +01:00
tsutils.pp * typo fixed 2025-01-26 23:00:48 +01:00

DBDigest tool.

Configuration

There are 2 kinds of configuration data for DBDigest.

  • global configuration
  • Test run data

Global configuration

This includes database configuration and run mode. the database configuration can be specified in 3 different ways:

  • in the global /etc/dbdigest.ini
  • the dbigest.cfg run file (deprecated)
  • the command-line. (deprecated)

The global file is read first, if it exists. The dbdigest.cfg file is read next, and the command-line options are list:

The recommended way is to put it in the global config file, which has the following format (the values are examples):

[Database]
Name=testsuite
Host=localhost
username=user
password=secret
port=5432

In the 'dbdigest.cfg' file, the format is backwards-compatible:

databasename=NAME
host=HOST
password=PWD
username=USER

On the command-line the options are:

  -d --databasename=NAME            database name
  -h --host=HOST                    database hostname
  -p --password=PWD                 database user password
  -P --port=NNN                     database connection port
  -u --username=USER                database user name

Other than the database connection, the following global options can be given:

  • -r --relsrcdir=DIR the relative source dir for getting test files.
  • -S --testsrcdir=DIR the absolute test source dir
  • -T --tasklist=FILE file with configuration file names to import.
  • -j --taskcount=N Maximum number of threads to use when importing.
  • -V --verbose be more verbose (writes lots of debug info)
  • -f --config=FILENAME in case a single digest file is imported, the name of the config file. If not set, dbdigest.cfg is used.

If the -T --tasklist option is given, then -f/--config is ignored: no default file will be read. Only the files in the threadlist file will be treated.

Example of a thread list file (mytests.lst):

2025-05-01-i386/gcc-dbdigest.cfg
2025-05-01-arm/llvm-dbdigest.cfg

The logfile and longlogfile will be treated as relative to the dbdigest.cfg files if they are relative filenames. If they are absolute filenames, they're used as-is.

Test Run data

Run data describes one test run: basically, one dbdigest.cfg. For a single test run, the dbdigest.cfg file is read and the command-line options are examined to compose all data for a test run.

  • -l --logfile=FILE set log file to analyse
  • -L --longlogfile=FILE set long log filename (logs of run tests)
  • -o --os=OS set OS for testrun
  • -c --cpu=CPU set CPU
  • -a --category=CAT set category
  • -v --version=VER set compiler version
  • -t --date=DATE date in YYYMMDD(hhmmnn) format (only the date part is retained)
  • -s --submitter=NAME submitter name
  • -m --machine=NAME set machine name on which testsuite was run
  • -C --compile-flags=FLAGS set used compilation flags
  • --comment=FLAGS backwards compatible way to set compilation flags (deprecated)
  • -D --description=DESC set config description (helpful comment)
  • --compilerdate=DATE set compiler date
  • --compilerfullversion=VERSION set full compiler version
  • --svncompilerrevision=REV set revision of used compiler
  • --svntestsrevision=REV set revision of testsuite files
  • --svnrtlrevision=REV set revision of RTL
  • --svnpackagesrevision=REV set revison of packages

The preferred way to specify the options is in a dbdigest.cfg file. The name of this file is settable using the -f or --config command-line option.

The dbdigest.cfg accepts all long versions of the command-line options, and you can specify comments using the usual # sign.

Examples

Import data from a single testrun, with testrun data in mytest.cfg:

dbdigest -f mytest.lst

The database connection data will be read from the global configuration.

Import data from a list of testruns in mytests.lst (4 threads):

dbdigest -T mytests.lst

Import data from a list of testruns in mytests.lst (8 threads):

dbdigest -T mytests.lst -j 8

DBAdd tool.

To add new CPUs or OSes to the database, use the dbadd tool. It will use the global dbdigest.ini file to connect to the database, and will add the new record in the appropriate table. The tool accepts 3 command-line options:

  • -t --type=TYPE where TYPE is one of os, cpu, category or version
  • -v --value=value the value to add
  • -d --date=YYYYMMDD only used when adding a version: the release date of the version (if not specified, today is used).

Test definitions are added automatically during import.