tengine_job 0.6.9

Sign up to get free protection for your applications and to get access to all the features.
Files changed (133) hide show
  1. data/.document +5 -0
  2. data/.rspec +1 -0
  3. data/Gemfile +23 -0
  4. data/Gemfile.lock +109 -0
  5. data/README.rdoc +20 -0
  6. data/Rakefile +42 -0
  7. data/VERSION +1 -0
  8. data/examples/0004_retry_one_layer.rb +24 -0
  9. data/examples/0004_retry_one_layer.sh +38 -0
  10. data/examples/0005_retry_two_layer.rb +54 -0
  11. data/examples/0005_retry_two_layer.sh +80 -0
  12. data/examples/0006_retry_three_layer.rb +58 -0
  13. data/examples/0006_retry_three_layer.sh +74 -0
  14. data/examples/0007_simple_jobnet.rb +7 -0
  15. data/examples/0021_dynamic_env.rb +20 -0
  16. data/examples/VERSION +1 -0
  17. data/examples/tengine_job_test.sh +10 -0
  18. data/lib/tengine/job.rb +94 -0
  19. data/lib/tengine/job/category.rb +54 -0
  20. data/lib/tengine/job/connectable.rb +43 -0
  21. data/lib/tengine/job/drivers/job_control_driver.rb +82 -0
  22. data/lib/tengine/job/drivers/job_execution_driver.rb +30 -0
  23. data/lib/tengine/job/drivers/jobnet_control_driver.rb +117 -0
  24. data/lib/tengine/job/drivers/schedule_driver.rb +30 -0
  25. data/lib/tengine/job/dsl_binder.rb +12 -0
  26. data/lib/tengine/job/dsl_evaluator.rb +18 -0
  27. data/lib/tengine/job/dsl_loader.rb +180 -0
  28. data/lib/tengine/job/edge.rb +150 -0
  29. data/lib/tengine/job/element_selector_notation.rb +169 -0
  30. data/lib/tengine/job/end.rb +32 -0
  31. data/lib/tengine/job/executable.rb +74 -0
  32. data/lib/tengine/job/execution.rb +141 -0
  33. data/lib/tengine/job/expansion.rb +37 -0
  34. data/lib/tengine/job/fork.rb +6 -0
  35. data/lib/tengine/job/job.rb +23 -0
  36. data/lib/tengine/job/jobnet.rb +173 -0
  37. data/lib/tengine/job/jobnet/builder.rb +150 -0
  38. data/lib/tengine/job/jobnet/job_state_transition.rb +167 -0
  39. data/lib/tengine/job/jobnet/jobnet_state_transition.rb +110 -0
  40. data/lib/tengine/job/jobnet/state_transition.rb +37 -0
  41. data/lib/tengine/job/jobnet_actual.rb +55 -0
  42. data/lib/tengine/job/jobnet_template.rb +10 -0
  43. data/lib/tengine/job/join.rb +6 -0
  44. data/lib/tengine/job/junction.rb +29 -0
  45. data/lib/tengine/job/killing.rb +30 -0
  46. data/lib/tengine/job/mm_compatibility.rb +6 -0
  47. data/lib/tengine/job/mm_compatibility/connectable.rb +13 -0
  48. data/lib/tengine/job/name_path.rb +31 -0
  49. data/lib/tengine/job/root.rb +16 -0
  50. data/lib/tengine/job/root_jobnet_actual.rb +39 -0
  51. data/lib/tengine/job/root_jobnet_template.rb +49 -0
  52. data/lib/tengine/job/script_executable.rb +235 -0
  53. data/lib/tengine/job/signal.rb +121 -0
  54. data/lib/tengine/job/start.rb +20 -0
  55. data/lib/tengine/job/stoppable.rb +15 -0
  56. data/lib/tengine/job/vertex.rb +172 -0
  57. data/lib/tengine_job.rb +3 -0
  58. data/spec/fixtures/rjn_0001_simple_jobnet_builder.rb +42 -0
  59. data/spec/fixtures/rjn_0002_simple_parallel_jobnet_builder.rb +42 -0
  60. data/spec/fixtures/rjn_0003_fork_join_jobnet_builder.rb +61 -0
  61. data/spec/fixtures/rjn_0004_parallel_jobnet_with_finally_fixture.rb +62 -0
  62. data/spec/fixtures/rjn_0005_retry_two_layer_fixture.rb +153 -0
  63. data/spec/fixtures/rjn_0008_expansion_fixture.rb +32 -0
  64. data/spec/fixtures/rjn_0009_tree_sequential_jobnet_builder.rb +174 -0
  65. data/spec/fixtures/rjn_0010_2jobs_and_1job_parallel_jobnet_builder.rb +39 -0
  66. data/spec/fixtures/rjn_0011_nested_fork_jobnet_builder.rb +96 -0
  67. data/spec/fixtures/rjn_0012_nested_and_finally_builder.rb +157 -0
  68. data/spec/fixtures/rjn_1004_hadoop_job_in_jobnet_fixture.rb +105 -0
  69. data/spec/fixtures/rjn_means_root_jobnet +0 -0
  70. data/spec/fixtures/test_credential_fixture.rb +12 -0
  71. data/spec/fixtures/test_server_fixture.rb +28 -0
  72. data/spec/mongoid.yml +35 -0
  73. data/spec/spec_helper.rb +56 -0
  74. data/spec/sshd/.gitignore +1 -0
  75. data/spec/sshd/id_rsa +51 -0
  76. data/spec/sshd/id_rsa.pub +1 -0
  77. data/spec/sshd/ssh_host_rsa_key +51 -0
  78. data/spec/sshd/ssh_host_rsa_key.pub +1 -0
  79. data/spec/sshd/sshd_config +10 -0
  80. data/spec/sshd/sshd_config.erb +11 -0
  81. data/spec/sshd/tengine_job_test.sh +6 -0
  82. data/spec/support/jobnet_fixture_builder.rb +145 -0
  83. data/spec/support/mongo_index_key_log.rb +91 -0
  84. data/spec/tengine/job/category_spec.rb +193 -0
  85. data/spec/tengine/job/connectable_spec.rb +94 -0
  86. data/spec/tengine/job/drivers/job_controll_driver/connection_error_spec.rb +236 -0
  87. data/spec/tengine/job/drivers/job_controll_driver/duplicated_job_start_spec.rb +302 -0
  88. data/spec/tengine/job/drivers/job_controll_driver/expansion_spec.rb +120 -0
  89. data/spec/tengine/job/drivers/job_controll_driver/stop_spec.rb +159 -0
  90. data/spec/tengine/job/drivers/job_controll_driver_spec.rb +623 -0
  91. data/spec/tengine/job/drivers/job_execution_driver_spec.rb +88 -0
  92. data/spec/tengine/job/drivers/jobnet_control_driver/nested_and_finally_spec.rb +472 -0
  93. data/spec/tengine/job/drivers/jobnet_control_driver/nested_jobnet_spec.rb +231 -0
  94. data/spec/tengine/job/drivers/jobnet_control_driver/stop_jobnet_spec.rb +202 -0
  95. data/spec/tengine/job/drivers/jobnet_control_driver_spec.rb +446 -0
  96. data/spec/tengine/job/drivers/schedule_driver_spec.rb +202 -0
  97. data/spec/tengine/job/dsl_binder_spec.rb +36 -0
  98. data/spec/tengine/job/dsl_loader_spec.rb +403 -0
  99. data/spec/tengine/job/dsls/0013_hadoop_job_run.rb +29 -0
  100. data/spec/tengine/job/dsls/0014_join_and_join.rb +19 -0
  101. data/spec/tengine/job/dsls/0015_fork_and_fork.rb +18 -0
  102. data/spec/tengine/job/dsls/0016_complex_fork_and_join.rb +20 -0
  103. data/spec/tengine/job/dsls/0017_finally.rb +15 -0
  104. data/spec/tengine/job/dsls/0018_expansion.rb +23 -0
  105. data/spec/tengine/job/dsls/0019_execute_job_on_event.rb +16 -0
  106. data/spec/tengine/job/dsls/0020_duplicated_jobnet_name.rb +16 -0
  107. data/spec/tengine/job/dsls/1060_test_dir1/1060_test_dir2/0013_hadoop_job_run.rb +29 -0
  108. data/spec/tengine/job/dsls/2003_expansion/expansion_5.rb +11 -0
  109. data/spec/tengine/job/dsls/VERSION +1 -0
  110. data/spec/tengine/job/dynamic_env_spec.rb +95 -0
  111. data/spec/tengine/job/edge_spec.rb +241 -0
  112. data/spec/tengine/job/element_selector_notation_spec.rb +354 -0
  113. data/spec/tengine/job/examples_spec.rb +62 -0
  114. data/spec/tengine/job/execution_spec.rb +100 -0
  115. data/spec/tengine/job/expansion_spec.rb +116 -0
  116. data/spec/tengine/job/hadoop_job_run_spec.rb +65 -0
  117. data/spec/tengine/job/job_spec.rb +4 -0
  118. data/spec/tengine/job/jobnet/1015_complecated_jobnet_spec.rb +72 -0
  119. data/spec/tengine/job/jobnet_actual_spec.rb +175 -0
  120. data/spec/tengine/job/jobnet_spec.rb +399 -0
  121. data/spec/tengine/job/jobnet_template_spec.rb +240 -0
  122. data/spec/tengine/job/killing_spec.rb +91 -0
  123. data/spec/tengine/job/reset_spec.rb +958 -0
  124. data/spec/tengine/job/reset_spec/4056_1_dump.txt +1 -0
  125. data/spec/tengine/job/root_jobnet_actual_spec.rb +89 -0
  126. data/spec/tengine/job/root_jobnet_template_spec.rb +248 -0
  127. data/spec/tengine/job/script_executable_spec.rb +132 -0
  128. data/spec/tengine/job/stoppable_spec.rb +176 -0
  129. data/spec/tengine/job/vertex_spec.rb +25 -0
  130. data/spec/tengine_job_spec.rb +4 -0
  131. data/tengine_job.gemspec +197 -0
  132. data/tmp/log/.gitignore +1 -0
  133. metadata +296 -0
