teuton 2.1.8 → 2.1.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +5 -8
- data/bin/check_teuton +43 -0
- data/docs/changelog/contributions.md +32 -0
- data/docs/changelog/v2.1.md +22 -0
- data/docs/changelog/v2.2.md +29 -0
- data/docs/commands/README.md +105 -7
- data/docs/commands/example_check.md +54 -0
- data/docs/commands/example_run.md +112 -0
- data/docs/dsl/README.md +11 -9
- data/docs/dsl/definition/expect.md +25 -21
- data/docs/dsl/definition/group.md +5 -1
- data/docs/dsl/definition/result.md +45 -34
- data/docs/dsl/definition/run_local.md +34 -0
- data/docs/dsl/definition/run_remote.md +119 -0
- data/docs/dsl/definition/target.md +6 -0
- data/docs/dsl/execution/export.md +27 -19
- data/docs/dsl/execution/play.md +4 -0
- data/docs/dsl/execution/send.md +21 -2
- data/docs/dsl/execution/show.md +13 -8
- data/docs/dsl/setting/get.md +24 -8
- data/docs/dsl/setting/set.md +8 -3
- data/docs/install/README.md +19 -26
- data/docs/install/modes_of_use.md +27 -26
- data/docs/install/scripts.md +53 -36
- data/docs/install/vagrant_docker.md +56 -0
- data/docs/learn/README.md +13 -6
- data/docs/learn/example-01-target.md +78 -61
- data/docs/learn/example-02-config.md +152 -0
- data/docs/learn/example-03-remote-hosts.md +31 -25
- data/docs/learn/example-04-use.md +23 -17
- data/docs/learn/example-05-debug.md +24 -17
- data/docs/learn/example-06-log.md +70 -0
- data/lib/teuton/application.rb +7 -4
- data/lib/teuton/case_manager/case/case.rb +4 -1
- data/lib/teuton/case_manager/case/dsl/expect.rb +3 -1
- data/lib/teuton/case_manager/case/dsl/goto.rb +12 -7
- data/lib/teuton/case_manager/case/dsl/macro.rb +38 -0
- data/lib/teuton/case_manager/case/dsl/main.rb +1 -2
- data/lib/teuton/case_manager/case/dsl/target.rb +1 -1
- data/lib/teuton/case_manager/case/runner.rb +7 -7
- data/lib/teuton/case_manager/case_manager.rb +1 -20
- data/lib/teuton/case_manager/check_cases.rb +12 -2
- data/lib/teuton/case_manager/dsl.rb +4 -6
- data/lib/teuton/case_manager/export_manager.rb +29 -3
- data/lib/teuton/case_manager/report.rb +29 -8
- data/lib/teuton/case_manager/show.rb +8 -4
- data/lib/teuton/cli.rb +1 -0
- data/lib/teuton/cli/play.rb +1 -0
- data/lib/teuton/cli/version.rb +1 -4
- data/lib/teuton/files/config.yaml +0 -1
- data/lib/teuton/files/start.rb +1 -1
- data/lib/teuton/files/template/case.html +135 -0
- data/lib/teuton/files/template/resume.html +115 -0
- data/lib/teuton/project/laboratory/builtin.rb +2 -1
- data/lib/teuton/project/laboratory/dsl.rb +13 -15
- data/lib/teuton/project/laboratory/laboratory.rb +5 -1
- data/lib/teuton/project/laboratory/show.rb +21 -13
- data/lib/teuton/project/name_file_finder.rb +6 -1
- data/lib/teuton/project/project.rb +7 -3
- data/lib/teuton/project/readme/dsl.rb +3 -1
- data/lib/teuton/project/readme/readme.rb +37 -26
- data/lib/teuton/project/skeleton.rb +20 -4
- data/lib/teuton/report/close.rb +15 -11
- data/lib/teuton/report/formatter/formatter_factory.rb +10 -6
- data/lib/teuton/report/formatter/html_formatter.rb +16 -79
- data/lib/teuton/report/formatter/resume_html_formatter.rb +39 -0
- data/lib/teuton/report/formatter/resume_yaml_formatter.rb +7 -1
- data/lib/teuton/report/report.rb +5 -4
- data/lib/teuton/report/show.rb +55 -26
- metadata +26 -39
- data/docs/changelog/todo.md +0 -46
- data/docs/commands/create_skeleton.md +0 -31
- data/docs/commands/help.md +0 -13
- data/docs/commands/revise_test.md +0 -46
- data/docs/commands/run_test_unit.md +0 -78
- data/docs/commands/show_version.md +0 -9
- data/docs/developers/01-telnet.md +0 -121
- data/docs/developers/02-ssh.md +0 -93
- data/docs/developers/03-encoding.md +0 -153
- data/docs/developers/comparative.md +0 -17
- data/docs/dsl/_Sidebar.md +0 -30
- data/docs/dsl/definition/goto.md +0 -112
- data/docs/dsl/definition/run.md +0 -23
- data/docs/install/tested_os.md +0 -25
- data/docs/install/vagrant.md +0 -9
- data/docs/learn/example-02-configfile.md +0 -174
- data/docs/learn/quick-demo.md +0 -170
- data/lib/teuton/case_manager/case/dsl/check.rb +0 -24
- data/lib/teuton/case_manager/case/dsl/missing.rb +0 -12
- data/lib/teuton/files/gitignore +0 -2
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
# * set
|
|
12
12
|
class Laboratory
|
|
13
13
|
def readme(_text)
|
|
14
|
-
# Usefull for "teuton
|
|
14
|
+
# Usefull for "teuton readme" command action.
|
|
15
15
|
end
|
|
16
16
|
|
|
17
17
|
def target(desc, args = {})
|
|
@@ -23,37 +23,35 @@ class Laboratory
|
|
|
23
23
|
end
|
|
24
24
|
alias goal target
|
|
25
25
|
|
|
26
|
-
def request(text)
|
|
27
|
-
@requests << text.to_s
|
|
28
|
-
end
|
|
26
|
+
# def request(text)
|
|
27
|
+
# @requests << text.to_s
|
|
28
|
+
# end
|
|
29
29
|
|
|
30
30
|
def tempfile(_tempfile = nil)
|
|
31
31
|
'tempfile'
|
|
32
32
|
end
|
|
33
33
|
|
|
34
|
+
def run(command, args = {})
|
|
35
|
+
args[:exec] = command
|
|
36
|
+
host = :localhost
|
|
37
|
+
host = args[:on] if args[:on]
|
|
38
|
+
goto(host, args)
|
|
39
|
+
end
|
|
40
|
+
|
|
34
41
|
def goto(host = :localhost, args = {})
|
|
35
42
|
result.reset
|
|
43
|
+
args[:on] = host unless args[:on]
|
|
36
44
|
|
|
37
45
|
if @hosts[host]
|
|
38
46
|
@hosts[host] += 1
|
|
39
47
|
else
|
|
40
48
|
@hosts[host] = 1
|
|
41
49
|
end
|
|
42
|
-
verboseln "
|
|
43
|
-
end
|
|
44
|
-
|
|
45
|
-
def run(command, args = {})
|
|
46
|
-
args[:exec] = command
|
|
47
|
-
goto(:localhost, args)
|
|
50
|
+
verboseln " run '#{args[:exec]}' on #{args[:on]}"
|
|
48
51
|
end
|
|
49
52
|
|
|
50
53
|
def expect(_cond, args = {})
|
|
51
|
-
#unless [ String, Array, Regexp].include? _cond.class
|
|
52
|
-
# verboseln "[ERROR] expect #{_cond} (#{_cond.class})"
|
|
53
|
-
# return
|
|
54
|
-
#end
|
|
55
54
|
verboseln " alter #{result.alterations}" unless result.alterations.empty?
|
|
56
|
-
#verboseln " expect #{result.expected} (#{result.expected.class})"
|
|
57
55
|
verboseln " expect #{_cond} (#{_cond.class})"
|
|
58
56
|
verboseln ''
|
|
59
57
|
end
|
|
@@ -43,6 +43,8 @@ alias play start
|
|
|
43
43
|
class Laboratory
|
|
44
44
|
attr_reader :result
|
|
45
45
|
|
|
46
|
+
##
|
|
47
|
+
# Initialize instance
|
|
46
48
|
def initialize(script_path, config_path)
|
|
47
49
|
@path = {}
|
|
48
50
|
@path[:script] = script_path
|
|
@@ -52,6 +54,8 @@ class Laboratory
|
|
|
52
54
|
reset
|
|
53
55
|
end
|
|
54
56
|
|
|
57
|
+
##
|
|
58
|
+
# Set attibutes to default values
|
|
55
59
|
def reset
|
|
56
60
|
@result = Result.new
|
|
57
61
|
@targetid = 0
|
|
@@ -59,7 +63,7 @@ class Laboratory
|
|
|
59
63
|
@gets = {}
|
|
60
64
|
@sets = {}
|
|
61
65
|
@hosts = {}
|
|
62
|
-
@requests = []
|
|
66
|
+
@requests = [] # REVISE this
|
|
63
67
|
@verbose = Application.instance.verbose
|
|
64
68
|
end
|
|
65
69
|
end
|
|
@@ -9,6 +9,8 @@ require_relative '../configfile_reader'
|
|
|
9
9
|
# * show_stats
|
|
10
10
|
# * show_config
|
|
11
11
|
class Laboratory
|
|
12
|
+
##
|
|
13
|
+
# Display DSL on screen
|
|
12
14
|
def show_dsl
|
|
13
15
|
@verbose = true
|
|
14
16
|
process_content
|
|
@@ -16,6 +18,8 @@ class Laboratory
|
|
|
16
18
|
show_config
|
|
17
19
|
end
|
|
18
20
|
|
|
21
|
+
##
|
|
22
|
+
# Display stats on screen
|
|
19
23
|
def show_stats
|
|
20
24
|
@stats[:hosts] = 0
|
|
21
25
|
@hosts.each_pair { |_k, v| @stats[:hosts] += v }
|
|
@@ -45,6 +49,8 @@ class Laboratory
|
|
|
45
49
|
verboseln my_screen_table.to_s + "\n"
|
|
46
50
|
end
|
|
47
51
|
|
|
52
|
+
##
|
|
53
|
+
# Display config on screen
|
|
48
54
|
def show_config
|
|
49
55
|
@verbose = false
|
|
50
56
|
process_content
|
|
@@ -52,19 +58,19 @@ class Laboratory
|
|
|
52
58
|
revise_config_content
|
|
53
59
|
end
|
|
54
60
|
|
|
55
|
-
def show_requests
|
|
56
|
-
@verbose = false
|
|
57
|
-
process_content
|
|
58
|
-
@verbose = true
|
|
59
|
-
my_screen_table = Terminal::Table.new do |st|
|
|
60
|
-
st.add_row ['Lines', 'REQUEST description']
|
|
61
|
-
st.add_separator
|
|
62
|
-
@requests.each_with_index do |line, index|
|
|
63
|
-
st.add_row ['%03d' % index, line]
|
|
64
|
-
end
|
|
65
|
-
end
|
|
66
|
-
verboseln my_screen_table
|
|
67
|
-
end
|
|
61
|
+
# def show_requests
|
|
62
|
+
# @verbose = false
|
|
63
|
+
# process_content
|
|
64
|
+
# @verbose = true
|
|
65
|
+
# my_screen_table = Terminal::Table.new do |st|
|
|
66
|
+
# st.add_row ['Lines', 'REQUEST description']
|
|
67
|
+
# st.add_separator
|
|
68
|
+
# @requests.each_with_index do |line, index|
|
|
69
|
+
# st.add_row ['%03d' % index, line]
|
|
70
|
+
# end
|
|
71
|
+
# end
|
|
72
|
+
# verboseln my_screen_table
|
|
73
|
+
# end
|
|
68
74
|
|
|
69
75
|
private
|
|
70
76
|
|
|
@@ -121,6 +127,8 @@ class Laboratory
|
|
|
121
127
|
verboseln YAML.dump(output)
|
|
122
128
|
end
|
|
123
129
|
|
|
130
|
+
##
|
|
131
|
+
# Revive and check config content
|
|
124
132
|
def revise_config_content
|
|
125
133
|
@verbose = true
|
|
126
134
|
my_screen_table = Terminal::Table.new do |st|
|
|
@@ -116,6 +116,8 @@ module NameFileFinder
|
|
|
116
116
|
verboseln Rainbow(trim(app.script_path)).blue.bright
|
|
117
117
|
verbose Rainbow('[INFO] ConfigPath => ').blue
|
|
118
118
|
verboseln Rainbow(trim(app.config_path)).blue.bright
|
|
119
|
+
verbose Rainbow('[INFO] Pwd => ').blue
|
|
120
|
+
verboseln Rainbow(app.running_basedir).blue.bright
|
|
119
121
|
verbose Rainbow('[INFO] TestName => ').blue
|
|
120
122
|
verboseln Rainbow(trim(app.test_name)).blue.bright
|
|
121
123
|
end
|
|
@@ -125,8 +127,11 @@ module NameFileFinder
|
|
|
125
127
|
# @param input (String)
|
|
126
128
|
# @return String
|
|
127
129
|
def self.trim(input)
|
|
130
|
+
return input unless input.to_s.start_with? Dir.pwd.to_s
|
|
131
|
+
|
|
128
132
|
output = input.to_s
|
|
129
|
-
|
|
133
|
+
offset = (Dir.pwd).length + 1
|
|
134
|
+
output = "#{input[offset, input.size]}"
|
|
130
135
|
output.to_s
|
|
131
136
|
end
|
|
132
137
|
|
|
@@ -33,16 +33,20 @@ module Project ##
|
|
|
33
33
|
# @param options (Array) Array of input options
|
|
34
34
|
def self.play(projectpath, options)
|
|
35
35
|
Application.instance.options.merge! options
|
|
36
|
-
|
|
36
|
+
process_input_options
|
|
37
37
|
NameFileFinder.find_filenames_for(projectpath)
|
|
38
38
|
NameFileFinder.puts_input_info_on_screen
|
|
39
39
|
require_dsl_and_script('../case_manager/dsl') # Define DSL keywords
|
|
40
40
|
end
|
|
41
41
|
|
|
42
42
|
##
|
|
43
|
-
#
|
|
44
|
-
|
|
43
|
+
# Preprocess input options:
|
|
44
|
+
# * Convert input case options String to an Array of integers
|
|
45
|
+
# * Read color input option
|
|
46
|
+
def self.process_input_options
|
|
45
47
|
options = Application.instance.options
|
|
48
|
+
options['color'] = true if options['color'].nil?
|
|
49
|
+
Rainbow.enabled = options['color']
|
|
46
50
|
return if options['case'].nil?
|
|
47
51
|
|
|
48
52
|
a = options['case'].split(',')
|
|
@@ -31,6 +31,10 @@ class Readme
|
|
|
31
31
|
attr_reader :result
|
|
32
32
|
attr_reader :data
|
|
33
33
|
|
|
34
|
+
##
|
|
35
|
+
# Initialize Readme instance
|
|
36
|
+
# @param script_path (String) Path to main rb file (start.rb)
|
|
37
|
+
# @param config_path (String) Path to main config file (config.yaml)
|
|
34
38
|
def initialize(script_path, config_path)
|
|
35
39
|
@path = {}
|
|
36
40
|
@path[:script] = script_path
|
|
@@ -76,30 +80,8 @@ class Readme
|
|
|
76
80
|
show_tail
|
|
77
81
|
end
|
|
78
82
|
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
next if group[:actions].empty?
|
|
82
|
-
|
|
83
|
-
puts "\n## #{group[:name]}\n\n"
|
|
84
|
-
group[:readme].each { |line| puts "#{line}\n" }
|
|
85
|
-
previous_host = nil
|
|
86
|
-
group[:actions].each_with_index do |item, index|
|
|
87
|
-
if item[:host].nil? && index.positive?
|
|
88
|
-
item[:host] = group[:actions][0][:host]
|
|
89
|
-
end
|
|
90
|
-
if previous_host.nil? || item[:host] != previous_host
|
|
91
|
-
previous_host = item[:host] || 'null'
|
|
92
|
-
puts format(Lang::get(:goto), previous_host.upcase)
|
|
93
|
-
end
|
|
94
|
-
|
|
95
|
-
weight = ''
|
|
96
|
-
weight = "(x#{item[:weight]}) " if item[:weight] != 1.0
|
|
97
|
-
puts "* #{weight}#{item[:target]}"
|
|
98
|
-
item[:readme].each { |line| puts " * #{line}\n" }
|
|
99
|
-
end
|
|
100
|
-
end
|
|
101
|
-
end
|
|
102
|
-
|
|
83
|
+
##
|
|
84
|
+
# Show README head
|
|
103
85
|
def show_head
|
|
104
86
|
app = Application.instance
|
|
105
87
|
puts '```'
|
|
@@ -107,8 +89,8 @@ class Readme
|
|
|
107
89
|
puts format(Lang::get(:date), Time.now)
|
|
108
90
|
puts format(Lang::get(:version), Application::VERSION)
|
|
109
91
|
puts '```'
|
|
110
|
-
puts "\n
|
|
111
|
-
puts "#
|
|
92
|
+
puts "\n"
|
|
93
|
+
puts "# #{app.test_name}\n"
|
|
112
94
|
|
|
113
95
|
i = 1
|
|
114
96
|
unless @required_hosts.empty?
|
|
@@ -135,6 +117,35 @@ class Readme
|
|
|
135
117
|
end
|
|
136
118
|
end
|
|
137
119
|
|
|
120
|
+
##
|
|
121
|
+
# Show README content
|
|
122
|
+
def show_content
|
|
123
|
+
@data[:groups].each do |group|
|
|
124
|
+
next if group[:actions].empty?
|
|
125
|
+
|
|
126
|
+
puts "\n## #{group[:name].capitalize}\n\n"
|
|
127
|
+
group[:readme].each { |line| puts "#{line}\n" }
|
|
128
|
+
previous_host = nil
|
|
129
|
+
group[:actions].each_with_index do |item, index|
|
|
130
|
+
if item[:host].nil? && index.positive?
|
|
131
|
+
item[:host] = group[:actions][0][:host]
|
|
132
|
+
end
|
|
133
|
+
if previous_host.nil? || item[:host] != previous_host
|
|
134
|
+
previous_host = item[:host] || 'null'
|
|
135
|
+
puts format(Lang::get(:goto), previous_host.upcase)
|
|
136
|
+
end
|
|
137
|
+
|
|
138
|
+
weight = ''
|
|
139
|
+
weight = "(x#{item[:weight]}) " if item[:weight] != 1.0
|
|
140
|
+
last = (item[:target].end_with?('.') ? '' : '.')
|
|
141
|
+
puts "* #{weight}#{item[:target]}#{last}"
|
|
142
|
+
item[:readme].each { |line| puts " * #{line}\n" }
|
|
143
|
+
end
|
|
144
|
+
end
|
|
145
|
+
end
|
|
146
|
+
|
|
147
|
+
##
|
|
148
|
+
# Show README tail
|
|
138
149
|
def show_tail
|
|
139
150
|
return if @global_params.empty?
|
|
140
151
|
|
|
@@ -11,6 +11,9 @@ require 'rainbow'
|
|
|
11
11
|
# * create_dirs
|
|
12
12
|
# * copyfile
|
|
13
13
|
module Skeleton
|
|
14
|
+
##
|
|
15
|
+
# Create teuton project skeleton
|
|
16
|
+
# @param project_dir (String)
|
|
14
17
|
def self.create(project_dir)
|
|
15
18
|
project_name = File.basename(project_dir)
|
|
16
19
|
puts "\n[INFO] Creating #{Rainbow(project_name).bright} project skeleton"
|
|
@@ -19,12 +22,15 @@ module Skeleton
|
|
|
19
22
|
create_main_dir_and_files(project_dir, source_basedir)
|
|
20
23
|
end
|
|
21
24
|
|
|
25
|
+
##
|
|
26
|
+
# Create main dir and files
|
|
27
|
+
# @param project_dir (String)
|
|
28
|
+
# @param source_basedir (String)
|
|
22
29
|
def self.create_main_dir_and_files(project_dir, source_basedir)
|
|
23
30
|
# Directory and files: Ruby script, Configfile, gitignore
|
|
24
31
|
items = [
|
|
25
32
|
{ source: 'files/config.yaml', target: 'config.yaml' },
|
|
26
33
|
{ source: 'files/start.rb', target: 'start.rb' },
|
|
27
|
-
# { source: 'files/README.md', target: 'README.md' },
|
|
28
34
|
{ source: 'files/gitignore', target: '.gitignore' }
|
|
29
35
|
]
|
|
30
36
|
items.each do |item|
|
|
@@ -34,6 +40,9 @@ module Skeleton
|
|
|
34
40
|
end
|
|
35
41
|
end
|
|
36
42
|
|
|
43
|
+
##
|
|
44
|
+
# Create dir
|
|
45
|
+
# @param dirpath (String)
|
|
37
46
|
def self.create_dir(dirpath)
|
|
38
47
|
if Dir.exist? dirpath
|
|
39
48
|
puts "* Exists dir! => #{Rainbow(dirpath).yellow}"
|
|
@@ -47,17 +56,24 @@ module Skeleton
|
|
|
47
56
|
end
|
|
48
57
|
end
|
|
49
58
|
|
|
59
|
+
##
|
|
60
|
+
# Create dirs
|
|
61
|
+
# @param args (Array)
|
|
50
62
|
def self.create_dirs(*args)
|
|
51
63
|
args.each { |arg| create_dir arg }
|
|
52
64
|
end
|
|
53
65
|
|
|
54
|
-
|
|
66
|
+
##
|
|
67
|
+
# Copy file
|
|
68
|
+
# @param source (String) Source file
|
|
69
|
+
# @param dest (String) Dest file
|
|
70
|
+
def self.copyfile(source, dest)
|
|
55
71
|
if File.exist? dest
|
|
56
72
|
puts "* Exists file! => #{Rainbow(dest).yellow}"
|
|
57
73
|
else
|
|
58
|
-
puts "* File not found! => #{Rainbow(
|
|
74
|
+
puts "* File not found! => #{Rainbow(source).yellow}" unless File.exist? source
|
|
59
75
|
begin
|
|
60
|
-
FileUtils.cp(
|
|
76
|
+
FileUtils.cp(source, dest)
|
|
61
77
|
puts "* Create file => #{Rainbow(dest).green}"
|
|
62
78
|
rescue StandardError
|
|
63
79
|
puts "* Create file ERROR => #{Rainbow(dest).red}"
|
data/lib/teuton/report/close.rb
CHANGED
|
@@ -9,6 +9,8 @@ class Report
|
|
|
9
9
|
# * good_weight,d
|
|
10
10
|
# * fail_weight
|
|
11
11
|
# * fail_counter
|
|
12
|
+
# rubocop:disable Metrics/AbcSize
|
|
13
|
+
# rubocop:disable Metrics/MethodLength
|
|
12
14
|
def close
|
|
13
15
|
app = Application.instance
|
|
14
16
|
max = 0.0
|
|
@@ -16,16 +18,16 @@ class Report
|
|
|
16
18
|
fail = 0.0
|
|
17
19
|
fail_counter = 0
|
|
18
20
|
@lines.each do |i|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
21
|
+
next unless i.class.to_s == 'Hash'
|
|
22
|
+
|
|
23
|
+
max += i[:weight] if i[:weight].positive?
|
|
24
|
+
if i[:check]
|
|
25
|
+
good += i[:weight]
|
|
26
|
+
@history += app.letter[:good]
|
|
27
|
+
else
|
|
28
|
+
fail += i[:weight]
|
|
29
|
+
fail_counter += 1
|
|
30
|
+
@history += app.letter[:bad]
|
|
29
31
|
end
|
|
30
32
|
end
|
|
31
33
|
@tail[:max_weight] = max
|
|
@@ -33,9 +35,11 @@ class Report
|
|
|
33
35
|
@tail[:fail_weight] = fail
|
|
34
36
|
@tail[:fail_counter] = fail_counter
|
|
35
37
|
|
|
36
|
-
i = good.to_f / max
|
|
38
|
+
i = good.to_f / max
|
|
37
39
|
i = 0 if i.nan?
|
|
38
40
|
@tail[:grade] = (100.0 * i).round
|
|
39
41
|
@tail[:grade] = 0 if @tail[:unique_fault].positive?
|
|
40
42
|
end
|
|
43
|
+
# rubocop:enable Metrics/AbcSize
|
|
44
|
+
# rubocop:enable Metrics/MethodLength
|
|
41
45
|
end
|
|
@@ -2,16 +2,17 @@
|
|
|
2
2
|
|
|
3
3
|
require 'rainbow'
|
|
4
4
|
require_relative 'json_formatter'
|
|
5
|
+
require_relative 'html_formatter'
|
|
5
6
|
require_relative 'list_formatter'
|
|
6
7
|
require_relative 'txt_formatter'
|
|
7
8
|
require_relative 'yaml_formatter'
|
|
8
9
|
require_relative 'resume_json_formatter'
|
|
10
|
+
require_relative 'resume_html_formatter'
|
|
9
11
|
require_relative 'resume_list_formatter'
|
|
10
12
|
require_relative 'resume_yaml_formatter'
|
|
11
13
|
require_relative 'resume_txt_formatter'
|
|
12
14
|
require_relative 'moodle_csv_formatter'
|
|
13
15
|
require_relative 'csv_formatter'
|
|
14
|
-
#require_relative 'html_formatter'
|
|
15
16
|
require_relative 'xml_formatter'
|
|
16
17
|
|
|
17
18
|
# FormaterFactory module
|
|
@@ -23,7 +24,7 @@ module FormatterFactory
|
|
|
23
24
|
when :csv
|
|
24
25
|
f = CSVFormatter.new(report)
|
|
25
26
|
when :html
|
|
26
|
-
|
|
27
|
+
f = HTMLFormatter.new(report)
|
|
27
28
|
when :json
|
|
28
29
|
f = JSONFormatter.new(report)
|
|
29
30
|
when :list
|
|
@@ -42,12 +43,14 @@ module FormatterFactory
|
|
|
42
43
|
f = ResumeTXTFormatter.new(report, true)
|
|
43
44
|
when :resume_json
|
|
44
45
|
f = ResumeJSONFormatter.new(report)
|
|
46
|
+
when :resume_html
|
|
47
|
+
f = ResumeHTMLFormatter.new(report)
|
|
45
48
|
when :resume_list
|
|
46
49
|
f = ResumeListFormatter.new(report)
|
|
47
50
|
when :resume_yaml
|
|
48
51
|
f = ResumeYAMLFormatter.new(report)
|
|
49
52
|
else
|
|
50
|
-
raise
|
|
53
|
+
raise "[ERROR] FormaterFactory #{format} unkown!"
|
|
51
54
|
end
|
|
52
55
|
f.init(filename)
|
|
53
56
|
f
|
|
@@ -58,14 +61,15 @@ module FormatterFactory
|
|
|
58
61
|
colored_text: 'txt',
|
|
59
62
|
json: 'json',
|
|
60
63
|
list: 'txt',
|
|
64
|
+
txt: 'txt',
|
|
65
|
+
yaml: 'yaml',
|
|
61
66
|
resume_colored_text: 'txt',
|
|
62
67
|
resume_csv: 'csv',
|
|
63
68
|
resume_json: 'json',
|
|
69
|
+
resume_html: 'html',
|
|
64
70
|
resume_list: 'txt',
|
|
65
71
|
resume_txt: 'txt',
|
|
66
|
-
resume_yaml: 'yaml'
|
|
67
|
-
txt: 'txt',
|
|
68
|
-
yaml: 'yaml' }
|
|
72
|
+
resume_yaml: 'yaml' }
|
|
69
73
|
return format.to_s if data[format].nil?
|
|
70
74
|
|
|
71
75
|
data[format]
|