avm-tools 0.99.0 → 0.102.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (198) hide show
  1. checksums.yaml +4 -4
  2. data/lib/avm/app_src.rb +12 -11
  3. data/lib/avm/docker/image.rb +7 -23
  4. data/lib/avm/docker/registry.rb +2 -11
  5. data/lib/avm/docker/runner.rb +32 -6
  6. data/lib/avm/eac_rails_base1/runner/bundle.rb +1 -2
  7. data/lib/avm/eac_redmine_base0/docker_image.rb +52 -0
  8. data/lib/avm/eac_redmine_base0/instance.rb +2 -2
  9. data/lib/avm/eac_webapp_base0/deploy.rb +1 -1
  10. data/lib/avm/eac_webapp_base0/deploy/git_info.rb +1 -1
  11. data/lib/avm/git/auto_commit/rules/manual.rb +1 -1
  12. data/lib/avm/git/commit/file.rb +1 -1
  13. data/lib/avm/git/issue/complete.rb +3 -3
  14. data/lib/avm/git/revision_test.rb +9 -6
  15. data/lib/avm/git/subrepo_check.rb +1 -1
  16. data/lib/avm/git/subrepo_check/show_result.rb +1 -1
  17. data/lib/avm/git/subrepo_checks.rb +1 -1
  18. data/lib/avm/instances/base/dockerizable.rb +1 -0
  19. data/lib/avm/instances/base/entry_keys.rb +6 -1
  20. data/lib/avm/instances/docker_image.rb +15 -0
  21. data/lib/avm/instances/entries.rb +0 -1
  22. data/lib/avm/instances/entry.rb +3 -2
  23. data/lib/avm/instances/entry_keys.rb +3 -0
  24. data/lib/avm/launcher/context.rb +83 -0
  25. data/lib/avm/launcher/context/instance_discovery.rb +56 -0
  26. data/lib/avm/launcher/context/instance_manager.rb +3 -3
  27. data/lib/avm/launcher/context/instance_manager/cached_instance.rb +1 -1
  28. data/lib/avm/launcher/context/settings.rb +53 -0
  29. data/lib/avm/launcher/git.rb +7 -0
  30. data/lib/avm/launcher/git/base.rb +86 -0
  31. data/lib/avm/launcher/git/base/class_methods.rb +28 -0
  32. data/lib/avm/launcher/git/base/dirty_files.rb +23 -0
  33. data/lib/avm/launcher/git/base/remotes.rb +40 -0
  34. data/lib/avm/launcher/git/base/subrepo.rb +44 -0
  35. data/lib/avm/launcher/git/base/underlying.rb +63 -0
  36. data/lib/avm/launcher/git/error.rb +13 -0
  37. data/lib/avm/launcher/git/mirror_update.rb +38 -0
  38. data/lib/avm/launcher/git/publish_base.rb +123 -0
  39. data/lib/avm/launcher/git/remote.rb +55 -0
  40. data/lib/avm/launcher/git/sub_warp_base.rb +33 -0
  41. data/lib/avm/launcher/git/warp_base.rb +67 -0
  42. data/lib/{eac_launcher → avm/launcher}/instances.rb +1 -1
  43. data/lib/avm/launcher/instances/base.rb +5 -4
  44. data/lib/avm/launcher/instances/base/cache.rb +1 -1
  45. data/lib/avm/launcher/instances/error.rb +1 -3
  46. data/lib/avm/launcher/instances/runner_helper.rb +1 -1
  47. data/lib/avm/launcher/paths.rb +4 -0
  48. data/lib/avm/launcher/paths/logical.rb +82 -0
  49. data/lib/avm/launcher/paths/real.rb +44 -0
  50. data/lib/avm/launcher/project.rb +18 -0
  51. data/lib/avm/launcher/publish.rb +4 -0
  52. data/lib/avm/launcher/publish/base.rb +47 -0
  53. data/lib/avm/launcher/publish/check_result.rb +67 -0
  54. data/lib/avm/launcher/ruby.rb +3 -0
  55. data/lib/avm/launcher/ruby/gem.rb +4 -0
  56. data/lib/avm/launcher/ruby/gem/build.rb +125 -0
  57. data/lib/avm/launcher/ruby/gem/specification.rb +63 -0
  58. data/lib/avm/launcher/vendor.rb +3 -0
  59. data/lib/avm/launcher/vendor/github.rb +20 -0
  60. data/lib/avm/projects/stereotype/job_comparator.rb +32 -0
  61. data/lib/avm/projects/stereotypes/git/publish.rb +2 -2
  62. data/lib/avm/projects/stereotypes/git/update.rb +1 -2
  63. data/lib/avm/projects/stereotypes/git/update/subrepo.rb +2 -2
  64. data/lib/avm/projects/stereotypes/git/warp.rb +2 -2
  65. data/lib/avm/projects/stereotypes/git_subrepo.rb +2 -2
  66. data/lib/avm/projects/stereotypes/git_subrepo/publish.rb +2 -2
  67. data/lib/avm/projects/stereotypes/git_subrepo/warp.rb +11 -11
  68. data/lib/avm/projects/stereotypes/git_subtree/publish.rb +2 -2
  69. data/lib/avm/projects/stereotypes/git_subtree/warp.rb +4 -4
  70. data/lib/avm/projects/stereotypes/ruby_gem.rb +2 -2
  71. data/lib/avm/projects/stereotypes/ruby_gem/publish.rb +12 -12
  72. data/lib/avm/projects/stereotypes/ruby_gem/update.rb +4 -0
  73. data/lib/avm/self.rb +9 -0
  74. data/lib/avm/tools/runner.rb +4 -0
  75. data/lib/avm/tools/runner/app_src/version_bump.rb +1 -1
  76. data/lib/avm/tools/runner/config.rb +17 -0
  77. data/lib/avm/tools/runner/config/load_path.rb +48 -0
  78. data/lib/avm/tools/runner/eac_redmine_base0/dev_docker.rb +17 -0
  79. data/lib/avm/tools/runner/eac_redmine_base0/docker.rb +3 -0
  80. data/lib/avm/tools/runner/files/format.rb +2 -2
  81. data/lib/avm/tools/runner/git.rb +2 -2
  82. data/lib/avm/tools/runner/git/commit.rb +2 -2
  83. data/lib/avm/tools/runner/git/deploy.rb +4 -3
  84. data/lib/avm/tools/runner/git/organize.rb +1 -1
  85. data/lib/avm/tools/runner/launcher/instances.rb +1 -1
  86. data/lib/avm/tools/runner/launcher/projects.rb +3 -3
  87. data/lib/avm/tools/runner/launcher/publish.rb +2 -2
  88. data/lib/avm/tools/version.rb +1 -1
  89. data/template/avm/eac_redmine_base0/docker_image/Dockerfile.template +47 -0
  90. data/template/avm/eac_redmine_base0/docker_image/apache_http_virtualhost.conf.template +10 -0
  91. data/template/avm/eac_redmine_base0/docker_image/apache_https_virtualhost.conf.template +16 -0
  92. data/template/avm/eac_redmine_base0/docker_image/install_settings.sh.template +29 -0
  93. data/template/avm/eac_redmine_base0/docker_image/start.sh.template +25 -0
  94. data/template/avm/eac_ubuntu_base0/docker_image/Dockerfile +1 -1
  95. data/vendor/avm-apps/avm-apps.gemspec +1 -1
  96. data/vendor/avm-apps/lib/avm/apps/config.rb +15 -0
  97. data/vendor/avm-apps/lib/avm/apps/jobs/base.rb +1 -1
  98. data/vendor/avm-apps/lib/avm/apps/version.rb +1 -1
  99. data/vendor/eac_cli/eac_cli.gemspec +1 -1
  100. data/vendor/eac_cli/lib/eac_cli/config.rb +19 -0
  101. data/vendor/eac_cli/lib/eac_cli/config/entry.rb +48 -0
  102. data/vendor/eac_cli/lib/eac_cli/config/entry/options.rb +57 -0
  103. data/vendor/eac_cli/lib/eac_cli/config/entry/undefined.rb +26 -0
  104. data/vendor/eac_cli/lib/eac_cli/definition/positional_argument.rb +6 -1
  105. data/vendor/eac_cli/lib/eac_cli/docopt/doc_builder/alternative.rb +3 -1
  106. data/vendor/eac_cli/lib/eac_cli/docopt_runner.rb +4 -8
  107. data/vendor/eac_cli/lib/eac_cli/docopt_runner/{_class_methods.rb → class_methods.rb} +5 -3
  108. data/vendor/eac_cli/lib/eac_cli/docopt_runner/context.rb +18 -0
  109. data/vendor/eac_cli/lib/eac_cli/old_configs.rb +0 -1
  110. data/vendor/eac_cli/lib/eac_cli/old_configs/entry_reader.rb +2 -2
  111. data/vendor/eac_cli/lib/eac_cli/old_configs_bridge.rb +37 -0
  112. data/vendor/eac_cli/lib/eac_cli/runner/after_class_methods.rb +20 -3
  113. data/vendor/eac_cli/lib/eac_cli/runner_with/help.rb +6 -2
  114. data/vendor/eac_cli/lib/eac_cli/runner_with/subcommands.rb +5 -1
  115. data/vendor/eac_cli/lib/eac_cli/speaker.rb +15 -19
  116. data/vendor/eac_cli/lib/eac_cli/speaker/_constants.rb +1 -1
  117. data/vendor/eac_cli/lib/eac_cli/speaker/list.rb +1 -1
  118. data/vendor/eac_cli/lib/eac_cli/speaker/options.rb +38 -0
  119. data/vendor/eac_cli/lib/eac_cli/version.rb +1 -1
  120. data/vendor/eac_cli/spec/lib/eac_cli/speaker_spec.rb +5 -9
  121. data/vendor/eac_config/lib/eac_config/entry.rb +7 -1
  122. data/vendor/eac_config/lib/eac_config/envvars_node.rb +25 -0
  123. data/vendor/eac_config/lib/eac_config/envvars_node/entry.rb +54 -0
  124. data/vendor/eac_config/lib/eac_config/load_path.rb +5 -13
  125. data/vendor/eac_config/lib/eac_config/node.rb +9 -2
  126. data/vendor/eac_config/lib/eac_config/node_entry.rb +2 -23
  127. data/vendor/eac_config/lib/eac_config/node_uri.rb +38 -0
  128. data/vendor/eac_config/lib/eac_config/old_configs.rb +1 -0
  129. data/vendor/eac_config/lib/eac_config/version.rb +1 -1
  130. data/vendor/eac_config/lib/eac_config/yaml_file_node.rb +9 -2
  131. data/vendor/eac_config/lib/eac_config/yaml_file_node/entry.rb +37 -0
  132. data/vendor/eac_config/spec/lib/eac_config/envvars_node/entry_spec.rb +14 -0
  133. data/vendor/eac_config/spec/lib/eac_config/envvars_node_spec.rb +40 -0
  134. data/vendor/eac_config/spec/lib/eac_config/yaml_file_node_spec_files/storage1.yaml +3 -1
  135. data/vendor/eac_config/spec/lib/eac_config/yaml_file_node_spec_files/storage1_2.yaml +2 -1
  136. data/vendor/eac_git/lib/eac_git/executables.rb +4 -0
  137. data/vendor/eac_git/lib/eac_git/local.rb +5 -1
  138. data/vendor/eac_git/lib/eac_git/local/commit/archive.rb +19 -0
  139. data/vendor/eac_git/lib/eac_git/local/subrepo.rb +2 -1
  140. data/vendor/eac_git/lib/eac_git/version.rb +1 -1
  141. data/vendor/eac_ruby_base0/eac_ruby_base0.gemspec +2 -2
  142. data/vendor/eac_ruby_base0/lib/eac_ruby_base0/application.rb +8 -11
  143. data/vendor/eac_ruby_base0/lib/eac_ruby_base0/application_xdg.rb +32 -0
  144. data/vendor/eac_ruby_base0/lib/eac_ruby_base0/jobs_runner.rb +2 -2
  145. data/vendor/eac_ruby_base0/lib/eac_ruby_base0/runner.rb +13 -6
  146. data/vendor/eac_ruby_base0/lib/eac_ruby_base0/runner_with/confirmation.rb +8 -1
  147. data/vendor/eac_ruby_base0/lib/eac_ruby_base0/version.rb +1 -1
  148. data/vendor/eac_ruby_gems_utils/eac_ruby_gems_utils.gemspec +1 -1
  149. data/vendor/eac_ruby_gems_utils/lib/eac_ruby_gems_utils/tests/multiple/decorated_gem.rb +2 -0
  150. data/vendor/eac_ruby_gems_utils/lib/eac_ruby_gems_utils/version.rb +1 -1
  151. data/vendor/eac_ruby_utils/lib/eac_ruby_utils/context.rb +31 -0
  152. data/vendor/eac_ruby_utils/lib/eac_ruby_utils/contextualizable.rb +12 -7
  153. data/vendor/eac_ruby_utils/lib/eac_ruby_utils/patches/module/context.rb +11 -0
  154. data/vendor/eac_ruby_utils/lib/eac_ruby_utils/patches/module/speaker.rb +9 -0
  155. data/vendor/eac_ruby_utils/lib/eac_ruby_utils/simple_cache.rb +10 -2
  156. data/vendor/eac_ruby_utils/lib/eac_ruby_utils/speaker.rb +16 -0
  157. data/vendor/eac_ruby_utils/lib/eac_ruby_utils/speaker/receiver.rb +57 -0
  158. data/vendor/eac_ruby_utils/lib/eac_ruby_utils/speaker/sender.rb +32 -0
  159. data/vendor/eac_ruby_utils/lib/eac_ruby_utils/version.rb +1 -1
  160. data/vendor/{eac_cli/spec/lib → eac_ruby_utils/spec/lib/eac_ruby_utils/patches}/module/speaker_spec.rb +2 -2
  161. data/vendor/eac_ruby_utils/spec/lib/eac_ruby_utils/simple_cache_spec.rb +18 -0
  162. metadata +67 -41
  163. data/lib/avm/configs.rb +0 -22
  164. data/lib/eac_launcher.rb +0 -13
  165. data/lib/eac_launcher/context.rb +0 -81
  166. data/lib/eac_launcher/context/instance_discovery.rb +0 -54
  167. data/lib/eac_launcher/context/settings.rb +0 -51
  168. data/lib/eac_launcher/git.rb +0 -7
  169. data/lib/eac_launcher/git/base.rb +0 -84
  170. data/lib/eac_launcher/git/base/class_methods.rb +0 -26
  171. data/lib/eac_launcher/git/base/dirty_files.rb +0 -21
  172. data/lib/eac_launcher/git/base/remotes.rb +0 -38
  173. data/lib/eac_launcher/git/base/subrepo.rb +0 -42
  174. data/lib/eac_launcher/git/base/underlying.rb +0 -61
  175. data/lib/eac_launcher/git/error.rb +0 -11
  176. data/lib/eac_launcher/git/mirror_update.rb +0 -36
  177. data/lib/eac_launcher/git/publish_base.rb +0 -119
  178. data/lib/eac_launcher/git/remote.rb +0 -53
  179. data/lib/eac_launcher/git/sub_warp_base.rb +0 -31
  180. data/lib/eac_launcher/git/warp_base.rb +0 -54
  181. data/lib/eac_launcher/paths.rb +0 -4
  182. data/lib/eac_launcher/paths/logical.rb +0 -80
  183. data/lib/eac_launcher/paths/real.rb +0 -42
  184. data/lib/eac_launcher/project.rb +0 -16
  185. data/lib/eac_launcher/publish.rb +0 -4
  186. data/lib/eac_launcher/publish/base.rb +0 -45
  187. data/lib/eac_launcher/publish/check_result.rb +0 -65
  188. data/lib/eac_launcher/ruby.rb +0 -3
  189. data/lib/eac_launcher/ruby/gem.rb +0 -4
  190. data/lib/eac_launcher/ruby/gem/build.rb +0 -123
  191. data/lib/eac_launcher/ruby/gem/specification.rb +0 -61
  192. data/lib/eac_launcher/vendor.rb +0 -3
  193. data/lib/eac_launcher/vendor/github.rb +0 -18
  194. data/lib/eac_launcher/version.rb +0 -5
  195. data/vendor/eac_cli/lib/eac_cli/patches/module.rb +0 -4
  196. data/vendor/eac_cli/lib/eac_cli/patches/module/speaker.rb +0 -10
  197. data/vendor/eac_cli/lib/eac_cli/speaker/_class_methods.rb +0 -37
  198. data/vendor/eac_cli/lib/eac_cli/speaker/node.rb +0 -24
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 9ca31a9492b30e0e2f3a549262ae2e25bc42ff70ebbdf8581141b7aae3cb336f
4
- data.tar.gz: '0590c35f7ee979814a50275ab7138dcb30ee98b93cb9f5a9ae38270d62d95e5e'
3
+ metadata.gz: 6182ce43a4fee65202cfec5b9134751ac9b15fb6df367b1393331263264339ef
4
+ data.tar.gz: 5ecb6def157bb85b53115f4bfe3fcda93f290c0a720a16969577d0606de9b1f9
5
5
  SHA512:
