eac_tools 0.34.0 → 0.35.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (103) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +24 -18
  3. data/lib/eac_tools/version.rb +1 -1
  4. data/sub/avm/avm.gemspec +1 -1
  5. data/sub/{avm-tools → avm}/lib/avm/launcher/context/instance_collector.rb +0 -0
  6. data/sub/{avm-tools → avm}/lib/avm/launcher/context/instance_discovery.rb +0 -0
  7. data/sub/{avm-tools → avm}/lib/avm/launcher/context/instance_manager/cached_instance.rb +0 -0
  8. data/sub/{avm-tools → avm}/lib/avm/launcher/context/instance_manager/cached_instances.rb +0 -0
  9. data/sub/{avm-tools → avm}/lib/avm/launcher/context/instance_manager.rb +0 -0
  10. data/sub/{avm-tools → avm}/lib/avm/launcher/context/settings.rb +0 -0
  11. data/sub/{avm-tools → avm}/lib/avm/launcher/context.rb +0 -0
  12. data/sub/{avm-tools → avm}/lib/avm/launcher/instances/base/cache.rb +0 -0
  13. data/sub/{avm-tools → avm}/lib/avm/launcher/instances/base.rb +0 -0
  14. data/sub/{avm-tools → avm}/lib/avm/launcher/instances/error.rb +0 -0
  15. data/sub/{avm-tools → avm}/lib/avm/launcher/instances/runner_helper.rb +0 -0
  16. data/sub/{avm-tools → avm}/lib/avm/launcher/instances/settings.rb +0 -0
  17. data/sub/{avm-tools → avm}/lib/avm/launcher/paths/logical.rb +0 -0
  18. data/sub/{avm-tools → avm}/lib/avm/launcher/publish/base.rb +2 -5
  19. data/sub/avm/lib/avm/registry.rb +0 -2
  20. data/sub/avm/lib/avm/version.rb +1 -1
  21. data/sub/avm-eac_webapp_base0/avm-eac_webapp_base0.gemspec +1 -1
  22. data/sub/avm-eac_webapp_base0/lib/avm/eac_webapp_base0/instances/apache_host.rb +2 -1
  23. data/sub/avm-eac_webapp_base0/lib/avm/eac_webapp_base0/version.rb +1 -1
  24. data/sub/avm-git/Gemfile +8 -0
  25. data/sub/avm-git/avm-git.gemspec +22 -0
  26. data/sub/avm-git/lib/avm/git/auto_commit/commit_info.rb +23 -0
  27. data/sub/avm-git/lib/avm/git/auto_commit/rules/base.rb +39 -0
  28. data/sub/avm-git/lib/avm/git/auto_commit/rules/last.rb +19 -0
  29. data/sub/avm-git/lib/avm/git/auto_commit/rules/manual.rb +45 -0
  30. data/sub/avm-git/lib/avm/git/auto_commit/rules/new.rb +24 -0
  31. data/sub/avm-git/lib/avm/git/auto_commit/rules/nth.rb +31 -0
  32. data/sub/avm-git/lib/avm/git/auto_commit/rules/unique.rb +21 -0
  33. data/sub/avm-git/lib/avm/git/auto_commit/rules.rb +31 -0
  34. data/sub/avm-git/lib/avm/git/auto_commit_path/ruby.rb +20 -0
  35. data/sub/avm-git/lib/avm/git/auto_commit_path.rb +28 -0
  36. data/sub/avm-git/lib/avm/git/commit/class_methods.rb +31 -0
  37. data/sub/avm-git/lib/avm/git/commit/deploy.rb +38 -0
  38. data/sub/avm-git/lib/avm/git/commit/deploy_methods.rb +19 -0
  39. data/sub/avm-git/lib/avm/git/commit/diff_tree_line.rb +32 -0
  40. data/sub/avm-git/lib/avm/git/commit/file.rb +46 -0
  41. data/sub/avm-git/lib/avm/git/commit.rb +59 -0
  42. data/sub/avm-git/lib/avm/git/file_auto_fixup.rb +83 -0
  43. data/sub/avm-git/lib/avm/git/issue/complete/commits.rb +42 -0
  44. data/sub/avm-git/lib/avm/git/issue/complete/git_subrepos.rb +23 -0
  45. data/sub/avm-git/lib/avm/git/issue/complete/local_branch.rb +61 -0
  46. data/sub/avm-git/lib/avm/git/issue/complete/local_tag.rb +39 -0
  47. data/sub/avm-git/lib/avm/git/issue/complete/push.rb +60 -0
  48. data/sub/avm-git/lib/avm/git/issue/complete/remote.rb +33 -0
  49. data/sub/avm-git/lib/avm/git/issue/complete/test.rb +40 -0
  50. data/sub/avm-git/lib/avm/git/issue/complete/tracker.rb +28 -0
  51. data/sub/avm-git/lib/avm/git/issue/complete/validation.rb +39 -0
  52. data/sub/avm-git/lib/avm/git/issue/complete/validations.rb +53 -0
  53. data/sub/avm-git/lib/avm/git/issue/complete/working_tree.rb +19 -0
  54. data/sub/avm-git/lib/avm/git/issue/complete.rb +66 -0
  55. data/sub/avm-git/lib/avm/git/issue/deliver.rb +56 -0
  56. data/sub/avm-git/lib/avm/git/issue.rb +11 -0
  57. data/sub/avm-git/lib/avm/git/organize/reference_update.rb +34 -0
  58. data/sub/avm-git/lib/avm/git/organize/repository.rb +76 -0
  59. data/sub/avm-git/lib/avm/git/organize.rb +11 -0
  60. data/sub/avm-git/lib/avm/git/revision_test.rb +105 -0
  61. data/sub/avm-git/lib/avm/git/scms/git/change_tracker.rb +35 -0
  62. data/sub/avm-git/lib/avm/git/scms/git/commit.rb +55 -0
  63. data/sub/avm-git/lib/avm/git/scms/git.rb +73 -0
  64. data/sub/avm-git/lib/avm/git/scms/git_subrepo.rb +39 -0
  65. data/sub/avm-git/lib/avm/git/scms/provider.rb +19 -0
  66. data/sub/avm-git/lib/avm/git/scms.rb +11 -0
  67. data/sub/avm-git/lib/avm/git/subrepo_check/parent.rb +51 -0
  68. data/sub/avm-git/lib/avm/git/subrepo_check/remote.rb +89 -0
  69. data/sub/avm-git/lib/avm/git/subrepo_check/show_result.rb +32 -0
  70. data/sub/avm-git/lib/avm/git/subrepo_check.rb +38 -0
  71. data/sub/avm-git/lib/avm/git/subrepo_checks.rb +59 -0
  72. data/sub/{avm-tools/lib/avm/launcher → avm-git/lib/avm/git}/vendor/github.rb +1 -1
  73. data/sub/avm-git/lib/avm/git/vendor.rb +11 -0
  74. data/sub/avm-git/lib/avm/git/version.rb +7 -0
  75. data/sub/avm-git/lib/avm/git.rb +11 -0
  76. data/sub/avm-git/spec/lib/avm/git/auto_commit_path_spec.rb +21 -0
  77. data/sub/avm-git/spec/lib/avm/git/commit/deploy_spec.rb +93 -0
  78. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec.rb +13 -0
  79. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec_files/add.source.out +1 -0
  80. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec_files/add.target.yaml +7 -0
  81. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec_files/modify.source.out +1 -0
  82. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec_files/modify.target.yaml +7 -0
  83. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec_files/remove.source.out +1 -0
  84. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec_files/remove.target.yaml +7 -0
  85. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec_files/rename.source.out +2 -0
  86. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec_files/rename.target.yaml +13 -0
  87. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec_files/rename_modify.source.out +2 -0
  88. data/sub/avm-git/spec/lib/avm/git/commit/diff_tree_line_spec_files/rename_modify.target.yaml +13 -0
  89. data/sub/avm-git/spec/lib/avm/git/commit_spec.rb +56 -0
  90. data/sub/avm-git/spec/lib/avm/git/scms/git_spec.rb +8 -0
  91. data/sub/avm-git/spec/lib/avm/git/scms/git_subrepo_spec.rb +8 -0
  92. data/sub/{avm-tools/spec/lib/avm/launcher → avm-git/spec/lib/avm/git}/vendor/github_spec.rb +4 -4
  93. data/sub/avm-git/spec/rubocop_spec.rb +3 -0
  94. data/sub/avm-git/spec/spec_helper.rb +4 -0
  95. data/sub/avm-tools/avm-tools.gemspec +2 -2
  96. data/sub/avm-tools/lib/avm/launcher/git/warp_base.rb +2 -2
  97. data/sub/avm-tools/lib/avm/projects/stereotypes/git_subrepo/warp.rb +2 -2
  98. data/sub/avm-tools/lib/avm/tools/version.rb +1 -1
  99. data/sub/eac_docker/eac_docker.gemspec +2 -2
  100. data/sub/eac_docker/lib/eac_docker/images/templatized.rb +7 -1
  101. data/sub/eac_docker/lib/eac_docker/version.rb +1 -1
  102. metadata +97 -23
  103. data/sub/avm-tools/lib/avm/launcher/vendor.rb +0 -3
