ehbrs-tools 0.23.0 → 0.25.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.avm.yml +4 -0
- data/.rspec +1 -0
- data/.rubocop.yml +39 -0
- data/Gemfile.lock +269 -0
- data/exe/ehbrs +2 -2
- data/lib/ehbrs/tools/runner/cooking_book/build.rb +52 -0
- data/lib/ehbrs/tools/runner/cooking_book.rb +32 -0
- data/lib/ehbrs/tools/runner/finances/bb_browser.rb +66 -0
- data/lib/ehbrs/{runner/videos/series.rb → tools/runner/finances.rb} +4 -4
- data/lib/ehbrs/tools/runner/fs/selected.rb +81 -0
- data/lib/ehbrs/tools/runner/fs/used_space.rb +161 -0
- data/lib/ehbrs/tools/runner/fs.rb +18 -0
- data/lib/ehbrs/tools/runner/google/translate.rb +89 -0
- data/lib/ehbrs/tools/runner/google.rb +18 -0
- data/lib/ehbrs/tools/runner/music/selected.rb +28 -0
- data/lib/ehbrs/tools/runner/music.rb +18 -0
- data/lib/ehbrs/tools/runner/self/test.rb +27 -0
- data/lib/ehbrs/tools/runner/self.rb +18 -0
- data/lib/ehbrs/tools/runner/telegram/send_message.rb +31 -0
- data/lib/ehbrs/tools/runner/telegram.rb +28 -0
- data/lib/ehbrs/tools/runner/vg/ips.rb +134 -0
- data/lib/ehbrs/tools/runner/vg/wii.rb +74 -0
- data/lib/ehbrs/tools/runner/vg.rb +18 -0
- data/lib/ehbrs/tools/runner/videos/extract.rb +70 -0
- data/lib/ehbrs/tools/runner/videos/probe.rb +34 -0
- data/lib/ehbrs/tools/runner/videos/series/rename.rb +74 -0
- data/lib/ehbrs/tools/runner/videos/series.rb +20 -0
- data/lib/ehbrs/tools/runner/videos/unsupported.rb +61 -0
- data/lib/ehbrs/{runner/web_utils → tools/runner}/videos.rb +3 -3
- data/lib/ehbrs/tools/runner/web_utils/videos/download.rb +75 -0
- data/lib/ehbrs/tools/runner/web_utils/videos/upload.rb +77 -0
- data/lib/ehbrs/tools/runner/web_utils/videos.rb +20 -0
- data/lib/ehbrs/tools/runner/web_utils.rb +26 -0
- data/lib/ehbrs/tools/runner.rb +21 -0
- data/lib/ehbrs/tools/version.rb +1 -1
- data/spec/code/rubocop_spec.rb +3 -0
- data/spec/lib/ehbrs/cooking_book/recipe/measure_spec.rb +21 -0
- data/spec/lib/ehbrs/observers/base_spec.rb +93 -0
- data/spec/lib/ehbrs/tools/runner/fs/used_space_spec.rb +61 -0
- data/spec/lib/ehbrs/tools/runner/vg/ips_spec.rb +31 -0
- data/spec/lib/ehbrs/tools/runner/vg/ips_spec_files/expected.rom +0 -0
- data/spec/lib/ehbrs/tools/runner/vg/ips_spec_files/patch_0.ips +0 -0
- data/spec/lib/ehbrs/tools/runner/vg/ips_spec_files/patch_1.ips +0 -0
- data/spec/lib/ehbrs/tools/runner/vg/ips_spec_files/source.rom +0 -0
- data/spec/lib/ehbrs/tools/runner/videos/probe_spec.rb +19 -0
- data/spec/lib/ehbrs/tools/runner/videos/probe_spec_files/fixed.target.yaml +105 -0
- data/spec/lib/ehbrs/tools/runner/videos/unsupported_spec.rb +75 -0
- data/spec/lib/ehbrs/tools/runner/videos/unsupported_spec_files/dts_audio.probe.yaml +90 -0
- data/spec/lib/ehbrs/tools/runner_spec.rb +16 -0
- data/spec/lib/ehbrs/vg/wii/game_file_spec.rb +21 -0
- data/spec/lib/ehbrs/vg/wii/wit/parsers/dump_spec.rb +11 -0
- data/spec/lib/ehbrs/vg/wii/wit/parsers/dump_spec_files/pikmin2_R92P01_wia.source.witdump +27 -0
- data/spec/lib/ehbrs/vg/wii/wit/parsers/dump_spec_files/pikmin2_R92P01_wia.target.yaml +22 -0
- data/spec/lib/ehbrs/vg/wii/wit/parsers/dump_spec_files/pikmin2_pal_iso.source.witdump +28 -0
- data/spec/lib/ehbrs/vg/wii/wit/parsers/dump_spec_files/pikmin2_pal_iso.target.yaml +21 -0
- data/spec/lib/ehbrs/vg/wii/wit/parsers/dump_spec_files/resident_evil_code_veronica_disc2_iso.source.witdump +16 -0
- data/spec/lib/ehbrs/vg/wii/wit/parsers/dump_spec_files/resident_evil_code_veronica_disc2_iso.target.yaml +19 -0
- data/spec/lib/ehbrs/vg/wii/wit/parsers/dump_spec_files/super_mario_galaxy_wbfs.source.witdump +28 -0
- data/spec/lib/ehbrs/vg/wii/wit/parsers/dump_spec_files/super_mario_galaxy_wbfs.target.yaml +23 -0
- data/spec/lib/ehbrs/vg/wii/wit/path_spec.rb +33 -0
- data/spec/spec_helper/videos.rb +30 -0
- data/spec/spec_helper/videos_files/stub_source.mp4 +0 -0
- data/spec/spec_helper.rb +7 -0
- data/vendor/aranha-parsers/aranha-parsers.gemspec +2 -2
- data/vendor/aranha-parsers/lib/aranha/parsers/rspec/setup.rb +15 -0
- data/vendor/aranha-parsers/lib/aranha/parsers/{spec → rspec}/source_target_fixtures_example.rb +0 -0
- data/vendor/aranha-parsers/lib/aranha/parsers/rspec.rb +11 -0
- data/vendor/aranha-parsers/lib/aranha/parsers/source_address.rb +10 -8
- data/vendor/aranha-parsers/lib/aranha/parsers/version.rb +1 -1
- data/vendor/aranha-parsers/spec/lib/rubocop_check_spec.rb +1 -1
- data/vendor/aranha-parsers/spec/spec_helper.rb +2 -9
- data/vendor/aranha-selenium/aranha-selenium.gemspec +2 -2
- data/vendor/aranha-selenium/lib/aranha/selenium/version.rb +1 -1
- data/vendor/aranha-selenium/spec/rubocop_check_spec.rb +1 -5
- data/vendor/aranha-selenium/spec/spec_helper.rb +2 -98
- data/vendor/eac_cli/eac_cli.gemspec +3 -3
- data/vendor/eac_cli/lib/eac_cli/config/entry.rb +0 -2
- data/vendor/eac_cli/lib/eac_cli/version.rb +1 -1
- data/vendor/eac_cli/spec/rubocop_spec.rb +1 -1
- data/vendor/eac_cli/spec/spec_helper.rb +2 -101
- data/vendor/eac_config/eac_config.gemspec +2 -2
- data/vendor/eac_config/lib/eac_config/version.rb +1 -1
- data/vendor/eac_config/spec/rubocop_spec.rb +1 -1
- data/vendor/eac_config/spec/spec_helper.rb +2 -15
- data/vendor/eac_docker/eac_docker.gemspec +2 -2
- data/vendor/eac_docker/lib/eac_docker/container.rb +7 -3
- data/vendor/eac_docker/lib/eac_docker/debug.rb +15 -0
- data/vendor/eac_docker/lib/eac_docker/images/coded.rb +4 -0
- data/vendor/eac_docker/lib/eac_docker/images/templatized.rb +16 -2
- data/vendor/eac_docker/lib/eac_docker/rspec/setup.rb +17 -0
- data/vendor/eac_docker/lib/eac_docker/rspec.rb +2 -10
- data/vendor/eac_docker/lib/eac_docker/version.rb +1 -1
- data/vendor/eac_docker/spec/rubocop_spec.rb +1 -1
- data/vendor/eac_docker/spec/spec_helper.rb +2 -104
- data/vendor/eac_ruby_base0/eac_ruby_base0.gemspec +4 -4
- data/vendor/eac_ruby_base0/lib/eac_ruby_base0/version.rb +1 -1
- data/vendor/eac_ruby_base0/spec/rubocop_spec.rb +1 -1
- data/vendor/eac_ruby_base0/spec/spec_helper.rb +2 -101
- data/vendor/eac_ruby_utils/eac_ruby_utils.gemspec +1 -1
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/boolean.rb +1 -1
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/envs/executable.rb +15 -3
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/gems_registry/gem.rb +75 -0
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/gems_registry.rb +35 -0
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/recursive_builder.rb +51 -0
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/rspec/default_setup.rb +20 -0
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/rspec/setup/conditionals.rb +17 -0
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/rspec/setup.rb +12 -0
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/rspec/setup_manager.rb +49 -0
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/version.rb +1 -1
- data/vendor/eac_ruby_utils/spec/lib/eac_ruby_utils/recursive_builder_spec.rb +65 -0
- data/vendor/eac_ruby_utils/spec/rubocop_check_spec.rb +1 -1
- data/vendor/eac_ruby_utils/spec/spec_helper.rb +6 -6
- data/vendor/ehbrs_ruby_utils/ehbrs_ruby_utils.gemspec +6 -3
- data/vendor/ehbrs_ruby_utils/lib/ehbrs_ruby_utils/finances/bb_browser/docker_image.rb +18 -0
- data/vendor/ehbrs_ruby_utils/lib/ehbrs_ruby_utils/patches/object/template.rb +6 -0
- data/vendor/ehbrs_ruby_utils/lib/ehbrs_ruby_utils/version.rb +1 -1
- data/vendor/ehbrs_ruby_utils/lib/ehbrs_ruby_utils/videos/stream.rb +11 -1
- data/vendor/ehbrs_ruby_utils/lib/ehbrs_ruby_utils/web_utils/videos/file/rename.rb +28 -0
- data/vendor/ehbrs_ruby_utils/lib/ehbrs_ruby_utils/web_utils/videos/file.rb +11 -8
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec.rb +13 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_attachment.source.yaml +28 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_attachment.target.yaml +7 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_audio.source.yaml +49 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_audio.target.yaml +7 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_subtitle.source.yaml +43 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_subtitle.target.yaml +7 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_video.source.yaml +59 -0
- data/vendor/ehbrs_ruby_utils/spec/lib/ehbrs_ruby_utils/videos/stream_spec_files/menina_ovo_video.target.yaml +7 -0
- data/vendor/ehbrs_ruby_utils/spec/rubocop_check_spec.rb +1 -5
- data/vendor/ehbrs_ruby_utils/spec/spec_helper.rb +2 -98
- data/vendor/ehbrs_ruby_utils/template/ehbrs_ruby_utils/finances/bb_browser/docker_image/Dockerfile +44 -0
- data/vendor/ehbrs_ruby_utils/template/ehbrs_ruby_utils/finances/bb_browser/docker_image/Makefile +35 -0
- data/vendor/ehbrs_ruby_utils/template/ehbrs_ruby_utils/finances/bb_browser/docker_image/README.md +16 -0
- data/vendor/ehbrs_ruby_utils/template/ehbrs_ruby_utils/finances/bb_browser/docker_image/context/firefox.service +8 -0
- data/vendor/ehbrs_ruby_utils/template/ehbrs_ruby_utils/finances/bb_browser/docker_image/context/startbrowser.sh +9 -0
- metadata +149 -40
- data/lib/ehbrs/runner/cooking_book/build.rb +0 -50
- data/lib/ehbrs/runner/cooking_book.rb +0 -30
- data/lib/ehbrs/runner/finances/bb_browser.rb +0 -35
- data/lib/ehbrs/runner/finances.rb +0 -16
- data/lib/ehbrs/runner/fs/selected.rb +0 -79
- data/lib/ehbrs/runner/fs/used_space.rb +0 -159
- data/lib/ehbrs/runner/fs.rb +0 -16
- data/lib/ehbrs/runner/google/translate.rb +0 -87
- data/lib/ehbrs/runner/google.rb +0 -16
- data/lib/ehbrs/runner/music/selected.rb +0 -26
- data/lib/ehbrs/runner/music.rb +0 -16
- data/lib/ehbrs/runner/self/test.rb +0 -25
- data/lib/ehbrs/runner/self.rb +0 -16
- data/lib/ehbrs/runner/telegram/send_message.rb +0 -29
- data/lib/ehbrs/runner/telegram.rb +0 -26
- data/lib/ehbrs/runner/vg/ips.rb +0 -132
- data/lib/ehbrs/runner/vg/wii.rb +0 -72
- data/lib/ehbrs/runner/vg.rb +0 -16
- data/lib/ehbrs/runner/videos/extract.rb +0 -68
- data/lib/ehbrs/runner/videos/probe.rb +0 -32
- data/lib/ehbrs/runner/videos/series/rename.rb +0 -72
- data/lib/ehbrs/runner/videos/unsupported.rb +0 -59
- data/lib/ehbrs/runner/videos.rb +0 -16
- data/lib/ehbrs/runner/web_utils/videos/download.rb +0 -63
- data/lib/ehbrs/runner/web_utils/videos/upload.rb +0 -75
- data/lib/ehbrs/runner/web_utils.rb +0 -24
- data/lib/ehbrs/runner.rb +0 -19
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/rspec/conditional.rb +0 -35
- data/vendor/eac_ruby_utils/lib/eac_ruby_utils/rspec/stubbed_ssh.rb +0 -44
@@ -0,0 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
|
5
|
+
module Ehbrs
|
6
|
+
module Tools
|
7
|
+
class Runner
|
8
|
+
class Videos
|
9
|
+
class Series
|
10
|
+
require_sub __FILE__
|
11
|
+
|
12
|
+
runner_with :help, :subcommands do
|
13
|
+
desc 'Ferramentas para seriados.'
|
14
|
+
subcommands
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,61 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
require 'ehbrs/videos/unsupported/check_set'
|
5
|
+
require 'ehbrs/videos/unsupported/search'
|
6
|
+
require 'ehbrs/videos/unsupported/profiles'
|
7
|
+
|
8
|
+
module Ehbrs
|
9
|
+
module Tools
|
10
|
+
class Runner
|
11
|
+
class Videos
|
12
|
+
class Unsupported
|
13
|
+
PROFILES = %w[aoc philco samsung].freeze
|
14
|
+
|
15
|
+
runner_with :help do
|
16
|
+
desc 'Procura e converte vídeos não suportados pelas TVs de EHB/RS.'
|
17
|
+
bool_opt '-f', '--fix', 'Converte vídeos para o formato apropriado.'
|
18
|
+
arg_opt '-p', '--profiles', "Seleciona os perfis (#{PROFILES.join(', ')})."
|
19
|
+
pos_arg 'paths', repeat: true
|
20
|
+
end
|
21
|
+
|
22
|
+
def run
|
23
|
+
infov 'Profiles', profiles.join(', ')
|
24
|
+
infov 'Paths', paths
|
25
|
+
paths.each do |d|
|
26
|
+
::Ehbrs::Videos::Unsupported::Search.new(d, file_options)
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
private
|
31
|
+
|
32
|
+
def file_check_set_uncached
|
33
|
+
::Ehbrs::Videos::Unsupported::CheckSet.build(profiles, :file)
|
34
|
+
end
|
35
|
+
|
36
|
+
def track_check_set_uncached
|
37
|
+
::Ehbrs::Videos::Unsupported::CheckSet.build(profiles, :track)
|
38
|
+
end
|
39
|
+
|
40
|
+
def paths
|
41
|
+
parsed.paths
|
42
|
+
end
|
43
|
+
|
44
|
+
def file_options
|
45
|
+
{ file_check_set: file_check_set, track_check_set: track_check_set,
|
46
|
+
fix: parsed.fix? }
|
47
|
+
end
|
48
|
+
|
49
|
+
def profiles_uncached
|
50
|
+
parsed.profiles.if_present(PROFILES) { |v| v.split(',').map(&:strip) }
|
51
|
+
.map { |name| profile_class(name).instance }
|
52
|
+
end
|
53
|
+
|
54
|
+
def profile_class(profile_name)
|
55
|
+
::Ehbrs::Videos::Unsupported::Profiles.const_get(profile_name.camelize)
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
@@ -3,13 +3,13 @@
|
|
3
3
|
require 'eac_cli/core_ext'
|
4
4
|
|
5
5
|
module Ehbrs
|
6
|
-
|
7
|
-
class
|
6
|
+
module Tools
|
7
|
+
class Runner
|
8
8
|
class Videos
|
9
9
|
require_sub __FILE__
|
10
10
|
|
11
11
|
runner_with :help, :subcommands do
|
12
|
-
desc '
|
12
|
+
desc 'Video tools for EHB/RS.'
|
13
13
|
subcommands
|
14
14
|
end
|
15
15
|
end
|
@@ -0,0 +1,75 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_ruby_base0/core_ext'
|
4
|
+
require 'ehbrs_ruby_utils/web_utils/videos/file'
|
5
|
+
|
6
|
+
module Ehbrs
|
7
|
+
module Tools
|
8
|
+
class Runner
|
9
|
+
class WebUtils
|
10
|
+
class Videos
|
11
|
+
class Download
|
12
|
+
runner_with :confirmation, :help do
|
13
|
+
desc 'Importa informações de arquivos de vídeo de uma instância EHB/RS Utils.'
|
14
|
+
bool_opt '-d', '--delete', 'Remove vídeos indesejados.'
|
15
|
+
arg_opt '-m', '--move', 'Move vídeos indesejados para o diretório indicado.'
|
16
|
+
end
|
17
|
+
|
18
|
+
def run
|
19
|
+
start_banner
|
20
|
+
to_rename.each { |file| process_rename_file(file) }
|
21
|
+
unwanted.each { |file| process_unwanted_file(file) }
|
22
|
+
end
|
23
|
+
|
24
|
+
private
|
25
|
+
|
26
|
+
def delete?
|
27
|
+
parsed.delete? && !move?
|
28
|
+
end
|
29
|
+
|
30
|
+
def move?
|
31
|
+
parsed.move.present?
|
32
|
+
end
|
33
|
+
|
34
|
+
def start_banner
|
35
|
+
infov 'Files downloaded', files.count
|
36
|
+
infov 'To rename', to_rename.count
|
37
|
+
infov 'Unwanted', unwanted.count
|
38
|
+
end
|
39
|
+
|
40
|
+
def process_rename_file(file)
|
41
|
+
infov " * #{file.new_path}", file.original_path
|
42
|
+
file.rename if confirm?
|
43
|
+
end
|
44
|
+
|
45
|
+
def process_unwanted_file(file)
|
46
|
+
infov " * #{file.new_path}", 'UNWANTED'
|
47
|
+
file.remove if delete? && confirm?
|
48
|
+
file.move(parsed.move) if move? && confirm?
|
49
|
+
end
|
50
|
+
|
51
|
+
def files_uncached
|
52
|
+
data.map { |file_data| ::EhbrsRubyUtils::WebUtils::Videos::File.new(file_data) }
|
53
|
+
end
|
54
|
+
|
55
|
+
def to_rename_uncached
|
56
|
+
files.select(&:path_changed?)
|
57
|
+
end
|
58
|
+
|
59
|
+
def unwanted_uncached
|
60
|
+
files.reject { |f| f.type == 'Videos::SeriesDirectory' }.select(&:unwanted)
|
61
|
+
end
|
62
|
+
|
63
|
+
def data_uncached
|
64
|
+
::JSON.parse(raw_content)
|
65
|
+
end
|
66
|
+
|
67
|
+
def raw_content
|
68
|
+
runner_context.call(:instance).http_request('/videos/files/export').body
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
@@ -0,0 +1,77 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
require 'ehbrs_ruby_utils/web_utils/videos/files_list'
|
5
|
+
require 'json'
|
6
|
+
require 'yaml'
|
7
|
+
|
8
|
+
module Ehbrs
|
9
|
+
module Tools
|
10
|
+
class Runner
|
11
|
+
class WebUtils
|
12
|
+
class Videos
|
13
|
+
class Upload
|
14
|
+
runner_with :help do
|
15
|
+
desc 'Exporta informações de arquivos de vídeo para uma instância EHB/RS Utils.'
|
16
|
+
bool_opt '-P', '--no-ffprobe', 'Não recupera dados com "ffprobe".'
|
17
|
+
end
|
18
|
+
|
19
|
+
def run
|
20
|
+
%w[movies series].each { |type| upload_files_list(type) }
|
21
|
+
end
|
22
|
+
|
23
|
+
def upload_files_list(type)
|
24
|
+
infom "Uploading \"#{type}\" files list..."
|
25
|
+
files_list_path = send("#{type}_files_list")
|
26
|
+
infov 'Path', files_list_path
|
27
|
+
process_response(upload_request(files_list_path))
|
28
|
+
end
|
29
|
+
|
30
|
+
def upload_request(files_list_path)
|
31
|
+
runner_context.call(:instance).http_request(
|
32
|
+
'/videos/files/import',
|
33
|
+
method: :put,
|
34
|
+
body: {
|
35
|
+
'videos_tableless_local_import_list[list_file]' => ::File.new(files_list_path)
|
36
|
+
},
|
37
|
+
header: {
|
38
|
+
'Accept' => 'application/json'
|
39
|
+
}
|
40
|
+
)
|
41
|
+
end
|
42
|
+
|
43
|
+
def process_response(response)
|
44
|
+
infov 'Response status', response.status
|
45
|
+
if response.status == 200
|
46
|
+
pp ::JSON.parse(response.body)
|
47
|
+
else
|
48
|
+
error_file = '/tmp/ehbrsutils.html'
|
49
|
+
::File.write(error_file, response.body)
|
50
|
+
system('firefox', error_file)
|
51
|
+
fatal_error('Retornou com status de erro: ' + error_file)
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
def series_files_list_uncached
|
56
|
+
write_files_list('Videos::SeriesDirectory', :series_directory)
|
57
|
+
end
|
58
|
+
|
59
|
+
def movies_files_list_uncached
|
60
|
+
write_files_list('Videos::MovieFile', :movies_directory)
|
61
|
+
end
|
62
|
+
|
63
|
+
def write_files_list(file_class, read_entry)
|
64
|
+
files_list = ::EhbrsRubyUtils::WebUtils::Videos::FilesList.new(
|
65
|
+
file_class,
|
66
|
+
runner_context.call(:instance).read_entry(read_entry),
|
67
|
+
ffprobe: !parsed.no_ffprobe?
|
68
|
+
)
|
69
|
+
infov 'Files found', files_list.data.fetch(:files).count
|
70
|
+
files_list.write_to
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
|
5
|
+
module Ehbrs
|
6
|
+
module Tools
|
7
|
+
class Runner
|
8
|
+
class WebUtils
|
9
|
+
class Videos
|
10
|
+
require_sub __FILE__
|
11
|
+
|
12
|
+
runner_with :help, :subcommands do
|
13
|
+
desc 'Ferramentas de vídeos para EHB/RS Utils.'
|
14
|
+
subcommands
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_cli/core_ext'
|
4
|
+
require 'ehbrs_ruby_utils/web_utils/instance'
|
5
|
+
|
6
|
+
module Ehbrs
|
7
|
+
module Tools
|
8
|
+
class Runner
|
9
|
+
class WebUtils
|
10
|
+
require_sub __FILE__
|
11
|
+
|
12
|
+
runner_with :help, :subcommands do
|
13
|
+
desc 'Ferramentas para EHB/RS Utils.'
|
14
|
+
pos_arg :instance_id
|
15
|
+
subcommands
|
16
|
+
end
|
17
|
+
|
18
|
+
private
|
19
|
+
|
20
|
+
def instance_uncached
|
21
|
+
::EhbrsRubyUtils::WebUtils::Instance.by_id(parsed.instance_id)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'eac_ruby_base0/runner'
|
4
|
+
require 'ehbrs/tools/application'
|
5
|
+
|
6
|
+
module Ehbrs
|
7
|
+
module Tools
|
8
|
+
class Runner
|
9
|
+
require_sub __FILE__
|
10
|
+
include ::EacRubyBase0::Runner
|
11
|
+
|
12
|
+
runner_definition do
|
13
|
+
desc 'Tools for EHB/RS.'
|
14
|
+
end
|
15
|
+
|
16
|
+
def application
|
17
|
+
::Ehbrs::Tools.application
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
data/lib/ehbrs/tools/version.rb
CHANGED
@@ -0,0 +1,21 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'ehbrs/cooking_book/recipe/measure'
|
4
|
+
|
5
|
+
RSpec.describe ::Ehbrs::CookingBook::Recipe::Measure do
|
6
|
+
describe '#build'
|
7
|
+
{
|
8
|
+
'1.5 cup' => [1.5, nil, 'cup'],
|
9
|
+
'~' => [nil, nil, nil],
|
10
|
+
'2/ 3 u' => [2, 3, 'u'],
|
11
|
+
'4.5/7.8' => [4.5, 7.8, nil]
|
12
|
+
}.each do |source, expected|
|
13
|
+
context "when source is \"#{source}\"" do
|
14
|
+
let(:instance) { described_class.build(source) }
|
15
|
+
|
16
|
+
it { expect(instance.numerator).to eq(expected[0]) }
|
17
|
+
it { expect(instance.denominator).to eq(expected[1]) }
|
18
|
+
it { expect(instance.unit).to eq(expected[2]) }
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
@@ -0,0 +1,93 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'ehbrs/observers/base'
|
4
|
+
|
5
|
+
RSpec.describe ::Ehbrs::Observers::Base do
|
6
|
+
let(:instance) { described_class.new }
|
7
|
+
let(:first_value) { 'a value' }
|
8
|
+
let(:same_value) { first_value.dup }
|
9
|
+
let(:different_value) { 'another value' }
|
10
|
+
let(:first_time) { ::Time.required_zone.local(2020, 5, 1, 12, 45, 0) }
|
11
|
+
let(:second_time) { ::Time.required_zone.local(2020, 5, 1, 12, 45, 0) }
|
12
|
+
|
13
|
+
it { expect(instance.records.count).to be_zero }
|
14
|
+
it { expect(instance.last_change_time).to be_blank }
|
15
|
+
it { expect(instance.last_check_time).to be_blank }
|
16
|
+
|
17
|
+
it { expect(instance).to be_changing_value(nil) }
|
18
|
+
it { expect(instance).to be_changing_value(first_value) }
|
19
|
+
it { expect(instance).to be_changing_value(same_value) }
|
20
|
+
it { expect(instance).to be_changing_value(different_value) }
|
21
|
+
|
22
|
+
context 'when firstly checked' do
|
23
|
+
before { instance.check(first_value, first_time) }
|
24
|
+
|
25
|
+
it { expect(instance.records.count).to eq(1) }
|
26
|
+
it { expect(instance.last_value).to eq(first_value) }
|
27
|
+
it { expect(instance).not_to be_changing_value(same_value) }
|
28
|
+
it { expect(instance).to be_changing_value(different_value) }
|
29
|
+
it { expect(instance.last_change_time).to eq(first_time) }
|
30
|
+
it { expect(instance.last_check_time).to eq(first_time) }
|
31
|
+
|
32
|
+
context 'when same first_value is checked' do
|
33
|
+
before { instance.check(same_value, second_time) }
|
34
|
+
|
35
|
+
it { expect(instance.records.count).to eq(1) }
|
36
|
+
it { expect(instance.last_value).to eq(same_value) }
|
37
|
+
it { expect(instance.last_change_time).to eq(first_time) }
|
38
|
+
it { expect(instance.last_check_time).to eq(second_time) }
|
39
|
+
end
|
40
|
+
|
41
|
+
context 'when different first_value is checked' do
|
42
|
+
before { instance.check(different_value, second_time) }
|
43
|
+
|
44
|
+
it { expect(instance.records.count).to eq(2) }
|
45
|
+
it { expect(instance.last_value).to eq(different_value) }
|
46
|
+
it { expect(instance.last_change_time).to eq(second_time) }
|
47
|
+
it { expect(instance.last_check_time).to eq(second_time) }
|
48
|
+
end
|
49
|
+
|
50
|
+
context 'when checked first_value is blank' do
|
51
|
+
context 'when blank_value == :add' do
|
52
|
+
let(:instance) { described_class.new(blank_value: :add) }
|
53
|
+
|
54
|
+
before { instance.check(nil, second_time) }
|
55
|
+
|
56
|
+
it { expect(instance.records.count).to eq(2) }
|
57
|
+
it { expect(instance.last_value).to eq(nil) }
|
58
|
+
it { expect(instance.last_change_time).to eq(second_time) }
|
59
|
+
it { expect(instance.last_check_time).to eq(second_time) }
|
60
|
+
end
|
61
|
+
|
62
|
+
context 'when blank_value == :ignore' do
|
63
|
+
let(:instance) { described_class.new(blank_value: :ignore) }
|
64
|
+
|
65
|
+
before { instance.check(nil, second_time) }
|
66
|
+
|
67
|
+
it { expect(instance.records.count).to eq(1) }
|
68
|
+
it { expect(instance.last_value).to eq(first_value) }
|
69
|
+
it { expect(instance.last_change_time).to eq(first_time) }
|
70
|
+
it { expect(instance.last_check_time).to eq(second_time) }
|
71
|
+
end
|
72
|
+
|
73
|
+
context 'when blank_value == :raise' do
|
74
|
+
let(:instance) { described_class.new(blank_value: :raise) }
|
75
|
+
|
76
|
+
before do
|
77
|
+
@exception = nil
|
78
|
+
begin
|
79
|
+
instance.check(nil, second_time)
|
80
|
+
rescue StandardError => e
|
81
|
+
@exception = e
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
85
|
+
it { expect(@exception).to be_a(::ArgumentError) } # rubocop:disable RSpec/InstanceVariable
|
86
|
+
it { expect(instance.records.count).to eq(1) }
|
87
|
+
it { expect(instance.last_value).to eq(first_value) }
|
88
|
+
it { expect(instance.last_change_time).to eq(first_time) }
|
89
|
+
it { expect(instance.last_check_time).to eq(second_time) }
|
90
|
+
end
|
91
|
+
end
|
92
|
+
end
|
93
|
+
end
|