6
- metadata.gz: 1b507793500b03c94adbde17d019c7be366cf9f056c3656da04d84f1cc8387352d607570ba1197e369b9a1943de83553920883d5f659bdc03e14a3df0fee0c43
7
- data.tar.gz: 65cc8c6f9831fbea86ea2e98892a539cb9d1c4d2acfe20b0eea45794560ef84ffc8995b1c7ab685446eda2202565571e46fea692ecf28cf1e79b74bf66a3a4b0
6
+ metadata.gz: bd57b81fdfb81500e6426f17c7e981d141547a174e13d6e109a11b16db0987773bf6ab82269d025da663cb6872464ff883d2367a9809f9a5cb878472c09ac380
7
+ data.tar.gz: 17af742c5cf348bb9efec3551000f3ce5f0cd79010d2522b2239c61dc4b294dd9e0806e322a6c81a00401171ef87c5710da5ed9757ec0710a7d0f2c2fa60244b
data/lib/avm/app_src.rb CHANGED
@@ -1,7 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require 'avm/apps/sources/configuration'
4
- require 'eac_launcher/paths/real'
4
+ require 'avm/launcher/paths/real'
5
+ require 'avm/projects/stereotype/job_comparator'
5
6
  require 'eac_ruby_utils/core_ext'
6
7
  require 'avm/projects/stereotypes'
