Skip to content
Snippets Groups Projects
README 3.24 KiB
Newer Older
  • Learn to ignore specific revisions
  • Daniel Stenberg's avatar
    Daniel Stenberg committed
                                      _   _ ____  _     
                                  ___| | | |  _ \| |    
                                 / __| | | | |_) | |    
                                | (__| |_| |  _ <| |___ 
                                 \___|\___/|_| \_\_____|
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    The cURL Test Suite
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    Requires:
    
      perl (and a unix-style shell)
    
      diff (when a test fail, a diff is shown)
      stunnel (for HTTPS and FTPS tests)
    
      sshd (for SCP and SFTP tests; OpenSSH ver. 3.8 is known to work)
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    
      - 8990 on localhost for HTTP tests
      - 8991 on localhost for HTTPS tests
      - 8994 on localhost for HTTP IPv6 tests
      - 8992 on localhost for FTP tests
      - 8995 on localhost for FTP (2) tests
      - 8993 on localhost for FTPS tests
      - 8996 on localhost for FTP IPv6 tests
      - 8997 on localhost for TFTP tests
    
      - 8999 on localhost for SCP/SFTP tests
    
    
      The test suite runs simple FTP, HTTP and TFTP servers on these ports to
    
      which it makes requests.  For SSL tests, it runs stunnel to handle
      encryption to the regular servers. For SSH, it runs a standard OpenSSH
      server.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Run:
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      'make test'. This invokes the 'runtests.pl' perl script. Edit the top
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      variables of that script in case you have some specific needs.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    
      The script breaks on the first test that doesn't do OK. Use -a to prevent
      the script to abort on the first error. Run the script with -v for more
    
      verbose output. Use -d to run the test servers with debug output enabled as
      well.
    
      Use -s for shorter output, or pass test numbers to run specific tests only
      (like "./runtests.pl 3 4" to test 3 and 4 only). It also supports test case
      ranges with 'to'. As in "./runtests 3 to 9" which runs the seven tests from
      3 to 9.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    
    Memory:
      The test script will check that all allocated memory is freed properly IF
    
      curl has been built with the CURLDEBUG define set. The script will
    
      automatically detect if that is the case, and it will use the ../memanalyze
      script to analyze the memory debugging output.
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Debug:
      If a test case fails, you can conveniently get the script to invoke the
      debugger (gdb) for you with the server running and the exact same command
      line parameters that failed. Just invoke 'runtests.pl <test number> -g' and
      then just type 'run' in the debugger to perform the command through the
      debugger.
    
    
      If a test case causes a core dump, analyze it by running gdb like:
    
              # gdb ../curl/src core
    
      ... and get a stack trace with the gdb command:
    
              (gdb) where
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    Logs:
    
      All logs are generated in the logs/ subdirectory (it is emptied first
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      in the runtests.pl script). Use runtests.pl -k to keep the temporary files
      after the test run.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    Data:
    
      All test cases are put in the data/ subdirectory. Each test is stored in the
    
      file named according to the test number.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
      See FILEFORMAT for the description of the test case files.
    
    Daniel Stenberg's avatar
    Daniel Stenberg committed
    
    
    TEST CASE NUMBERS
    
     So far, I've used this system:
    
     1   -  99   HTTP
     100 - 199   FTP
     200 - 299   FILE
     300 - 399   HTTPS
     400 - 499   FTPS
    
     500 - 599   libcurl source code tests, not using the curl command tool
    
     Since 30-apr-2003, there's nothing in the system that requires us to keep
    
     within these number series. Each test case now specifies its own server
    
     requirements, independent of test number.
    
      * Add tests for TELNET, LDAP, DICT...