Test Tools Working Under DEFT

This page describes the tools that are already supported under DEFT and how their instantiators process the config argrument to create

Jump to traffic_server , jtest , syntest .

traffic_server

Package Available No
Config

The configuration format for traffic_server is an extended form of that used by shadow.pl. Sections are dilinated by a line of the form [<config filename>]. Example:

[storage.config]

With exception of [records.config], [remap.config], [filter.config], and [meta] the contents between that tag and next file tag (or end of file) are written verbatim to a file of that name in that run_dir/config for that Traffic Server instance.

[records.config] section is processed specially using the shadow.pl format. Lines can can consist of two forms. The first gives a variable name and new value to substitute in. This form can only be used for variables that already present in records.config. Example:

proxy.config.hostdb.size              50000

The second form is used for adding lines to end of records.config and is intended for setting variables not all already in the file. Example:

add CONFIG proxy.config.core_limit INT -1

[remap.config] section allow for substitution of variables from records.config to allows for reverse proxy tests. The ports for TS are not known until the TS's instantiator runs so we need a special syntax to have the instantiator do substitution into the remap.config file. [remap.config] supports substitutions of the form &&(records_config_var). The named records.config var will be substituted in when the remap.config file is written. Example:

map http://%%(ts1):&&(proxy.config.http.server_port)/ \
http://%%(load1):%%(load1:server)/ 

[filter.config] section allows for the evaluation of perl expressions in writing the config file. The syntax is

&&(eval|< perl expression >|)
One use is to specify time based access control scheme. Example:

dest_ip=0.0.0.0-255.255.255.255 \
time=&&(eval|{my \$t=time; my (\$s1,\$m1,\$h1)=localtime(\$t-3600); my (\$s2,\$m2,\$h2)=localtime(\$t+3600); "\$h1:\$m1-\$h2:\$m2"}|) \
action=deny 

The [meta] sections is where the instantiator is told about attributes that affect its work. The there is only currently one option which is tell the instantiator to start up traffic_manager instead of traffic_server. Here's how:

[meta]

run_manager: 1
Port Bindings
  • rafPort - RAF service port
  • tsHttpPort - HTTP Proxy Port
  • tsRtspPort - RTSP Proxy Port
  • tsWmtPort - WMT Proxy Port
Other Setup Done All the config files from bin_dir/config are copied over to run_dir/config before the create config arguemnt is processed.
Raf Support Yes. query cmd

jtest

Package Available Yes
Config Configuration is simply a single line with the command line arguments to run jtest with
Other Setup Done None
Raf Support Yes. query cmd
Port Bindings
  • rafPort - RAF service port
  • server - jtest http server port

syntest

Package Available Yes
Config

Two lines of the form:

proxy_host: <hostname>
proxy_port: <http_port>
Other Setup Done Unpacks into bin_dir syntest.tar to get access to testcase files. Creates system.cfg with proxy information from the Config in run_dir. Copies over necessary files (test.cfg, *.pem) from bin_dir to run_dir. Adds symbolic link for Tests in run_dir to bin_dir for access to test case files
Raf Support No.
Port Bindings None

All rights Reserved.