7
8
  require 'i18n'
@@ -20,14 +21,14 @@ module Avm
20
21
  configuration.if_present(&:locale) || ::I18n.default_locale
21
22
  end
22
23
 
23
- # Backward compatibility with [EacLauncher::Paths::Logical].
24
- # @return [EacLauncher::Paths::Real].
24
+ # Backward compatibility with [Avm::Launcher::Paths::Logical].
25
+ # @return [Avm::Launcher::Paths::Real].
25
26
  def real
26
- ::EacLauncher::Paths::Real.new(path.to_path)
27
+ ::Avm::Launcher::Paths::Real.new(path.to_path)
27
28
  end
28
29
 
29
30
  def run_job(job, job_args = [])
30
- stereotypes.each { |stereotype| run_stereotype_job(stereotype, job, job_args) }
31
+ stereotypes_jobs(job, job_args).each(&:run)
31
32
  end
32
33
 
33
34
  private
@@ -37,14 +38,14 @@ module Avm
37
38
  ::Avm::Apps::Sources::Configuration.find_in_path(path)
38
39
  end
39
40
 
40
- def run_stereotype_job(stereotype, job, job_args)
41
+ def stereotypes_jobs(job, job_args)
41
42
  job_class_method = "#{job}_class"
42
- if stereotype.send(job_class_method).present?
43
- puts stereotype.label + ": #{job} class found. Running..."
44
- stereotype.send(job_class_method).new(self, *job_args).run
45
- else
46
- puts stereotype.label + ": #{job} class not found"
43
+ r = []
44
+ stereotypes.each do |stereotype|
45
+ r << stereotype.send(job_class_method).new(self, *job_args) if
46
+ stereotype.send(job_class_method).present?
47
47
  end
