The POTS (Plain Ordinary Telephone Service) application simulates basic telephone services.
Many of the scripts in the input directory are tests for the POTS application. When the test.cp.setup script is read, the following files are generated during each test (see the files in the output directory):
- A detailed function and message trace (*.trace.txt).
- A function profile (*.funcs.txt), as described in the Testing section.
- A message sequence chart of the scenario (*.msc.txt). This is followed by an event trace (a summary of socket activity, object creations/deletions, incoming and outgoing messages, and internal states and events). The items in this event trace also appear in the function trace.
- A console file (*.cli.txt).
The traffic script (>read traffic.start
) launches a
thread that initiates, answers, and releases calls, initially
at a rate of 600 per minute. The call rate can be increased to the point where the system
enters overload. Whatever the current call rate, you can observe the system's behavior with
commands such as >status
, >sched show
, and >traffic profile
. A console file of a
traffic run appears here, and a log file appears
here. During the run, the call rate is suddenly
increased from 600 to 20,000 calls per minute. Once this rate is reached, it is increased
to 24,000 calls per minute to create an overload situation. After overload has persisted
for a while, the call rate is dropped to 0, which gradually causes all calls to be released.
Users (phone numbers) are created in the >pots
CLI increment. The CLI commands
available in that increment are described here,
starting after the line pots>help full
.
Phone numbers are five digits in length, in the range 20000-99999. Supplementary services, which alter the behavior of basic calls, can also be assigned to each user.
The POTS application currently defines the following supplementary services:
- Barring of Incoming Calls (BIC): Incoming calls are blocked.
- Barring of Outgoing Calls (BOC): Outgoing calls are blocked.
- Call Forward Unconditional/Busy/No Reply (CFU/CFB/CFN): Incoming calls are
forwarded to a pre-specified number
- immediately (CFU),
- if the user is already involved in a call (CFB), or
- if the user does not answer before a specified timeout (CFN).
- Call Transfer (CXF): When a user who has established a consultation or conference call disconnects, the two remaining users are connected. Not yet implemented, but can be assigned to a user's profile.
- Call Waiting (CWT): A user in an established call can receive a second call and then repeatedly flip between the two calls. If the user disconnects, the inactive call rerings the user.
- Hot Line (HTL): When the user initiates a call, it always routes to a pre-specified number.
- Suspended Service (SUS): The user cannot initiate or receive calls.
- Three-Way Calling (TWC): A user in an established call can place the call on hold and initiate a consultation call, which can then be conferenced with the original call. Not yet implemented, but can be assigned to a user's profile.
- Warm Line (WML): When a call is initiated and no digits are dialed before the timeout interval, the call is routed to a pre-specified number.
The SessionBase
component of RCS defines virtual base classes for implementing state
machines and protocols. As a session-oriented application, POTS uses this framework. The
documents RSC Session Processing and A Pattern Language
of Call Processing should prove helpful if studying the POTS software in
detail.
The protocol between the user (client/phone) and network (server) is defined here. On the network side, the POTS basic call state machine is based on the states and events defined here. Its concrete state subclasses are defined here, and its event handlers are implemented here.