wireshark/test
Guy Harris e01f8fb3ad Explicitly specify the template for the mktemp command.
Not all versions of mktemp support omitting the template; in particular,
the one provided by some BSD-flavored OSes don't.

Change-Id: I657e002559dce165c677a473aa10bb17cc506037
Reviewed-on: https://code.wireshark.org/review/12592
Reviewed-by: Guy Harris <guy@alum.mit.edu>
2015-12-13 18:05:36 +00:00
..
baseline Remove svn:executable attribute. 2014-01-07 22:55:03 +00:00
captures WPA/WPA2 decoding fixes and improvements 2015-11-09 11:28:14 +00:00
config WPA/WPA2 decoding fixes and improvements 2015-11-09 11:28:14 +00:00
keys ssl-utils: fix failing decryption for some RSA keys 2015-07-15 21:31:44 +00:00
lua Change Lua tests to reflect the disappearance of WTAP_ENCAP_IEEE_802_11_AIROPEEK. 2015-11-26 21:34:24 +00:00
README.test Add a test-programs target everywhere. 2015-03-13 22:41:40 +00:00
config.sh text2pcap: Add test suite 2015-10-15 14:00:04 +00:00
hosts.custom Continue to remove $Id$ from top of file 2014-03-31 18:48:06 +00:00
hosts.global Continue to remove $Id$ from top of file 2014-03-31 18:48:06 +00:00
hosts.personal Continue to remove $Id$ from top of file 2014-03-31 18:48:06 +00:00
run_and_catch_crashes Exit with the exit status of the command we ran. 2015-06-23 17:16:12 +00:00
suite-capture.sh Ping on Windows isn't necessarily IPv4-only. 2015-12-12 01:52:54 +00:00
suite-clopts.sh Test suite: Make sure we have a usable locale before we run iconv. 2014-12-31 17:13:06 +00:00
suite-decryption.sh WPA (IEEE802.11) decryption function cleanups 2015-11-25 21:00:59 +00:00
suite-fileformats.sh Continue to remove $Id$ from top of file 2014-03-31 18:48:06 +00:00
suite-io.sh Add tests for the Qt UI. 2014-10-01 22:30:33 +00:00
suite-mergecap.sh Get the windows buildbot working for mergecap test suite 2015-08-20 01:39:53 +00:00
suite-nameres.sh When piping tshark to something else, run it with run_and_catch_crashes. 2015-05-11 00:00:46 +00:00
suite-text2pcap.sh text2pcap: Add test suite 2015-10-15 14:00:04 +00:00
suite-unittests.sh Add a test to verify we pre-allocated enough hf entries. 2015-09-23 20:09:39 +00:00
suite-wslua.sh Change Lua tests to reflect the disappearance of WTAP_ENCAP_IEEE_802_11_AIROPEEK. 2015-11-26 21:34:24 +00:00
test-backend.sh Continue to remove $Id$ from top of file 2014-03-31 18:48:06 +00:00
test.sh Explicitly specify the template for the mktemp command. 2015-12-13 18:05:36 +00:00

README.test

What is it?
-----------
This is a collection of bash scripts which test the features of:

 - Wireshark
 - TShark
 - Dumpcap

Motivation
----------

The command line options of Wireshark and the companion command line tools are
numerous. This makes it hard to find newly introduced bugs doing manual testing
(try and error) with source code changes.

The current way is to do some changes, testing some scenarios by hand and
commit the code so other users will complain about new problems. This obviously
is far from being optimal.

Limitations
-----------

The test set currently provided will only do some basic tests, but even that
is far better than nothing. This may involve in time as new tests can be added
to fix problems reported by users. This will hopefully lead to a "complete"
and reliable testset in the future.

The tests are limited to command line tests, other things like unit tests or
GUI test are not included.

Prerequisites
-------------

What you'll need (to do):

 - edit the file config.sh to suit your configuration
 - build the "all" target
 - build the "test-programs" target
 - have a bash (cygwin should do well)
 - have tput (e.g. in the cygwin ncurses package)
 - you'll need a network interface with some network traffic
   (so you can run the capture tests)
 - (for non-Windows platforms) An X server for running the capture tests with
   the graphical Wireshark program.

A Test Ride
-----------

The default configuration might not be suitable for your set-up. Most settings
can be adjusted by setting an environment variable matching or by editing the
setting in config.sh.

For instance, the first network interface might not be used for traffic (like an
unconnected Ethernet port). In that case, you might want to set the environment
variable TRAFFIC_CAPTURE_IFACE to pick another interface. Use `dumpcap -D` to
get a list of devices.

On Windows, it is assumed that the user is able to perform captures. On
non-Windows platforms, the opposite is assumed. If your dumpcap executable
allows you to perform captures (for example, when it has appropriate
capabilities), then you can override the default with:

    SKIP_CAPTURE=0

If you do not want to test the binaries in the build directory, you can override
it with:

    WS_BIN_PATH=/usr/bin

When your configuration is sane, you can start test.sh which should provide a
basic menu. Just press Enter to start all tests.

It should start all the available tests. Each test will throw out a line
which should end with a green "Ok". If one of the tests fail, the script
will report it and stop at this test step.

Please remember to have some ICMP traffic on your network interface! The test
suite will ping to www.wireshark.org while running capture tests, but this will
slow down the tests.