48
+ r.sort { |a, b| ::Avm::Projects::Stereotype::JobComparator.new(a, b).result }
48
49
  end
49
50
 
50
51
  def stereotypes_uncached
@@ -3,10 +3,11 @@
3
3
  require 'eac_ruby_utils/core_ext'
4
4
  require 'avm/executables'
5
5
  require 'avm/patches/object/template'
6
+ require 'eac_docker/images/templatized'
6
7
 
7
8
  module Avm
8
9
  module Docker
9
- class Image
10
+ class Image < ::EacDocker::Images::Templatized
10
11
  attr_reader :registry
11
12
  attr_accessor :snapshot
12
13
  attr_accessor :version
@@ -18,10 +19,9 @@ module Avm
18
19
  end
19
20
 
20
21
  def build(extra_args = [])
21
- on_build_dir do
22
- template.apply(self, build_dir)
23
- run_docker_build(extra_args)
24
- end
22
+ nyi "Extra args: #{extra_args}" if extra_args.any?
23
+
24
+ provide
25
25
  end
26
26
 
27
27
  def generator_version
@@ -32,9 +32,10 @@ module Avm
32
32
  ::Avm::Executables.docker.command.append(['push', tag]).system!
33
33
  end
34
34
 
35
- def read_entry(path, _options = {})
35
+ def read_entry(path, options = {})
36
36
  method = path.gsub('.', '_')
