summaryrefslogtreecommitdiff
path: root/tools/tbot/README.create_a_new_testcase
blob: fbf8ae832984f3bf1c01757949c9d4ef6d981afe (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
# Copyright (c) 2016 DENX Software Engineering GmbH
# Heiko Schocher <hs@denx.de>
#
# SPDX-License-Identifier:	GPL-2.0+
#

write a new testcase
=====================

A TC is written in python, so you can use python as usual. For accessing
the boards console, use functions from the tbotlib, therefore

First import the tbotlib with the line:

  from tbotlib import tbot

If your TC uses variables, please add a line which adds them to
the log file (for debugging purposes):

  logging.info("args: %s ...", tb.varname, ...)

Say tbot, for which board state your TC is valid with:

  tb.set_board_state("u-boot")

Then you are ready ... and you can use the tbotlib funtions
for writting/reading to the boards console.

Big fat warning:

A TC must worry about to end only if a board has finished the shell
command!

Not following this rule, will end in unpredictable behaviour.

(hopefully) useful tbotlib functions
====================================
- set the board state, you want to test
  tb.set_board_state(state)
  states are: "u-boot" or "linux"
  If tbot could not set the board state, tbot ends with failure.

- write a command to the boards console:
  tb.eof_write_con(command):
    write the command to the boards console. If this
    fails, tbot ends with failure

- write a command to boards console and wait for prompt:
  tb.eof_write_cmd(fd, command):
    fd: filedescriptor which is used, use tb.channel_con for boards console
    command: command which is written to fd

    Wait endless for board prompt

- write a list of commands to boards console:
  tb.eof_write_cmd_list(fd, cmdlist):
    fd: filedescriptor which is used, use tb.channel_con for boards console
    cmdlist: python list of commandstrings which is written to fd

- wait for boards prompt:
  tb.eof_read_end_state_con(retry):
    retry: deprecated, not used anymore, cleanup needed here...
    tbot waits endless for the boards prompt

- write a command, wait for prompt and check, if a string is read
  tb.write_cmd_check(fd, cmd, string):
    fd: filedescriptor which is used, use tb.channel_con for boards console
    cmd: command, which is send to fd
    string: string which should be read from fd

    return value:
      True, if string is read and tbot got back boards prompt
      False, else

  tb.eof_write_cmd_check(fd, cmd, string):
    same as tb.write_cmd_check(fd, cmd, string) except, that tbot
    ends immediately with Failure, if string is not read.

- read until prompt and search strings:
  tb.readline_and_search_strings(fd, strings):
    fd: filedescriptor which is used, use tb.channel_con for boards console
    strings: python list of strings, which can be read
      If one of this strings is read, this function return the index, which
      string is read. This function shoud be called in a while loop,
      until this function returns 'prompt'

- read a line from filedescriptor:
  not recommended to use, as the TC must check, if tprompt is read for every
  readen line. Also TC must ensure, that it ends only, if prompt is read.
  tb.read_line(fd, retry)
    fd: filedescriptor which is used, use tb.channel_con for boards console
    retry: retry of trying to reead a line

  return values:
    True, if a line is read. Readen line in tb.buf[fd]
    False, if something read, but not a complete line
    None, if nothing is read

  check if string contains prompt with:
  tb.is_end_fd(fd, string)
    fd: filedescriptor which is used, use tb.channel_con for boards console
    string: buffer, in which a prompt gets searched.

- calling other TC:
  eof_call_tc(name):
    call another TC from "src/tc"
    if the called TC fails with failure, tbot ends with failure

  call_tc(name):
    call another TC from "src/tc"
    if the TC which call_tc calls  fails, call_tc() returns False, else True

There are more functions, but for writting TC this should be enough. But
its software, so new useful functions can always pop up.

Heiko Schocher <hs@denx.de>
v1 2016.01.23