Provided by: erlang-manpages_16.b.3-dfsg-1ubuntu2.2_all bug

NAME

       ct_telnet - Common Test specific layer on top of telnet client ct_telnet_client.erl.

DESCRIPTION

       Common Test specific layer on top of telnet client ct_telnet_client.erl

       Use this module to set up telnet connections, send commands and perform string matching on
       the result. See the unix_telnet manual page for information about how  to  use  ct_telnet,
       and configure connections, specifically for unix hosts.

       The following default values are defined in ct_telnet:

          Connection timeout = 10 sec (time to wait for connection)
          Command timeout = 10 sec (time to wait for a command to return)
          Max no of reconnection attempts = 3
          Reconnection interval = 5 sek (time to wait in between reconnection attempts)
          Keep alive = true (will send NOP to the server every 10 sec if connection is idle)

       These parameters can be altered by the user with the following configuration term:

          {telnet_settings, [{connect_timeout,Millisec},
                             {command_timeout,Millisec},
                             {reconnection_attempts,N},
                             {reconnection_interval,Millisec},
                             {keep_alive,Bool}]}.

       Millisec = integer(), N = integer()

       Enter  the telnet_settings term in a configuration file included in the test and ct_telnet
       will retrieve the information automatically. Note that keep_alive  may  be  specified  per
       connection if required. See unix_telnet for details.

DATA TYPES

         connection()   =  handle()  |  {target_name()  (see  module  ct),  connection_type()}  |
         target_name() (see module ct):

         connection_type() = telnet | ts1 | ts2:

         handle() = handle() (see module ct_gen_conn):

           Handle for a specific telnet connection.

         prompt_regexp() = string():

           A regular expression which matches all possible prompts for a specific type of target.
           The  regexp  must not have any groups i.e. when matching, re:run/3 shall return a list
           with one single element.