37
37
  return send(method) if respond_to?(path, true)
38
+ return instance.read_entry(path, options) if respond_to?(:instance)
38
39
 
39
40
  raise "Method \"#{method}\" not found for entry \"#{path}\""
40
41
  end
@@ -66,23 +67,6 @@ module Avm
66
67
  r += '-snapshot' if snapshot
67
68
  r
68
69
  end
69
-
70
- private
71
-
72
- attr_reader :build_dir
73
-
74
- def run_docker_build(extra_args)
75
- ::Avm::Executables.docker.command.append(
76
- ['build', '-t', tag] + extra_args + [build_dir]
77
- ).system!
78
- end
79
-
80
- def on_build_dir
81
- @build_dir = ::Dir.mktmpdir
82
- yield
83
- ensure
84
- ::FileUtils.rm_rf(@build_dir)
85
- end
86
70
  end
87
71
  end
88
72
  end
@@ -1,11 +1,12 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require 'avm/self/instance'
4
+ require 'eac_docker/registry'
4
5
  require 'eac_ruby_utils/core_ext'
5
6
 
6
7
  module Avm
7
8
  module Docker
8
- class Registry
9
+ class Registry < ::EacDocker::Registry
9
10
  class << self
10
11
  def default
11
12
  @default ||= new(::Avm::Self.instance.read_entry(
@@ -13,16 +14,6 @@ module Avm
13
14
  ))
