Skip to content
/ expect Public
forked from leemcloughlin/expect

Expect is pure Go (golang) version of the terminal interaction package Expect common on many Linux systems

Notifications You must be signed in to change notification settings

grrtrr/expect

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

expect

import "github.com/grrtrr/expect"

Expect is pure Go (golang) version of the terminal interaction package Expect common on many Linux systems

A very simple example that calls the rev program to reverse the text in each line is:

exp, err := NewExpect("rev")
if err != nil {
	fmt.Fprintf(os.Stderr, "NewExpect failed %s", err)
}
exp.SetTimeoutSecs(5)
exp.Send("hello\r")

// i will be the index of the argument that matched the input otherwise
// i will be a negative number showing match fail or error
i, found, err := exp.Expect("olleh")
if i == 0 {
	fmt.Println("found", string(found))
} else {
	fmt.Println("failed ", err)
}
exp.Send(EOF)

This package has only been tested on Linux

expect.go

const (
    // NotFound is returned by Expect for non-matching non-errors (include EOF)
    NotFound = -1

    // TimedOut is returned by Expect on a timeout (along with an error of ETimedOut)
    TimedOut = -2

    // NotStringOrRexgexp is returned if a paramter is not a string or a regexp
    NotStringOrRexgexp = -3
)
var (
    ETimedOut           = errors.New("TimedOut")
    ENotStringOrRexgexp = errors.New("Not string or regexp")
    EReadError          = errors.New("Read Error")

    // Debug if true will generate vast amounts of internal logging
    Debug = false

    // ExpectInSize is the size of the channel between the expectReader and Expect.
    // If you overflow this than expectReader will block.
    ExpectInSize = 20 * 1024

    // EOF is the terminal EOF character - NOT guaranteed to be correct on all
    // systems nor if the program passed to expect connects to a different
    // platform
    EOF = "\004"
)
type Expect struct {

    // Expect reads into here. On a successful match all data up the end of the
    // match is deleted shrinking the buffer.
    // See also Clear() and BufStr()
    Buffer *bytes.Buffer

    // On EOF being read from Cmd this is set (and ExpectReader is ended)
    Eof bool

    // Result is filled in asynchronously after the cmd exits
    Result ExpectWaitResult
    // contains filtered or unexported fields
}
func NewExpect(prog string, arg ...string) (*Expect, error)

NewExpect starts prog, passing any given args, in its own pty. Note that in order to be non-blocking while reading from the pty this sets the non-blocking flag and looks for EAGAIN on reads failing. This has only been tested on Linux systems. On prog exiting or being killed Result is filled in shortly after.

func NewExpectProc(ctx context.Context, prog string, arg ...string) (*Expect, *os.Process, error)

NewExpectProc is similar to NewExpect except the created cmd is returned. It is expected that the cmd will exit normally otherwise it is left to the caller to kill it. This can be achieved by canceling the context @ctx. In the event of an error starting the cmd it will be killed but not reaped. However the cmd ends it is important that the caller reap the process by calling cmd.Process.Wait() otherwise it can use up a process slot in the operating system. Note that Result is not filled in.

func Spawn(prog string, arg ...string) (*Expect, error)

Spawn is a wrapper to NewExpect(), for compatibility with the original expect

func (*Expect) BufStr

func (exp *Expect) BufStr() string

BufStr is the buffer of expect read data as a string

func (*Expect) Clear

func (exp *Expect) Clear()

Clear out any unprocessed input

func (*Expect) Expect

func (exp *Expect) Expect(reOrStrs ...interface{}) (int, []byte, error)

Expect keeps reading input till either a timeout occurs (if set), one of the strings/regexps passed matches the input, end of input occurs or an error. If a string/regexp match occurs the index of the successful argument and the matching bytes are returned. Otherwise an error value and error are returned. Note: on EOF the return value will be NotFound and the error will be nil as EOF is not considered an error. This is the only time those values will be returned. See also Expecti()

func (*Expect) Expecti

func (exp *Expect) Expecti(reOrStrs ...interface{}) int

Expecti is a convenience wrapper around Expect() that only returns the index and not the found bytes or error. This is close to the original expect()

func (*Expect) Expectp

func (exp *Expect) Expectp(reOrStrs ...interface{}) int

Expectp is a convenience wrapper around Expect() that panics on no match (so will panic on eof)

func (*Expect) Kill

func (exp *Expect) Kill()

Kill the command. Using an Expect after a Kill is undefined

func (*Expect) LogUser

func (exp *Expect) LogUser(on bool)

LogUser true asks for all input read by Expect() to be copied to stdout. LogUser false (default) turns it off. For compatibility with the original expect

func (*Expect) Send

func (exp *Expect) Send(s string) (int, error)

Send sends the string to the process, for compatibility with the original expect

func (*Expect) SendL

func (exp *Expect) SendL(lines ...string) error

SendL is a convenience wrapper around Send(), adding linebreaks around each of the @lines.

func (*Expect) SendSlow

func (exp *Expect) SendSlow(delay time.Duration, s string) (int, error)

Sends string rune by rune with a delay before each. Note: the return is the number of bytes sent not the number of runes sent

func (*Expect) SetCmdOut

func (exp *Expect) SetCmdOut(cmdOut io.Writer)

SetCmdOut if a non-nil io.Writer is passed it will be sent a copy of everything read by Expect() from the pty. Note that if you bypass expect and read directly from the *Expect this is will not be used

func (*Expect) SetTimeout

func (exp *Expect) SetTimeout(timeout time.Duration)

SetTimeout sets the timeout for future calls to Expect(). The default value is zero which cause Expect() to wait forever.

func (exp *Expect) SetTimeoutSecs(timeout int)

SetTimeoutSecs is a convenience wrapper around SetTimeout

type ExpectWaitResult struct {
    ProcessState *os.ProcessState
    Error        error
}

Generated by godoc2md

About

Expect is pure Go (golang) version of the terminal interaction package Expect common on many Linux systems

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 99.8%
  • Shell 0.2%