2022-06-14 16:22:56 +08:00
|
|
|
<!--
|
|
|
|
Copyright (C) 1998 - 2022 Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
|
|
|
|
|
|
SPDX-License-Identifier: curl
|
|
|
|
-->
|
|
|
|
|
2020-09-30 21:12:06 +08:00
|
|
|
# Unit tests
|
2011-01-04 06:47:13 +08:00
|
|
|
|
2020-09-30 21:12:06 +08:00
|
|
|
The goal is to add tests for *all* functions in libcurl. If functions are too
|
2011-01-04 06:47:13 +08:00
|
|
|
big and complicated, we should split them into smaller and testable ones.
|
|
|
|
|
2020-09-30 21:12:06 +08:00
|
|
|
## Build Unit Tests
|
2011-01-04 06:47:13 +08:00
|
|
|
|
2020-09-30 21:12:06 +08:00
|
|
|
`./configure --enable-debug` is required for the unit tests to build. To
|
2011-01-04 06:47:13 +08:00
|
|
|
enable unit tests, there will be a separate static libcurl built that will be
|
|
|
|
used exclusively for linking unit test programs. Just build everything as
|
|
|
|
normal, and then you can run the unit test cases as well.
|
|
|
|
|
2020-09-30 21:12:06 +08:00
|
|
|
## Run Unit Tests
|
2011-01-04 06:47:13 +08:00
|
|
|
|
|
|
|
Unit tests are run as part of the regular test suite. If you have built
|
|
|
|
everything to run unit tests, to can do 'make test' at the root level. Or you
|
2020-09-30 21:12:06 +08:00
|
|
|
can `cd tests` and `make` and then invoke individual unit tests with
|
|
|
|
`./runtests.pl NNNN` where `NNNN` is the specific test number.
|
2011-01-04 06:47:13 +08:00
|
|
|
|
2020-09-30 21:12:06 +08:00
|
|
|
## Debug Unit Tests
|
2011-01-04 06:47:13 +08:00
|
|
|
|
|
|
|
If a specific test fails you will get told. The test case then has output left
|
|
|
|
in the log/ subdirectory, but most importantly you can re-run the test again
|
2020-09-30 21:12:06 +08:00
|
|
|
using gdb by doing `./runtests.pl -g NNNN`. That is, add a `-g` to make it
|
|
|
|
start up gdb and run the same case using that.
|
2011-01-04 06:47:13 +08:00
|
|
|
|
2020-09-30 21:12:06 +08:00
|
|
|
## Write Unit Tests
|
2011-01-04 06:47:13 +08:00
|
|
|
|
|
|
|
We put tests that focus on an area or a specific function into a single C
|
|
|
|
source file. The source file should be named 'unitNNNN.c' where NNNN is a
|
2020-09-30 21:12:06 +08:00
|
|
|
previously unused number.
|
2011-01-04 06:47:13 +08:00
|
|
|
|
2022-09-19 23:30:30 +08:00
|
|
|
Add your test to `tests/unit/Makefile.inc` (if it is a unit test). Add your
|
2020-09-30 21:12:06 +08:00
|
|
|
test data file name to `tests/data/Makefile.inc`
|
2019-09-14 09:16:09 +08:00
|
|
|
|
2020-09-30 21:12:06 +08:00
|
|
|
You also need a separate file called `tests/data/testNNNN` (using the same
|
2011-01-04 06:47:13 +08:00
|
|
|
number) that describes your test case. See the test1300 file for inspiration
|
2020-09-30 21:12:06 +08:00
|
|
|
and the `tests/FILEFORMAT.md` documentation.
|
2011-01-04 06:47:13 +08:00
|
|
|
|
2022-09-19 23:30:30 +08:00
|
|
|
For the actual C file, here's a simple example:
|
2020-09-30 21:12:06 +08:00
|
|
|
~~~c
|
2011-05-25 03:23:52 +08:00
|
|
|
#include "curlcheck.h"
|
2011-01-04 06:47:13 +08:00
|
|
|
|
|
|
|
#include "a libcurl header.h" /* from the lib dir */
|
|
|
|
|
2019-09-14 09:16:09 +08:00
|
|
|
static CURLcode unit_setup( void )
|
2011-01-04 06:47:13 +08:00
|
|
|
{
|
|
|
|
/* whatever you want done first */
|
2019-09-14 09:16:09 +08:00
|
|
|
return CURLE_OK;
|
2011-01-04 06:47:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static void unit_stop( void )
|
|
|
|
{
|
|
|
|
/* done before shutting down and exiting */
|
|
|
|
}
|
|
|
|
|
|
|
|
UNITTEST_START
|
|
|
|
|
|
|
|
/* here you start doing things and checking that the results are good */
|
|
|
|
|
|
|
|
fail_unless( size == 0 , "initial size should be zero" );
|
|
|
|
fail_if( head == NULL , "head should not be initiated to NULL" );
|
2011-12-30 10:36:18 +08:00
|
|
|
|
2011-01-04 06:47:13 +08:00
|
|
|
/* you end the test code like this: */
|
2011-12-30 10:36:18 +08:00
|
|
|
|
2011-01-04 06:47:13 +08:00
|
|
|
UNITTEST_STOP
|