14
15
  end
15
16
  end
16
-
17
- common_constructor :name
18
-
19
- def to_s
20
- name
21
- end
22
-
23
- def sub(suffix)
24
- self.class.new("#{name}#{suffix}")
25
- end
26
17
  end
27
18
  end
28
19
  end
@@ -43,42 +43,68 @@ module Avm
43
43
  infov 'Registry name', registry
44
44
  infov 'Version?', version?
45
45
  infov 'Snapshot?', snapshot?
46
- infov 'Image name', instance.docker_image.tag
46
+ infov 'Image name', docker_image.tag
47
47
  infov 'Build arguments', build_args
48
48
  infov 'Entrypoint arguments', entrypoint_args
49
49
  end
50
50
 
51
51
  def build
52
- instance.docker_image.build(build_args)
52
+ docker_image.build(build_args)
53
+ success 'Docker image builded'
53
54
  end
54
55
 
55
56
  def build_args
56
57
  parsed.build_arg
57
58
  end
58
59
 
60
+ def docker_container
61
+ instance.docker_container
62
+ end
63
+
64
+ def docker_image
65
+ instance.docker_image
66
+ end
67
+
59
68
  def entrypoint_args
60
69
  parsed.entrypoint_arg
61
70
  end
62
71
 
63
72
  def push
64
- instance.docker_image.push if parsed.push?
73
+ docker_image.push if parsed.push?
65
74
  end
66
75
 
67
76
  def container_run
68
77
  return unless parsed.run?
69
78
 
