Class: Case

Inherits:
Object
  • Object
show all
Includes:
DSL, Verbose
Defined in:
lib/teuton/case/case.rb,
lib/teuton/case/host.rb,
lib/teuton/case/play.rb,
lib/teuton/case/close.rb,
lib/teuton/case/config.rb,
lib/teuton/case/builtin/main.rb,
lib/teuton/deprecated/runner.rb

Defined Under Namespace

Classes: Config, Host

Constant Summary collapse

@@id =

First case ID value

"01"

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Verbose

#verbose, #verboseln

Methods included from DSL

#expect, #expect2, #expect_any, #expect_exit, #expect_fail, #expect_first, #expect_last, #expect_none, #expect_nothing, #expect_ok, #expect_one, #expect_sequence, #get, #get_host, #gett, #goto, #log, #macro, #method_missing, #readme, #remote_tempdir, #remote_tempfile, #respond_to_missing?, #run, #run_script, #send, #set, #target, #tempdir, #tempfile, #unique, #unset, #upload, #upload_one, #weight

Constructor Details

#initialize(config) ⇒ Case

Returns a new instance of Case.



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
# File 'lib/teuton/case/case.rb', line 29

def initialize(config)
  @config = Case::Config.new(
    local: config,
    global: Project.value[:global]
  )
  @groups = Project.value[:groups]

  @id = @@id
  @@id = @@id.next

  # Define Case Report
  @report = Report.new(@id)
  @report.output_dir = File.join("var", @config.global[:tt_testname])

  # Default configuration
  @skip = false
  @skip = get(:tt_skip) unless get(:tt_skip) == "NODATA"
  unless Project.value[:options]["case"].nil?
    @skip = true
    @skip = false if Project.value[:options]["case"].include? @id.to_i
  end
  @debug = Project.debug?
  @verbose = Project.value[:verbose]

  @tmpdir = File.join("var", @config.get(:tt_testname), "tmp", @id.to_s)
  # ensure_dir @tmpdir # REVISE: When we will need this? Samba?

  @unique_values = {}
  @result = Result.new
  @action_counter = 0
  @action = {
    id: 0,
    weight: 1.0,
    description: "No description!",
    groupname: nil
  }
  @uniques = []
  @sessions = {} # Store opened sessions for this case
  @conn_status = {}
  tempfile :default
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class DSL

Instance Attribute Details

#actionObject

Updated by ExecuteManager



18
19
20
# File 'lib/teuton/case/case.rb', line 18

def action
  @action
end

#configObject (readonly)

Readed by ExecuteManager



24
25
26
# File 'lib/teuton/case/case.rb', line 24

def config
  @config
end

#conn_statusObject

Updated by ExecuteManager



21
22
23
# File 'lib/teuton/case/case.rb', line 21

def conn_status
  @conn_status
end

#idObject (readonly)

Returns the value of attribute id.



23
24
25
# File 'lib/teuton/case/case.rb', line 23

def id
  @id
end

#resultObject

Updated by ExecuteManager



19
20
21
# File 'lib/teuton/case/case.rb', line 19

def result
  @result
end

#sessionsObject

Updated by ExecuteManager



20
21
22
# File 'lib/teuton/case/case.rb', line 20

def sessions
  @sessions
end

#skipObject (readonly) Also known as: skip?

Returns the value of attribute skip.



26
27
28
# File 'lib/teuton/case/case.rb', line 26

def skip
  @skip
end

#uniquesObject (readonly)

Returns the value of attribute uniques.



25
26
27
# File 'lib/teuton/case/case.rb', line 25

def uniques
  @uniques
end

Instance Method Details

#close(uniques) ⇒ Object



4
5
6
7
8
9
10
11
12
13
14
15
16
# File 'lib/teuton/case/close.rb', line 4

def close(uniques)
  # Invoked from check_cases!

  fails = 0
  @uniques.each do |key|
    next unless uniques[key].include?(id) && uniques[key].count > 1

    fails += 1
    log_unique_message(key, uniques[key])
  end
  @report.tail[:unique_fault] = fails
  @report.close
end

#export(format) ⇒ Object



71
72
73
74
75
# File 'lib/teuton/case/case.rb', line 71

def export(format)
  return if skip?

  @report.export format
end

#filenameObject



77
78
79
80
# File 'lib/teuton/case/case.rb', line 77

def filename
  # called from: close_main_report
  @report.filename
end

#gradeObject



82
83
84
85
86
# File 'lib/teuton/case/case.rb', line 82

def grade
  return 0.0 if skip

  @report.tail[:grade]
end

#host(host = "localhost") ⇒ Object



4
5
6
# File 'lib/teuton/case/builtin/main.rb', line 4

def host(host = "localhost")
  TeutonHost.new(self, host)
end

#membersObject



88
89
90
91
92
# File 'lib/teuton/case/case.rb', line 88

def members
  return "-" if skip

  @report.head[:tt_members] || "noname"
end

#playObject Also known as: start

READ: sessions, config, groups, action, report TODO: groups from Project or from Case???



6
7
8
9
10
11
12
13
14
15
# File 'lib/teuton/case/play.rb', line 6

def play
  if skip?
    verbose Rainbow("S").green
    return false
  end
  start_time = Time.now
  play_groups_in_sequence
  fill_report(start_time, Time.now)
  close_opened_sessions
end