@@ -0,0 +1,74 @@
1
+ #!/bin/bash
2
+ typeset -i time="$1"
3
+ export LOGFILE=tengine_job_test.log
4
+ echo "`date` tengine_job_test $MM_ACTUAL_JOB_NAME_PATH start" >> $LOGFILE
5
+ case "$MM_ACTUAL_JOB_NAME_PATH" in
6
+ "/jn0006/jn1/jn11/j111" )
7
+ sleep ${J111_SLEEP:=0}
8
+ if [ "$J111_FAIL" = "true" ] ; then
9
+ exit 1
10
+ fi
11
+ ;;
12
+ "/jn0006/jn1/jn11/j112" )
13
+ sleep ${J112_SLEEP:=0}
14
+ if [ "$J112_FAIL" = "true" ] ; then
15
+ exit 1
16
+ fi
17
+ ;;
18
+ "/jn0006/jn1/jn11/finally/jn11_f" )
19
+ sleep ${JN11_F_SLEEP:=0}
20
+ if [ "$JN11_F_FAIL" = "true" ] ; then
21
+ exit 1
22
+ fi
23
+ ;;
24
+ "/jn0006/jn1/j12" )
25
+ sleep ${J12_SLEEP:=0}
26
+ if [ "$JN12_FAIL" = "true" ] ; then
27
+ exit 1
28
+ fi
29
+ ;;
30
+ "/jn0006/jn1/finally/jn1_f" )
31
+ sleep ${JN1_F_SLEEP:=0}
32
+ if [ "$JN1_F_FAIL" = "true" ] ; then
33
+ exit 1
34
+ fi
35
+ ;;
36
+ "/jn0006/jn2/j21" )
37
+ sleep ${J21_SLEEP:=0}
38
+ if [ "$JN21_FAIL" = "true" ] ; then
39
+ exit 1
40
+ fi
41
+ ;;
42
+ "/jn0006/jn2/jn22/j221" )
43
+ sleep ${J221_SLEEP:=0}
44
+ if [ "$J221_FAIL" = "true" ] ; then
45
+ exit 1
46
+ fi
47
+ ;;
48
+ "/jn0006/jn2/jn22/j222" )
49
+ sleep ${J222_SLEEP:=0}
50
+ if [ "$J222_FAIL" = "true" ] ; then
51
+ exit 1
52
+ fi
53
+ ;;
54
+ "/jn0006/jn2/jn22/finally/jn22_f" )
55
+ sleep ${JN22_F_SLEEP:=0}
56
+ if [ "$JN22_F_FAIL" = "true" ] ; then
57
+ exit 1
58
+ fi
59
+ ;;
60
+ "/jn0006/jn2/finally/jn2_f" )
61
+ sleep ${JN2_F_SLEEP:=0}
62
+ if [ "$JN2_F_FAIL" = "true" ] ; then
63
+ exit 1
64
+ fi
65
+ ;;
66
+ "/jn0006/finally/finally/jn_f" )
67
+ sleep ${JN_F_SLEEP:=0}
68
+ if [ "$JN_F_FAIL" = "true" ] ; then
69
+ exit 1
70
+ fi
71
+ ;;
72
+ esac
73
+
74
+ echo "`date` tengine_job_test $MM_ACTUAL_JOB_NAME_PATH finish" >> $LOGFILE
@@ -0,0 +1,7 @@
1
+ require 'tengine_job'
2
+
3
+ jobnet("rjn0007", :server_name => "test_server1", :credential_name => "test_credential1") do
4
+ auto_sequence
5
+ job("j11", "$HOME/tengine_job_test.sh 30 j11")
6
+ job("j12", "$HOME/tengine_job_test.sh 30 j12")
7
+ end
@@ -0,0 +1,20 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'tengine_job'
3
+
4
+ jobnet("rjn0021_1", :server_name => "test_server1", :credential_name => "test_credential1") do
5
+ auto_sequence
6
+ job("j1", "env | sort", :preparation => proc{ "export FOO=BAR" })
7
+ job("j2", "env | sort", :preparation => proc{ "export SERVER_NAME=#{actual_server.name} && export DNS_NAME=#{actual_server.addresses['private_dns_name']}" })
8
+ end
9
+
10
+ jobnet("rjn0021_2") do # :server_name, :credential_nameの指定なし
11
+ auto_sequence
12
+ job("j1", "env | sort", :preparation => proc{ "export FOO=BAR" })
13
+ job("j2", "env | sort", :preparation => proc{ "export SERVER_NAME=#{actual_server.name} && export DNS_NAME=#{actual_server.addresses['private_dns_name']}" })
14
+ end
15
+
16
+ jobnet("rjn0021", :server_name => "test_server1", :credential_name => "test_credential1") do
17
+ auto_sequence
18
+ expansion("rjn0021_1")
19
+ expansion("rjn0021_2")
20
+ end
data/examples/VERSION ADDED
@@ -0,0 +1 @@
1
+ 20111003160000
@@ -0,0 +1,10 @@
1
+ #!/usr/bin/env bash
2
+ typeset -i time="$1"
3
+ export LOGFILE=tengine_job_test.log
4
+ echo "`date` tengine_job_test $2 start" >> $LOGFILE
5
+ if [ "$SLEEP" != "" ] ; then
6
+ sleep ${SLEEP:=0}
7
+ else
8
+ sleep `expr 1 + $time`
9
+ fi
10
+ echo "`date` tengine_job_test $2 finish" >> $LOGFILE
@@ -0,0 +1,94 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'tengine_job'
3
+
4
+ require 'active_support/concern'
5
+
6
+ module Tengine::Job
7
+ autoload :DslEvaluator , "tengine/job/dsl_evaluator"
8
+ autoload :DslLoader , "tengine/job/dsl_loader"
9
+ autoload :DslBinder , "tengine/job/dsl_binder"
10
+
11
+ autoload :Signal , 'tengine/job/signal'
12
+
13
+ autoload :Execution , "tengine/job/execution"
14
+
15
+ autoload :Category , "tengine/job/category"
16
+ autoload :Edge , "tengine/job/edge"
17
+ autoload :Vertex , "tengine/job/vertex"
18
+
19
+ autoload :Start , "tengine/job/start"
20
+ autoload :End , "tengine/job/end"
21
+ autoload :Junction , "tengine/job/junction"
22
+ autoload :Fork , "tengine/job/fork"
23
+ autoload :Join , "tengine/job/join"
24
+
25
+ autoload :Job , "tengine/job/job"
26
+
27
+ autoload :Jobnet , "tengine/job/jobnet"
28
+ autoload :JobnetActual , "tengine/job/jobnet_actual"
29
+ autoload :RootJobnetActual , "tengine/job/root_jobnet_actual"
30
+ autoload :JobnetTemplate , "tengine/job/jobnet_template"
31
+ autoload :RootJobnetTemplate , "tengine/job/root_jobnet_template"
32
+
33
+ autoload :Expansion , "tengine/job/expansion"
34
+
35
+ autoload :Root , "tengine/job/root"
36
+ autoload :NamePath , "tengine/job/name_path"
37
+ autoload :Executable , "tengine/job/executable"
38
+ autoload :Stoppable , "tengine/job/stoppable"
39
+ autoload :Killing , "tengine/job/killing"
40
+ autoload :Connectable , "tengine/job/connectable"
41
+ autoload :ScriptExecutable , "tengine/job/script_executable"
42
+
43
+ autoload :MmCompatibility , "tengine/job/mm_compatibility"
44
+ autoload :ElementSelectorNotation, "tengine/job/element_selector_notation"
45
+
46
+ class << self
47
+ # tengine_coreからそのプラグインへ通知を受けるための
48
+ def notify(sender, msg)
49
+ Tengine::Core.stdout_logger.info("*" * 100)
50
+ Dir[File.expand_path("job/drivers/*.rb", File.dirname(__FILE__))].each do |f|
51
+ Tengine::Core.stdout_logger.info("#{self.name}.notify #{f}")
52
+ end
53
+ # if (msg == :before___evaluate__) # だと、最初にtengine/jobがrequireされる前に実行されるのでフックできません
54
+ if (msg == :after___evaluate__)
55
+ Tengine::Core::Driveable.module_eval{ include Tengine::Job::DslBinder }
56
+ Dir[File.expand_path("job/drivers/*.rb", File.dirname(__FILE__))].each do |f|
57
+ # Tengine::Core.stdout_logger.debug("#{self.name} now evaluating #{f}")
58
+ # sender.instance_eval(File.read(f), f)
59
+ load(f)
60
+ end
61
+ end
62
+ if (msg == :after_load_dsl) && sender.respond_to?(:config)
63
+ # RootJobnetTemplateのdsl_filepathからCategoryを生成します
64
+ Tengine::Job::Category.update_for(sender.config.dsl_dir_path)
65
+ end
66
+ end
67
+
68
+
69
+ # 自動テストで呼び出しをフックするためのメソッド
70
+ def test_harness(idx, msg)
71
+ end
72
+
73
+ # test_harnessメソッドに渡されるidxを初期化します
74
+ def test_harness_clear
75
+ @test_harness_index = 0
76
+ Tengine.logger.debug("#{self.name}.test_harness_clear")
77
+ end
78
+
79
+ # test_harness呼び出すメソッド。
80
+ # ライブラリを提供する側が使用します。
81
+ def test_harness_hook(msg)
82
+ @test_harness_index ||= 0
83
+ @test_harness_index += 1
84
+ Tengine.logger.debug("#{self.name}.test_harness(#{@test_harness_index}, #{msg.inspect})")
85
+ test_harness(@test_harness_index, msg)
86
+ end
87
+
88
+ end
89
+
90
+ # DSLの記述に問題があることを示す例外
91
+ class DslError < ::Tengine::DslError
92
+ end
93
+
94
+ end
@@ -0,0 +1,54 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'tengine/job'
3
+
4
+ require 'yaml'
5
+ require 'tengine/support/yaml_with_erb'
6
+
7
+ class Tengine::Job::Category
8
+ include Mongoid::Document
9
+ include Mongoid::Timestamps
10
+ include Tengine::Core::FindByName
11
+
12
+ field :name , :type => String # カテゴリ名。ディレクトリ名を元に設定されるので、"/"などは使用不可。
13
+ field :caption , :type => String # カテゴリの表示名。各ディレクトリ名に対応する表示名。通常dictionary.ymlに定義する。
14
+
15
+ with_options(:class_name => "Tengine::Job::Category") do |c|
16
+ c.belongs_to :parent, :inverse_of => :children, :index => true
17
+ c.has_many :children, :inverse_of => :parent, :order => [:name, :asc]
18
+ end
19
+
20
+ class << self
21
+ def update_for(base_dir)
22
+ root_dir = File.basename(base_dir)
23
+ dic_dir_base = File.dirname(base_dir)
24
+ root_jobnets = Tengine::Job::RootJobnetTemplate.all
25
+ root_jobnets.each do |root_jobnet|
26
+ dirs = File.dirname(root_jobnet.dsl_filepath || "").split('/') - ['.', '..']
27
+ dirs.unshift(root_dir)
28
+ last_category = nil
29
+ dic_dir = dic_dir_base
30
+ dirs.each do |dir|
31
+ caption = nil
32
+ dic_path = File.expand_path("dictionary.yml", dic_dir)
33
+ if File.exist?(dic_path)
34
+ # TODO dictionary.yml が不正な形の場合の処理が必要
35
+ hash = YAML.load_file(dic_path)
36
+ caption = hash[dir]
37
+ end
38
+ category = Tengine::Job::Category.find_or_create_by(
39
+ :name => dir,
40
+ :caption => caption || dir,
41
+ :parent_id => last_category ? last_category.id : nil)
42
+ dic_dir = File.join(dic_dir, dir)
43
+ last_category = category
44
+ end
45
+ if last_category
46
+ root_jobnet.category_id = last_category.id
47
+ root_jobnet.save!
48
+ end
49
+ end
50
+
51
+ end
52
+ end
53
+
54
+ end
@@ -0,0 +1,43 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'tengine/job'
3
+
4
+ require 'tengine_resource'
5
+
6
+ module Tengine::Job::Connectable
7
+ extend ActiveSupport::Concern
8
+
9
+ included do
10
+ field :server_name , :type => String # 接続先となるサーバ名。Tengine::Resource::Server#name を指定します
11
+ field :credential_name, :type => String # 接続時に必要な認証情報。Tengine::Resource::Credential#name を指定します
12
+
13
+ include Tengine::Job::MmCompatibility::Connectable
14
+
15
+ def actual_credential_name
16
+ credential_name || (parent ? parent.actual_credential_name : nil)
17
+ end
18
+
19
+ def actual_server_name
20
+ server_name || (parent ? parent.actual_server_name : nil)
21
+ end
22
+
23
+ def actual_credential
24
+ key = actual_credential_name
25
+ return nil if key.blank?
26
+ result = Tengine::Resource::Credential.first(:conditions => {:name => key})
27
+ # TODO 使用する例外クラスはこれで良いのか検討
28
+ raise Mongoid::Errors::DocumentNotFound.new(Tengine::Resource::Credential, key) unless result
29
+ result
30
+ end
31
+
32
+ def actual_server
33
+ key = actual_server_name
34
+ return nil if key.blank?
35
+ result = Tengine::Resource::Server.first(:conditions => {:name => key})
36
+ # TODO 使用する例外クラスはこれで良いのか検討
37
+ raise Mongoid::Errors::DocumentNotFound.new(Tengine::Resource::Server, key) unless result
38
+ result
39
+ end
40
+
41
+
42
+ end
43
+ end
@@ -0,0 +1,82 @@
1
+ # -*- coding: utf-8 -*-
2
+
3
+ # ジョブ制御ドライバ
4
+ driver :job_control_driver do
5
+
6
+ on :'start.job.job.tengine' do
7
+ signal = Tengine::Job::Signal.new(event)
8
+ # activate
9
+ root_jobnet = Tengine::Job::RootJobnetActual.find(event[:root_jobnet_id])
10
+ root_jobnet.update_with_lock do
11
+ signal.reset
12
+ target_jobnet = root_jobnet.find_descendant(event[:target_jobnet_id]) || root_jobnet
13
+ target_job = target_jobnet.find_descendant(event[:target_job_id])
14
+ signal.with_paths_backup do
15
+ target_job.activate(signal) # transmitは既にされているはず。
16
+ end
17
+ end
18
+ root_jobnet.reload
19
+ if signal.callback
20
+ block = signal.callback
21
+ signal.callback = nil
22
+ block.call
23
+ end
24
+ if signal.callback
25
+ root_jobnet.update_with_lock(&signal.callback)
26
+ end
27
+ signal.reservations.each{|r| fire(*r.fire_args)}
28
+ end
29
+
30
+ on :'stop.job.job.tengine' do
31
+ signal = Tengine::Job::Signal.new(event)
32
+ root_jobnet = Tengine::Job::RootJobnetActual.find(event[:root_jobnet_id])
33
+ root_jobnet.update_with_lock do
34
+ signal.reset
35
+ target_jobnet = root_jobnet.find_descendant(event[:target_jobnet_id]) || root_jobnet
36
+ target_job = target_jobnet.find_descendant(event[:target_job_id])
37
+ signal.with_paths_backup do
38
+ target_job.stop(signal)
39
+ end
40
+ end
41
+ root_jobnet.reload
42
+ if signal.callback
43
+ signal.callback.call
44
+ end
45
+ signal.reservations.each{|r| fire(*r.fire_args)}
46
+ end
47
+
48
+ on :'finished.process.job.tengine' do
49
+ signal = Tengine::Job::Signal.new(event)
50
+ root_jobnet = Tengine::Job::RootJobnetActual.find(event[:root_jobnet_id])
51
+ # finish
52
+ root_jobnet.update_with_lock do
53
+ signal.reset
54
+ job = root_jobnet.find_descendant(event[:target_job_id])
55
+ job.finish(signal)
56
+ end
57
+ signal.reservations.each{|r| fire(*r.fire_args)}
58
+ end
59
+
60
+ on :'expired.job.heartbeat.tengine' do
61
+ event.tap do |e|
62
+ Tengine::Job::RootJobnetActual.find(e[:root_jobnet_id]).tap do |r|
63
+ r.update_with_lock do
64
+ r.find_descendant(e[:target_job_id]).phase_key = :stuck
65
+ end
66
+ end
67
+ end
68
+ end
69
+
70
+ on :'restart.job.job.tengine' do
71
+ signal = Tengine::Job::Signal.new(event)
72
+ root_jobnet = Tengine::Job::RootJobnetActual.find(event[:root_jobnet_id])
73
+ root_jobnet.update_with_lock do
74
+ signal.reset
75
+ job = root_jobnet.find_descendant(event[:target_job_id])
76
+ job.reset(signal)
77
+ job.transmit(signal)
78
+ end
79
+ signal.reservations.each{|r| fire(*r.fire_args)}
80
+ end
81
+
82
+ end
@@ -0,0 +1,30 @@
1
+ # -*- coding: utf-8 -*-
2
+
3
+ # ジョブ起動ドライバ
4
+ driver :job_execution_driver do
5
+
6
+ on :'start.execution.job.tengine' do
7
+ signal = Tengine::Job::Signal.new(event)
8
+ execution = signal.execution
9
+ root_jobnet = execution.root_jobnet
10
+ root_jobnet.update_with_lock do
11
+ signal.reset
12
+ execution.transmit(signal)
13
+ end
14
+ execution.save!
15
+ signal.reservations.each{|r| fire(*r.fire_args)}
16
+ end
17
+
18
+ on :'stop.execution.job.tengine' do
19
+ signal = Tengine::Job::Signal.new(event)
20
+ execution = signal.execution
21
+ root_jobnet = execution.root_jobnet
22
+ root_jobnet.update_with_lock do
23
+ signal.reset
24
+ execution.stop(signal)
25
+ end
26
+ execution.save!
27
+ signal.reservations.each{|r| fire(*r.fire_args)}
28
+ end
29
+
30
+ end
@@ -0,0 +1,117 @@
1
+ # -*- coding: utf-8 -*-
2
+
3
+ # ジョブネット制御ドライバ
4
+ driver :jobnet_control_driver do
5
+
6
+ on :'start.jobnet.job.tengine' do
7
+ signal = Tengine::Job::Signal.new(event)
8
+ root_jobnet = Tengine::Job::RootJobnetActual.find(event[:root_jobnet_id])
9
+ root_jobnet.update_with_lock do
10
+ signal.reset
11
+ target_jobnet = root_jobnet.find_descendant(event[:target_jobnet_id]) || root_jobnet
12
+ signal.with_paths_backup do
13
+ target_jobnet.activate(signal)
14
+ end
15
+ end
16
+ signal.execution.save! if event[:root_jobnet_id] == event[:target_jobnet_id]
17
+ signal.reservations.each{|r| fire(*r.fire_args)}
18
+ end
19
+
20
+ on :'success.job.job.tengine' do
21
+ signal = Tengine::Job::Signal.new(event)
22
+ root_jobnet = Tengine::Job::RootJobnetActual.find(event[:root_jobnet_id])
23
+ root_jobnet.update_with_lock do
24
+ signal.reset
25
+ target_job = root_jobnet.find_descendant(event[:target_job_id])
26
+ signal.with_paths_backup do
27
+ edge = target_job.next_edges.first
28
+ edge.transmit(signal)
29
+ end
30
+ end
31
+ signal.reservations.each{|r| fire(*r.fire_args)}
32
+ end
33
+
34
+ on :'error.job.job.tengine' do
35
+ signal = Tengine::Job::Signal.new(event)
36
+ root_jobnet = Tengine::Job::RootJobnetActual.find(event[:root_jobnet_id])
37
+ root_jobnet.update_with_lock do
38
+ signal.reset
39
+ target_job = root_jobnet.vertex(event[:target_job_id])
40
+ signal.with_paths_backup do
41
+ edge = target_job.next_edges.first
42
+ edge.close_followings
43
+ edge.transmit(signal)
44
+ end
45
+ # target_jobnet = target_job.parent
46
+ # target_jobnet.jobnet_fail(signal)
47
+ end
48
+ signal.reservations.each{|r| fire(*r.fire_args)}
49
+ end
50
+
51
+ on :'success.jobnet.job.tengine' do
52
+ signal = Tengine::Job::Signal.new(event)
53
+ root_jobnet = Tengine::Job::RootJobnetActual.find(event[:root_jobnet_id])
54
+ root_jobnet.update_with_lock do
55
+ signal.reset
56
+ target_jobnet = root_jobnet.vertex(event[:target_jobnet_id])
57
+ signal.with_paths_backup do
58
+ case target_jobnet.jobnet_type_key
59
+ when :finally then
60
+ parent = target_jobnet.parent
61
+ edge = parent.end_vertex.prev_edges.first
62
+ (edge.closed? || edge.closing?) ?
63
+ parent.fail(signal) :
64
+ parent.succeed(signal)
65
+ else
66
+ if edge = (target_jobnet.next_edges || []).first
67
+ edge.transmit(signal)
68
+ else
69
+ (target_jobnet.parent || signal.execution).succeed(signal)
70
+ end
71
+ end
72
+ end
73
+ end
74
+ signal.execution.save! if event[:root_jobnet_id] == event[:target_jobnet_id]
75
+ signal.reservations.each{|r| fire(*r.fire_args)}
76
+ end
77
+
78
+ on :'error.jobnet.job.tengine' do
79
+ signal = Tengine::Job::Signal.new(event)
80
+ root_jobnet = Tengine::Job::RootJobnetActual.find(event[:root_jobnet_id])
81
+ root_jobnet.update_with_lock do
82
+ signal.reset
83
+ target_jobnet = root_jobnet.find_descendant(event[:target_jobnet_id]) || root_jobnet
84
+ signal.with_paths_backup do
85
+ case target_jobnet.jobnet_type_key
86
+ when :finally then
87
+ target_jobnet.parent.fail(signal)
88
+ else
89
+ if edge = (target_jobnet.next_edges || []).first
90
+ edge.close_followings
91
+ edge.transmit(signal)
92
+ else
93
+ (target_jobnet.parent || signal.execution).fail(signal)
94
+ end
95
+ end
96
+ end
97
+ # if target_parent = target_jobnet.parent
98
+ # target_parent.end_vertex.transmit(signal)
99
+ # end
100
+ end
101
+ signal.execution.save! if event[:root_jobnet_id] == event[:target_jobnet_id]
102
+ signal.reservations.each{|r| fire(*r.fire_args)}
103
+ end
104
+
105
+
106
+ on :'stop.jobnet.job.tengine' do
107
+ signal = Tengine::Job::Signal.new(event)
108
+ root_jobnet = Tengine::Job::RootJobnetActual.find(event[:root_jobnet_id])
109
+ root_jobnet.update_with_lock do
110
+ signal.reset
111
+ target_jobnet = root_jobnet.find_descendant(event[:target_jobnet_id]) || root_jobnet
112
+ target_jobnet.stop(signal)
113
+ end
114
+ signal.reservations.each{|r| fire(*r.fire_args) }
115
+ end
116
+
117
+ end