@@ -0,0 +1,32 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Avm
4
+ module Git
5
+ class Commit
6
+ class DiffTreeLine
7
+ DIFF_TREE_PATTERN = /\A:(\d{6}) (\d{6}) (\S+) (\S+) (\S+)\t(\S.*)\z/.freeze
8
+ FIELDS = %w[src_mode dst_mode src_sha1 dst_sha1 status path].freeze
9
+ GIT_COMMAND_ARGS = %w[-c core.quotepath=off diff-tree --no-commit-id -r --full-index].freeze
10
+
11
+ attr_reader(*FIELDS)
12
+
13
+ # line: a line of command "git [GIT_COMMAND_ARGS]"'s output.
14
+ # Reference: https://git-scm.com/docs/git-diff-tree
15
+ def initialize(line)
16
+ m = DIFF_TREE_PATTERN.match(line.strip)
17
+ raise "\"#{line}\" did not match pattern" unless m
18
+
19
+ FIELDS.count.times { |i| send("#{FIELDS[i]}=", m[i + 1]) }
20
+ end
21
+
22
+ def fields
23
+ FIELDS.map { |field| [field, send(field)] }.to_h
24
+ end
25
+
26
+ private
27
+
28
+ attr_writer(*FIELDS)
29
+ end
30
+ end
31
+ end
32
+ end
@@ -0,0 +1,46 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'active_support/core_ext/module/delegation'
4
+ require 'eac_ruby_utils/simple_cache'
5
+ require 'avm/git/commit/diff_tree_line'
6
+
7
+ module Avm
8
+ module Git
9
+ class Commit
10
+ class File
11
+ include ::EacRubyUtils::SimpleCache
12
+
13
+ attr_reader :git, :diff_tree
14
+
15
+ # git: [EacGit::Local]
16
+ # diff_tree_tree: a line of command "git diff-tree --no-commit-id -r --full-index"'s output
17
+ def initialize(git, diff_tree_line)
18
+ @git = git
19
+ @diff_tree = ::Avm::Git::Commit::DiffTreeLine.new(diff_tree_line)
20
+ end
21
+
22
+ delegate(*::Avm::Git::Commit::DiffTreeLine::FIELDS, to: :diff_tree)
23
+
24
+ def to_s
25
+ "#{path}|#{status}"
26
+ end
27
+
28
+ def src_size_uncached
29
+ size(src_sha1)
30
+ end
31
+
32
+ def dst_size_uncached
33
+ size(dst_sha1)
34
+ end
35
+
36
+ private
37
+
38
+ def size(sha1)
39
+ return 0 if /\A0+\z/.match(sha1)
40
+
41
+ git.command('cat-file', '-s', sha1).execute!.strip.to_i
42
+ end
43
+ end
44
+ end
45
+ end
46
+ end
@@ -0,0 +1,59 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'eac_ruby_utils/core_ext'
4
+
5
+ module Avm
6
+ module Git
7
+ class Commit
8
+ require_sub __FILE__, include_modules: true
9
+ enable_simple_cache
10
+
11
+ FIELDS = {
12
+ author_name: '%an', author_email: '%ae', author_date: '%ai',
13
+ subject: '%s',
14
+ author_all: '%an <%ae>, %ai',
15
+ commiter_name: '%cn', commiter_email: '%ce', commiter_date: '%ci',
16
+ commiter_all: '%cn <%ce>, %ci'
17
+ }.freeze
18
+
19
+ attr_reader :git, :sha1
20
+
21
+ # @param git [EacGit::Local]
22
+ def initialize(git, sha1)
23
+ @git = git
24
+ @sha1 = sha1
25
+ end
26
+
27
+ def format(format)
28
+ git.command('--no-pager', 'log', '-1', "--pretty=format:#{format}", sha1).execute!.strip
29
+ end
30
+
31
+ FIELDS.each do |field, format|
32
+ define_method field do
33
+ format(format)
34
+ end
35
+ end
36
+
37
+ def files_uncached
38
+ diff_tree_execute.each_line.map { |line| ::Avm::Git::Commit::File.new(git, line) }
39
+ end
40
+
41
+ def files_size_uncached
42
+ files.inject(0) { |a, e| a + e.dst_size }
43
+ end
44
+
45
+ def root_child?
46
+ format('%P').blank?
47
+ end
48
+
49
+ private
50
+
51
+ def diff_tree_execute
52
+ args = []
53
+ args << '--root' if root_child?
54
+ args << sha1
55
+ git.command(*::Avm::Git::Commit::DiffTreeLine::GIT_COMMAND_ARGS, *args).execute!
56
+ end
57
+ end
58
+ end
59
+ end
@@ -0,0 +1,83 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'avm/git/auto_commit/commit_info'
4
+ require 'eac_ruby_utils/core_ext'
5
+
6
+ module Avm
7
+ module Git
8
+ class FileAutoFixup
9
+ enable_speaker
10
+ enable_simple_cache
11
+ enable_listable
12
+
13
+ common_constructor :git, :path, :rules do
14
+ self.path = path.to_pathname.expand_path(git.root_path)
15
+ end
16
+
17
+ COMMITS_SEARCH_INTERVAL = 'origin/master..HEAD'
18
+
19
+ def git_relative_path
20
+ path.to_pathname.relative_path_from(git.root_path)
21
+ end
22
+
23
+ def run
24
+ start_banner
25
+ run_commit || warn("No rule returned commit information for \"#{path}\"")
26
+ end
27
+
28
+ private
29
+
30
+ def commit_args
31
+ commit_info.if_present([], &:git_commit_args) + ['--', git_relative_path]
32
+ end
33
+
34
+ def commit_info_uncached
35
+ rules.lazy.map { |rule| rule.with_file(self).commit_info }.find(&:present?)
36
+ end
37
+
38
+ def start_banner
39
+ infov 'Path', path
40
+ infov ' Commits found', commits.count
41
+ end
42
+
43
+ def run_commit
44
+ return false if commit_info.blank?
45
+
46
+ infov ' Commit arguments', ::Shellwords.join(commit_args)
47
+ run_git_add_and_commit
48
+ success ' Commited'
49
+ true
50
+ end
51
+
52
+ def run_git_add_and_commit
53
+ git.execute!('reset', '--soft', 'HEAD')
54
+ if path.exist?
55
+ git.execute!('add', git_relative_path)
56
+ else
57
+ git.execute!('rm', '-f', git_relative_path)
58
+ end
59
+ git.execute!('commit', *commit_args)
60
+ end
61
+
62
+ def commits_uncached
63
+ git.execute!('log', '--pretty=format:%H', COMMITS_SEARCH_INTERVAL, '--', path)
64
+ .each_line.map { |sha1| ::Avm::Git::Commit.new(git, sha1.strip) }
65
+ .reject { |commit| commit.subject.start_with?('fixup!') }
66
+ .each_with_index.map { |commit, index| CommitDelegator.new(commit, index) }
67
+ end
68
+
69
+ class CommitDelegator < ::SimpleDelegator
70
+ attr_reader :index
71
+
72
+ def initialize(commit, index)
73
+ super(commit)
74
+ @index = index
75
+ end
76
+
77
+ def position
78
+ index + 1
79
+ end
80
+ end
81
+ end
82
+ end
83
+ end
@@ -0,0 +1,42 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'avm/result'
4
+
5
+ module Avm
6
+ module Git
7
+ module Issue
8
+ class Complete
9
+ module Commits
10
+ def commits_result
11
+ ::Avm::Result.success_or_error(commits.any?, 'yes', 'none')
12
+ end
13
+
14
+ def commits_uncached
15
+ return [] unless branch_hash && follow_master?
16
+
17
+ interval = remote_master_hash ? "#{remote_master_hash}..#{branch_hash}" : branch_hash
18
+ launcher_git.execute!('rev-list', interval).each_line.map(&:strip)
19
+ end
20
+
21
+ def bifurcations_result
22
+ commits.each do |commit|
23
+ if multiple_parents?(commit)
24
+ return ::Avm::Result.error("#{commit} has multiple parents")
25
+ end
26
+ end
27
+ ::Avm::Result.success('no')
28
+ end
29
+
30
+ def multiple_parents?(commit)
31
+ commit_parents(commit).count > 1
32
+ end
33
+
34
+ def commit_parents(commit)
35
+ launcher_git.execute!('log', '--pretty=%P', '-n', '1', commit).split(' ').map(&:strip)
36
+ .select(&:present?)
37
+ end
38
+ end
39
+ end
40
+ end
41
+ end
42
+ end
@@ -0,0 +1,23 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'avm/git/subrepo_checks'
4
+ require 'eac_git/local'
5
+
6
+ module Avm
7
+ module Git
8
+ module Issue
9
+ class Complete
10
+ module GitSubrepos
11
+ def git_subrepos_result
12
+ return ::Avm::Result.error('Unclean workspace') unless clean_workspace?
13
+
14
+ infom 'Checking Git subrepos...'
15
+ r = ::Avm::Git::SubrepoChecks.new(::EacGit::Local.new(launcher_git)).add_all_subrepos
16
+ r.check_remote = true
17
+ r.result
18
+ end
19
+ end
20
+ end
21
+ end
22
+ end
23
+ end
@@ -0,0 +1,61 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'avm/result'
4
+
5
+ module Avm
6
+ module Git
7
+ module Issue
8
+ class Complete
9
+ module LocalBranch
10
+ NO_CURRENT_BRANCH_NAME = 'none'
11
+
12
+ # Retrieves the current local branch.
13
+ #
14
+ # @return [EacGit::Local::Branch, nil]
15
+ def branch_uncached
16
+ eac_git.current_branch
17
+ end
18
+
19
+ def branch_hash_uncached
20
+ branch.if_present(&:current_commit_id)
21
+ end
22
+
23
+ def branch_name
24
+ branch.if_present(NO_CURRENT_BRANCH_NAME, &:name)
25
+ end
26
+
27
+ def branch_name_result
28
+ ::Avm::Result.success_or_error(issue_id.present?, branch_name)
29
+ end
30
+
31
+ def branch_hash_result
32
+ ::Avm::Result.success_or_error(
33
+ branch_hash.present?,
34
+ branch_hash
35
+ )
36
+ end
37
+
38
+ def follow_master_result
39
+ return ::Avm::Result.neutral('No branch hash') unless branch_hash
40
+
41
+ r = follow_master?
42
+ ::Avm::Result.success_or_error(r, 'yes', 'no')
43
+ end
44
+
45
+ def follow_master?
46
+ remote_master_hash ? launcher_git.descendant?(branch_hash, remote_master_hash) : true
47
+ end
48
+
49
+ def remove_local_branch
50
+ return unless branch
51
+
52
+ info 'Removendo branch local...'
53
+ bn = branch_name
54
+ git_execute(['checkout', branch_hash])
55
+ git_execute(['branch', '-D', bn])
56
+ end
57
+ end
58
+ end
59
+ end
60
+ end
61
+ end
@@ -0,0 +1,39 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'avm/result'
4
+
5
+ module Avm
6
+ module Git
7
+ module Issue
8
+ class Complete
9
+ module LocalTag
10
+ def assert_tag
11
+ if tag_hash
12
+ return if tag_hash == branch_hash
13
+
14
+ delete_tag
15
+ end
16
+ create_tag
17
+ end
18
+
19
+ def delete_tag
20
+ info 'Removendo tag...'
21
+ git_execute(['tag', '-d', branch_name])
22
+ end
23
+
24
+ def tag
25
+ "refs/tags/#{branch_name}"
26
+ end
27
+
28
+ def tag_hash
29
+ launcher_git.rev_parse(tag)
30
+ end
31
+
32
+ def create_tag
33
+ git_execute(['tag', branch_name, branch_hash])
34
+ end
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end
@@ -0,0 +1,60 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Avm
4
+ module Git
5
+ module Issue
6
+ class Complete
7
+ module Push
8
+ def dry_push_args
9
+ %w[push --dry-run] + [remote_name] + pushs
10
+ end
11
+
12
+ def dry_push_result
13
+ return ::Avm::Result.error('Nothing to push') if pushs.empty?
14
+
15
+ dry_push_execution_result
16
+ end
17
+
18
+ def push
19
+ if pushs.empty?
20
+ info 'PUSH: Nada a enviar'
21
+ else
22
+ info "PUSH: enviando \"#{pushs}\"..."
23
+ git_execute(%w[push origin] + pushs)
24
+ end
25
+ end
26
+
27
+ def pushs_uncached
28
+ [master_push, remove_branch_push, tag_push].reject(&:nil?)
29
+ end
30
+
31
+ def master_push
32
+ remote_master_hash != branch_hash ? "#{branch_hash}:refs/heads/master" : nil
33
+ end
34
+
35
+ def remove_branch_push
36
+ remote_branch_hash ? ":refs/heads/#{branch.name}" : nil
37
+ end
38
+
39
+ def tag_push
40
+ return nil unless !remote_tag_hash || remote_tag_hash != branch_hash
41
+
42
+ "#{branch_hash}:#{tag}"
43
+ end
44
+
45
+ private
46
+
47
+ def dry_push_execution_result
48
+ r = launcher_git.execute(dry_push_args)
49
+ message = if r.fetch(:exit_code).zero?
50
+ 'ok'
51
+ else
52
+ r.fetch(:stderr) + "\n#{::Shellwords.join(dry_push_args)}"
53
+ end
54
+ ::Avm::Result.success_or_error(r.fetch(:exit_code).zero?, message)
55
+ end
56
+ end
57
+ end
58
+ end
59
+ end
60
+ end
@@ -0,0 +1,33 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Avm
4
+ module Git
5
+ module Issue
6
+ class Complete
7
+ module Remote
8
+ def remote_master_hash
9
+ remote_hashs['refs/heads/master']
10
+ end
11
+
12
+ def remote_branch_hash
13
+ remote_hashs["refs/heads/#{branch.name}"]
14
+ end
15
+
16
+ def remote_tag_hash
17
+ remote_hashs[tag]
18
+ end
19
+
20
+ private
21
+
22
+ def remote_name
23
+ 'origin'
24
+ end
25
+
26
+ def remote_hashs_uncached
27
+ launcher_git.remote_hashs(remote_name)
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,40 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'avm/sources/configuration'
4
+ require 'avm/result'
5
+ require 'avm/sources/base'
6
+ require 'avm/sources/tests/builder'
7
+ require 'eac_ruby_utils/fs/temp'
8
+
9
+ module Avm
10
+ module Git
11
+ module Issue
12
+ class Complete
13
+ module Test
14
+ def test_result
15
+ infom 'Running tests...'
16
+ test_performer.units.each do |single|
17
+ return ::Avm::Result.error(test_failed_result_message(single)) if single.failed?
18
+ end
19
+ ::Avm::Result.success('all passed')
20
+ end
21
+
22
+ private
23
+
24
+ def test_failed_result_message(single)
25
+ { 'Source' => single, 'STDOUT' => single.logs[:stdout],
26
+ 'STDERR' => single.logs[:stderr] }.map { |k, v| "#{k}: #{v}" }.join(', ')
27
+ end
28
+
29
+ def test_performer
30
+ ::Avm::Sources::Tests::Builder
31
+ .new(::Avm::Registry.sources.detect(launcher_git))
32
+ .include_main(true)
33
+ .include_subs(true)
34
+ .performer
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
@@ -0,0 +1,28 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'clipboard'
4
+
5
+ module Avm
6
+ module Git
7
+ module Issue
8
+ class Complete
9
+ module Tracker
10
+ def clipboard_copy_tracker_message
11
+ ::Clipboard.copy(textile_tracker_message)
12
+ infov 'Copied to clipboard', textile_tracker_message
13
+ end
14
+
15
+ private
16
+
17
+ def textile_tracker_message_uncached
18
+ "Revisado para commit:#{branch_short_hash}, ok."
19
+ end
20
+
21
+ def branch_short_hash
22
+ git_execute(['log', '--pretty=format:%h', '-1', '-q', branch_hash])
23
+ end
24
+ end
25
+ end
26
+ end
27
+ end
28
+ end
@@ -0,0 +1,39 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'avm/result'
4
+ require 'eac_ruby_utils/core_ext'
5
+
6
+ module Avm
7
+ module Git
8
+ module Issue
9
+ class Complete
10
+ class Validation
11
+ enable_simple_cache
12
+ common_constructor :parent, :key, :label
13
+
14
+ SKIPPED_RESULT_MESSAGE = 'skipped'
15
+
16
+ def skip?
17
+ parent.skip_validations.include?(key)
18
+ end
19
+
20
+ private
21
+
22
+ def result_uncached
23
+ skip? ? skipped_result : validation_result
24
+ end
25
+
26
+ def skipped_result
27
+ ::Avm::Result.neutral(SKIPPED_RESULT_MESSAGE)
28
+ end
29
+
30
+ def validation_result
31
+ parent.send("#{key}_result")
32
+ rescue ::RuntimeError => e
33
+ ::Avm::Result.error("error raised: #{e.message}")
34
+ end
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end
@@ -0,0 +1,53 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'avm/git/issue/complete/validation'
4
+ require 'avm/result'
5
+ require 'ostruct'
6
+
7
+ module Avm
8
+ module Git
9
+ module Issue
10
+ class Complete
11
+ module Validations
12
+ VALIDATIONS = {
13
+ clean_workspace: 'Clean workspace?',
14
+ branch_name: 'Branch name',
15
+ branch_hash: 'Branch hash',
16
+ follow_master: 'Follow master?',
17
+ commits: 'Commits?',
18
+ bifurcations: 'Bifurcations?',
19
+ dry_push: 'Dry push?',
20
+ git_subrepos: 'Git subrepos ok?',
21
+ test: 'Test ok?'
22
+ }.with_indifferent_access.freeze
23
+
24
+ def valid?
25
+ validations.map(&:result).none?(&:error?)
26
+ end
27
+
28
+ def validations_banner
29
+ validations.each do |v|
30
+ infov "[#{v.key}] #{v.label}", v.result.label
31
+ end
32
+ end
33
+
34
+ def validate_skip_validations
35
+ skip_validations.each do |validation|
36
+ next if VALIDATIONS.keys.include?(validation)
37
+
38
+ raise "\"#{validation}\" is not a registered validation"
39
+ end
40
+ end
41
+
42
+ private
43
+
44
+ def validations_uncached
45
+ VALIDATIONS.map do |key, label|
46
+ ::Avm::Git::Issue::Complete::Validation.new(self, key, label)
47
+ end
48
+ end
49
+ end
50
+ end
51
+ end
52
+ end
53
+ end
@@ -0,0 +1,19 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Avm
4
+ module Git
5
+ module Issue
6
+ class Complete
7
+ module WorkingTree
8
+ def clean_workspace_result
9
+ ::Avm::Result.success_or_error(clean_workspace?, 'yes', 'no')
10
+ end
11
+
12
+ def clean_workspace?
13
+ launcher_git.dirty_files.none?
14
+ end
15
+ end
16
+ end
17
+ end
18
+ end
19
+ end