EXPORTS

       close(Connection) -> ok | {error, Reason}

              Types:

                 Connection = connection() (see module ct_telnet)

              Close the telnet connection and stop the process managing it.

              A connection may be associated with a target name and/or a  handle.  If  Connection
              has no associated target name, it may only be closed with the handle value (see the
              open/4 function).

       cmd(Connection, Cmd) -> {ok, Data} | {error, Reason}

              Equivalent to cmd(Connection, Cmd, DefaultTimeout).

       cmd(Connection, Cmd, Timeout) -> {ok, Data} | {error, Reason}

              Types:

                 Connection = connection() (see module ct_telnet)
                 Cmd = string()
                 Timeout = integer()
                 Data = [string()]

              Send a command via telnet and wait for prompt.

       cmdf(Connection, CmdFormat, Args) -> {ok, Data} | {error, Reason}

              Equivalent to cmdf(Connection, CmdFormat, Args, DefaultTimeout).

       cmdf(Connection, CmdFormat, Args, Timeout) -> {ok, Data} | {error, Reason}

              Types:

                 Connection = connection() (see module ct_telnet)
                 CmdFormat = string()
                 Args = list()
                 Timeout = integer()
                 Data = [string()]

              Send a telnet command and wait for  prompt  (uses  a  format  string  and  list  of
              arguments to build the command).

       cont_log(Str, Args) -> term()

       end_log() -> term()

       expect(Connection, Patterns) -> term()

              Equivalent to expect(Connections, Patterns, []).

       expect(Connection,  Patterns, Opts) -> {ok, Match} | {ok, MatchList, HaltReason} | {error,
       Reason}

              Types:

                 Connection = connection() (see module ct_telnet)
                 Patterns = Pattern | [Pattern]
                 Pattern = string() | {Tag, string()} | prompt | {prompt, Prompt}
                 Prompt = string()
                 Tag = term()
                 Opts = [Opt]
                 Opt  =  {timeout,  Timeout}  |  repeat  |  {repeat,  N}  |  sequence  |   {halt,
                 HaltPatterns} | ignore_prompt | no_prompt_check
                 Timeout = integer()
                 N = integer()
                 HaltPatterns = Patterns
                 MatchList = [Match]
                 Match = RxMatch | {Tag, RxMatch} | {prompt, Prompt}
                 RxMatch = [string()]
                 HaltReason = done | Match
                 Reason = timeout | {prompt, Prompt}

              Get data from telnet and wait for the expected pattern.

              Pattern  can  be a POSIX regular expression. If more than one pattern is given, the
              function returns when the first match is found.

              RxMatch is a list of matched strings. It looks like  this:  [FullMatch,  SubMatch1,
              SubMatch2,  ...]  where  FullMatch  is  the  string  matched  by  the whole regular
              expression  and  SubMatchN  is  the  string  that  matched  subexpression   no   N.
              Subexpressions are denoted with '(' ')' in the regular expression

              If a Tag is given, the returned Match will also include the matched Tag. Else, only
              RxMatch is returned.

              The timeout option indicates that the function shall return if the telnet client is
              idle  (i.e.  if  no  data  is received) for more than Timeout milliseconds. Default
              timeout is 10 seconds.

              The function will always  return  when  a  prompt  is  found,  unless  any  of  the
              ignore_prompt  or  no_prompt_check  options  are used, in which case it will return
              when a match is found or after a timeout.

              If the ignore_prompt option is used, ct_telnet will ignore any prompt  found.  This
              option  is  useful  if  data  sent by the server could include a pattern that would
              match the prompt regexp (as returned by TargedMod:get_prompt_regexp/0),  but  which
              should not cause the function to return.

              If  the  no_prompt_check  option is used, ct_telnet will not search for a prompt at
              all. This is useful if, for instance, the Pattern itself matches the prompt.

              The repeat option indicates that the pattern(s) shall be matched multiple times. If
              N  is  given,  the pattern(s) will be matched N times, and the function will return
              with HaltReason = done.

              The sequence option indicates that all patterns shall be matched in a  sequence.  A
              match will not be concluded untill all patterns are matched.

              Both  repeat  and  sequence  can  be  interrupted by one or more HaltPatterns. When
              sequence or repeat is used, there will always be a MatchList returned, i.e. a  list
              of Match instead of only one Match. There will also be a HaltReason returned.

              Examples:
              expect(Connection,[{abc,"ABC"},{xyz,"XYZ"}], [sequence,{halt,[{nnn,"NNN"}]}]).
              will  try  to  match  "ABC" first and then "XYZ", but if "NNN" appears the function
              will return {error,{nnn,["NNN"]}}.  If  both  "ABC"  and  "XYZ"  are  matched,  the
              function will return {ok,[AbcMatch,XyzMatch]}.

              expect(Connection,[{abc,"ABC"},{xyz,"XYZ"}], [{repeat,2},{halt,[{nnn,"NNN"}]}]).
              will  try  to match "ABC" or "XYZ" twice. If "NNN" appears the function will return
              with HaltReason = {nnn,["NNN"]}.

              The repeat and sequence options can be  combined  in  order  to  match  a  sequence
              multiple times.

       get_data(Connection) -> {ok, Data} | {error, Reason}

              Types:

                 Connection = connection() (see module ct_telnet)
                 Data = [string()]

              Get  all  data  which has been received by the telnet client since last command was
              sent.

       open(Name) -> {ok, Handle} | {error, Reason}

              Equivalent to open(Name, telnet).

       open(Name, ConnType) -> {ok, Handle} | {error, Reason}

              Types:

                 Name = target_name()
                 ConnType = connection_type() (see module ct_telnet)
                 Handle = handle() (see module ct_telnet)

              Open a telnet connection to the specified target host.

       open(KeyOrName, ConnType, TargetMod) -> {ok, Handle} | {error, Reason}

              Equivalent to open(KeyOrName, ConnType, TargetMod, []).

       open(KeyOrName, ConnType, TargetMod, Extra) -> {ok, Handle} | {error, Reason}

              Types:

                 KeyOrName = Key | Name
                 Key = atom()
                 Name = target_name() (see module ct)
                 ConnType = connection_type()
                 TargetMod = atom()
                 Extra = term()
                 Handle = handle()

              Open a telnet connection to the specified target host.

              The target data  must  exist  in  a  configuration  file.  The  connection  may  be
              associated  with either Name and/or the returned Handle. To allocate a name for the
              target, use ct:require/2 in a test case, or use a require statement  in  the  suite
              info  function  (suite/0),  or  in  a  test  case  info  function.  If you want the
              connection to be associated with Handle only (in case you  need  to  open  multiple
              connections  to  a  host  for  example), simply use Key, the configuration variable
              name, to specify the target. Note that a connection that has no  associated  target
              name can only be closed with the handle value.

              TargetMod  is a module which exports the functions connect(Ip,Port,KeepAlive,Extra)
              and get_prompt_regexp() for the given TargetType (e.g. unix_telnet).

              See also: ct:require/2.

       send(Connection, Cmd) -> ok | {error, Reason}

              Types:

                 Connection = connection() (see module ct_telnet)
                 Cmd = string()

              Send a telnet command and return immediately.

              The resulting output from the command can be read with get_data/1 or expect/2/3.

       sendf(Connection, CmdFormat, Args) -> ok | {error, Reason}

              Types:

                 Connection = connection() (see module ct_telnet)
                 CmdFormat = string()
                 Args = list()

              Send a telnet command and return immediately (uses a format string and  a  list  of
              arguments to build the command).

SEE ALSO

       unix_telnet

AUTHORS

       <>

                                        common_test 1.7.4                         ct_telnet(3erl)