70
- instance.docker_container.run(
79
+ docker_container.run(
71
80
  entrypoint_args: entrypoint_args,
72
81
  clear: parsed.clear?
73
82
  )
74
83
  end
75
84
 
76
85
  def registry_uncached
77
- parsed.registry_name.if_present(::Avm::Docker::Registry.default) do |v|
78
- ::Avm::Docker::Registry.new(v)
86
+ registry_from_option || registry_from_instance || registry_from_default ||
87
+ fatal_error('No registry defined')
88
+ end
89
+
90
+ def registry_from_option
91
+ parsed.registry_name.if_present { |v| ::Avm::Docker::Registry.new(v) }
92
+ end
93
+
94
+ def registry_from_instance
95
+ if if_respond(:use_default_registry?, true)
96
+ instance.docker_registry_optional.if_present { |v| ::Avm::Docker::Registry.new(v) }
97
+ else
98
+ ::Avm::Docker::Registry.new(instance.docker_registry)
79
99
  end
80
100
  end
81
101
 
102
+ def registry_from_default
103
+ return nil unless if_respond(:use_default_registry?, true)
104
+
105
+ ::Avm::Docker::Registry.default
106
+ end
107
+
82
108
  def snapshot?
83
109
  !parsed.no_snapshot?
84
110
  end
@@ -8,8 +8,7 @@ module Avm
8
8
  module EacRailsBase1
9
9
  class Runner < ::Avm::EacWebappBase0::Runner
10
10
  class Bundle
11
- runner_with ::Avm::EacRailsBase1::RunnerWith::Bundle
12
- runner_definition do
11
+ runner_with ::Avm::EacRailsBase1::RunnerWith::Bundle, :help do
13
12
  desc 'Runs "bundle ...".'
14
13
  pos_arg :'bundle-args', repeat: true, optional: true
15
14
  end
@@ -0,0 +1,52 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'avm/core_ext'
4
+ require 'avm/instances/docker_image'
5
+
6
+ module Avm
7
+ module EacRedmineBase0
8
+ class DockerImage < ::Avm::Instances::DockerImage
9
+ enable_simple_cache
10
+
11
+ REDMINE_SOURCE_HOST_SUBPATH = 'redmine_source'
12
+
13
+ def avm_fs_cache_object_id
14
+ instance.id
15
+ end
16
+
17
+ def redmine_user
18
+ 'redmine'
19
+ end
20
+
21
+ def redmine_user_home
22
+ "/home/#{redmine_user}"
23
+ end
24
+
25
+ def redmine_path
26
+ "#{redmine_user_home}/redmine_app"
27
+ end
28
+
29
+ def start_path
30
+ '/start.sh'
31
+ end
32
+
33
+ private
34
+
35
+ def git_repo_uncached
36
+ ::EacGit::Local.new(instance.source_instance.fs_path)
37
+ end
38
+
39
+ def redmine_source_git_id
40
+ git_repo.rev_parse('HEAD')
41
+ end
42
+
43
+ def redmine_source_path_uncached
44
+ r = provide_dir.join(REDMINE_SOURCE_HOST_SUBPATH)
45
+ ::FileUtils.rm_rf(r.to_path)
46
+ r.mkpath
47
+ git_repo.commit(redmine_source_git_id).archive_to_dir(r).system!
48
+ REDMINE_SOURCE_HOST_SUBPATH
49
+ end
50
+ end
51
+ end
52
+ end
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require 'avm/eac_redmine_base0/data_unit'
4
- require 'avm/eac_ubuntu_base0/docker_image'
4
+ require 'avm/eac_redmine_base0/docker_image'
5
5
  require 'avm/eac_webapp_base0/instance'
6
6
  require 'avm/eac_rails_base1/instance'
7
7
 
@@ -11,7 +11,7 @@ module Avm
11
11
  FILES_UNITS = { files: 'files' }.freeze
12
12
 
13
13
  def docker_image_class
14
- ::Avm::EacUbuntuBase0::DockerImage
14
+ ::Avm::EacRedmineBase0::DockerImage
15
15
  end
16
16
 
17
17
  def docker_run_arguments
@@ -5,7 +5,7 @@ require 'avm/apps/jobs/base'
5
5
  require 'avm/git'
6
6
  require 'avm/patches/object/template'
7
7
  require 'eac_ruby_utils/core_ext'
8
- require 'eac_launcher/git/base'
8
+ require 'avm/launcher/git/base'
9
9
  require 'net/http'
10
10
 
11
11
  module Avm
@@ -42,7 +42,7 @@ module Avm
42
42
  end
43
43
 
44
44
  def git_uncached
45
- ::EacLauncher::Git::Base.new(git_repository_path)
45
+ ::Avm::Launcher::Git::Base.new(git_repository_path)
46
46
  end
47
47
 
48
48
  def instance_branch
@@ -17,7 +17,7 @@ module Avm
17
17
  return nil unless file.commits.any?
18
18
 
19
19
  commits_banner
20
- request_input('Which commit?', list: commits_by_position).if_present do |v|
20
+ input('Which commit?', list: commits_by_position).if_present do |v|
21
21
  new_commit_info.fixup(v)
22
22
  end
23
23
  end
@@ -12,7 +12,7 @@ module Avm
12
12
 
13
13
  attr_reader :git, :diff_tree
14
14
 
15
- # git: [EacLauncher::Git::Base]
15
+ # git: [Avm::Launcher::Git::Base]
16
16
  # diff_tree_tree: a line of command "git diff-tree --no-commit-id -r --full-index"'s output
17
17
  def initialize(git, diff_tree_line)
18
18
  @git = git
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'eac_launcher/git/base'
3
+ require 'avm/launcher/git/base'
4
4
  require 'eac_cli/speaker'
5
5
  require 'eac_ruby_utils/options_consumer'
6
6
  require 'eac_ruby_utils/require_sub'
@@ -12,7 +12,7 @@ module Avm
12
12
  module Issue
13
13
  class Complete
14
14
  include ::EacRubyUtils::SimpleCache
15
- include ::EacCli::Speaker
15
+ enable_speaker
16
16
 
17
17
  attr_reader :skip_validations
18
18
 
@@ -21,7 +21,7 @@ module Avm
21
21
  dir, @skip_validations = consumer.consume_all(:dir, :skip_validations)
22
22
  validate_skip_validations
23
23
  consumer.validate
24
- @git = ::EacLauncher::Git::Base.new(dir)
24
+ @git = ::Avm::Launcher::Git::Base.new(dir)
25
25
  end
26
26
 
27
27
  def start_banner
@@ -13,12 +13,8 @@ module Avm
13
13
 
14
14
  def banner
15
15
  infov 'Revision to test', sha1
16
- on_speaker_node do |node|
17
- node.stderr_line_prefix = ' '
18
- infov '* Subject', commit.subject
19
- infov '* Success?', successful_label
20
- infov '* STDOUT', stdout_cache.content_path
21
- infov '* STDERR', stderr_cache.content_path
16
+ ::EacRubyUtils::Speaker.context.on(::EacCli::Speaker.new(err_line_prefix: ' ')) do
17
+ revision_banner
22
18
  end
23
19
  end
24
20
 
@@ -49,6 +45,13 @@ module Avm
49
45
  ::File.expand_path(git.to_s)
50
46
  end
51
47
 
48
+ def revision_banner
49
+ infov '* Subject', commit.subject
50
+ infov '* Success?', successful_label
51
+ infov '* STDOUT', stdout_cache.content_path
52
+ infov '* STDERR', stderr_cache.content_path
53
+ end
54
+
52
55
  def root_cache
53
56
  ::Avm.fs_cache.child('git', 'revision_test', git_absolute_path.parameterize, sha1,
54
57
  options.fetch(:test_command).to_s.parameterize)
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'eac_launcher/git/base'
3
+ require 'avm/launcher/git/base'
4
4
  require 'eac_ruby_utils/core_ext'
5
5
 
6
6
  module Avm
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'eac_launcher/git/base'
3
+ require 'avm/launcher/git/base'
4
4
  require 'eac_ruby_utils/core_ext'
5
5
 
6
6
  module Avm
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'eac_launcher/git/base'
3
+ require 'avm/launcher/git/base'
4
4
  require 'eac_ruby_utils/core_ext'
5
5
 
6
6
  module Avm
@@ -33,6 +33,7 @@ module Avm
33
33
 
34
34
  def docker_image_uncached
35
35
  r = docker_image_class.new(docker_image_options.fetch(:registry))
36
+ r.instance = self if r.respond_to?(:instance)
36
37
  r.version = docker_image_options[:version] if docker_image_options.key?(:version)
37
38
  r.snapshot = docker_image_options[:snapshot] if docker_image_options.key?(:snapshot)
38
39
  r