pione 0.1.4 → 0.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (270) hide show
  1. data/.gitignore +4 -3
  2. data/.simplecov +7 -0
  3. data/.travis.yml +8 -0
  4. data/Gemfile +3 -0
  5. data/History.txt +13 -0
  6. data/README.md +2 -0
  7. data/Rakefile +16 -6
  8. data/bin/pione-val +5 -0
  9. data/example/AbstractRule/package.yml +1 -0
  10. data/example/HelloWorld/package.yml +2 -0
  11. data/example/HelloWorld/scenario/scenario.yml +2 -0
  12. data/example/LoopByTouch/LoopByTouch.pione +28 -0
  13. data/example/LoopByTouch/package.yml +1 -0
  14. data/example/MakePair/package.yml +2 -0
  15. data/example/MakePair/{data → scenario/input}/1.i +0 -0
  16. data/example/MakePair/{data → scenario/input}/2.i +0 -0
  17. data/example/MakePair/{data → scenario/input}/3.i +0 -0
  18. data/example/MakePair/{data → scenario/input}/4.i +0 -0
  19. data/example/MakePair/{data → scenario/input}/5.i +0 -0
  20. data/example/MakePair/scenario/scenario.yml +1 -0
  21. data/example/ScoreAggregation/ScoreAggregation.pione +122 -0
  22. data/example/ScoreAggregation/bin/apply-template.rb +10 -0
  23. data/example/ScoreAggregation/bin/histgram-graph.sh +18 -0
  24. data/example/ScoreAggregation/bin/mean-summary.rb +10 -0
  25. data/example/ScoreAggregation/bin/personal-bar-graph.sh +18 -0
  26. data/example/ScoreAggregation/bin/personal-pre-statistics.rb +37 -0
  27. data/example/ScoreAggregation/bin/total-mean.rb +10 -0
  28. data/example/ScoreAggregation/bin/total-statistics.rb +43 -0
  29. data/example/ScoreAggregation/generate-data.rb +63 -0
  30. data/example/ScoreAggregation/package.yml +1 -0
  31. data/example/ScoreAggregation/scenario/case1/input/A.score +15 -0
  32. data/example/ScoreAggregation/scenario/case1/input/B.score +15 -0
  33. data/example/ScoreAggregation/scenario/case1/input/C.score +15 -0
  34. data/example/ScoreAggregation/scenario/case1/input/D.score +15 -0
  35. data/example/ScoreAggregation/scenario/case1/input/E.score +15 -0
  36. data/example/ScoreAggregation/scenario/case1/input/F.score +15 -0
  37. data/example/ScoreAggregation/scenario/case1/input/G.score +15 -0
  38. data/example/ScoreAggregation/scenario/case1/input/H.score +15 -0
  39. data/example/ScoreAggregation/scenario/case1/input/I.score +15 -0
  40. data/example/ScoreAggregation/scenario/case1/input/J.score +15 -0
  41. data/example/ScoreAggregation/scenario/case1/input/K.score +15 -0
  42. data/example/ScoreAggregation/scenario/case1/input/L.score +15 -0
  43. data/example/ScoreAggregation/scenario/case1/input/M.score +15 -0
  44. data/example/ScoreAggregation/scenario/case1/input/N.score +15 -0
  45. data/example/ScoreAggregation/scenario/case1/input/O.score +15 -0
  46. data/example/ScoreAggregation/scenario/case1/input/P.score +15 -0
  47. data/example/ScoreAggregation/scenario/case1/input/Q.score +15 -0
  48. data/example/ScoreAggregation/scenario/case1/input/R.score +15 -0
  49. data/example/ScoreAggregation/scenario/case1/input/S.score +15 -0
  50. data/example/ScoreAggregation/scenario/case1/input/T.score +15 -0
  51. data/example/ScoreAggregation/scenario/case1/input/U.score +15 -0
  52. data/example/ScoreAggregation/scenario/case1/input/V.score +15 -0
  53. data/example/ScoreAggregation/scenario/case1/input/W.score +15 -0
  54. data/example/ScoreAggregation/scenario/case1/input/X.score +15 -0
  55. data/example/ScoreAggregation/scenario/case1/input/Y.score +15 -0
  56. data/example/ScoreAggregation/scenario/case1/input/Z.score +15 -0
  57. data/example/ScoreAggregation/scenario/case1/input/stat-template.erb +24 -0
  58. data/example/ScoreAggregation/scenario/case1/scenario.yml +3 -0
  59. data/example/{SequentialProcess/SequentialProcess.pione → SerialProcessing/SerialProcessing.pione} +0 -0
  60. data/example/SerialProcessing/package.yml +1 -0
  61. data/example/WorkflowPatterns/01_Sequence/Sequence.pione +21 -0
  62. data/example/WorkflowPatterns/02_PrallelSplit/ParallelSplit.pione +29 -0
  63. data/example/WorkflowPatterns/03_Synchronization/Synchronization.pione +30 -0
  64. data/example/WorkflowPatterns/04_ExclusiveChoice/ExclusiveChoice.pione +44 -0
  65. data/example/WorkflowPatterns/05_SimpleMerge/SimpleMerge.pione +44 -0
  66. data/example/WorkflowPatterns/06_MultiChoice/MultiChoice.pione +48 -0
  67. data/example/WorkflowPatterns/07_StructuredSynchronizingMerge/StructuredSynchronizingMerge.pione +71 -0
  68. data/example/WorkflowPatterns/08_MultiMerge/MultiMerge.pione +44 -0
  69. data/example/WorkflowPatterns/11_ImplicitTermination/ImplicitTermination.pione +29 -0
  70. data/example/WorkflowPatterns/12_MultipleInstancesWithoutSynchronization/MultipleInstancesWithoutSynchronization.pione +29 -0
  71. data/example/WorkflowPatterns/13_MultipleInstancesWithDesignTimeKnowledge/MultipleInstancesWithDesignTimeKnowledge.pione +28 -0
  72. data/example/WorkflowPatterns/14_MultipleInstancesWithRunTimeKnowledge/MultipleInstancesWithRunTimeKnowledge.pione +33 -0
  73. data/example/WorkflowPatterns/33_GeneralizedANDJoin/GeneralizedANDJoin.pione +21 -0
  74. data/example/WorkflowPatterns/37_LocalSynchronizingMerge/LocalSynchronizingMerge.pione +101 -0
  75. data/example/WorkflowPatterns/41_ThreadMerge/ThreadMerge.pione +43 -0
  76. data/example/WorkflowPatterns/42_ThreadSplit/ThreadSplit.pione +16 -0
  77. data/lib/pione.rb +23 -47
  78. data/lib/pione/agent/broker.rb +1 -1
  79. data/lib/pione/agent/input-generator.rb +1 -1
  80. data/lib/pione/agent/logger.rb +62 -49
  81. data/lib/pione/agent/messenger.rb +38 -0
  82. data/lib/pione/agent/rule-provider.rb +3 -3
  83. data/lib/pione/agent/task-worker.rb +14 -2
  84. data/lib/pione/agent/tuple-space-client.rb +1 -1
  85. data/lib/pione/agent/tuple-space-server-client-life-checker.rb +5 -3
  86. data/lib/pione/command.rb +2 -0
  87. data/lib/pione/command/basic-command.rb +1 -1
  88. data/lib/pione/command/pione-client.rb +57 -16
  89. data/lib/pione/command/pione-log.rb +5 -5
  90. data/lib/pione/command/pione-syntax-checker.rb +22 -7
  91. data/lib/pione/command/pione-task-worker.rb +36 -19
  92. data/lib/pione/command/pione-tuple-space-viewer.rb +3 -3
  93. data/lib/pione/command/pione-val.rb +40 -0
  94. data/lib/pione/component.rb +8 -0
  95. data/lib/pione/{system → component}/document.rb +13 -11
  96. data/lib/pione/component/package.rb +269 -0
  97. data/lib/pione/component/rule.rb +206 -0
  98. data/lib/pione/location/basic-location.rb +49 -7
  99. data/lib/pione/location/ftp-location.rb +19 -6
  100. data/lib/pione/location/local-location.rb +15 -6
  101. data/lib/pione/log.rb +4 -1
  102. data/lib/pione/log/{domain-info.rb → domain-log.rb} +23 -11
  103. data/lib/pione/{util/console-message.rb → log/message-log.rb} +16 -15
  104. data/lib/pione/log/process-log.rb +35 -86
  105. data/lib/pione/log/process-record.rb +24 -11
  106. data/lib/pione/log/system-log.rb +107 -0
  107. data/lib/pione/log/xes-log.rb +54 -48
  108. data/lib/pione/model.rb +1 -3
  109. data/lib/pione/model/assignment.rb +1 -0
  110. data/lib/pione/model/basic-model.rb +31 -15
  111. data/lib/pione/model/block.rb +1 -1
  112. data/lib/pione/model/boolean.rb +10 -23
  113. data/lib/pione/model/constraints.rb +12 -0
  114. data/lib/pione/model/data-expr.rb +31 -36
  115. data/lib/pione/model/feature-expr.rb +6 -23
  116. data/lib/pione/model/float.rb +29 -18
  117. data/lib/pione/model/integer.rb +44 -56
  118. data/lib/pione/model/keyed-sequence.rb +11 -4
  119. data/lib/pione/model/message.rb +4 -4
  120. data/lib/pione/model/ordinal-sequence.rb +12 -14
  121. data/lib/pione/model/package-expr.rb +53 -0
  122. data/lib/pione/model/parameters.rb +12 -11
  123. data/lib/pione/model/pione-method.rb +2 -2
  124. data/lib/pione/model/rule-expr.rb +30 -52
  125. data/lib/pione/model/sequence.rb +26 -26
  126. data/lib/pione/model/string.rb +13 -54
  127. data/lib/pione/model/ticket-expr.rb +12 -53
  128. data/lib/pione/model/type.rb +7 -1
  129. data/lib/pione/model/variable-table.rb +5 -4
  130. data/lib/pione/model/variable.rb +0 -5
  131. data/lib/pione/option/common-option.rb +2 -1
  132. data/lib/pione/option/task-worker-owner-option.rb +1 -1
  133. data/lib/pione/patch/drb-patch.rb +1 -1
  134. data/lib/pione/patch/em-ftpd-patch.rb +7 -0
  135. data/lib/pione/patch/rinda-patch.rb +53 -0
  136. data/lib/pione/patch/uri-patch.rb +5 -0
  137. data/lib/pione/relay/relay-socket.rb +2 -2
  138. data/lib/pione/rule-handler/action-handler.rb +71 -64
  139. data/lib/pione/rule-handler/basic-handler.rb +50 -32
  140. data/lib/pione/rule-handler/flow-handler.rb +51 -34
  141. data/lib/pione/rule-handler/update-criteria.rb +43 -20
  142. data/lib/pione/system.rb +13 -0
  143. data/lib/pione/system/domain-info.rb +34 -0
  144. data/lib/pione/system/global.rb +8 -1
  145. data/lib/pione/system/object.rb +1 -1
  146. data/lib/pione/transformer/expr-transformer.rb +3 -3
  147. data/lib/pione/transformer/literal-transformer.rb +3 -3
  148. data/lib/pione/transformer/rule-definition-transformer.rb +11 -9
  149. data/lib/pione/tuple-space/tuple-space-server-interface.rb +19 -1
  150. data/lib/pione/tuple-space/tuple-space-server.rb +9 -2
  151. data/lib/pione/tuple.rb +30 -0
  152. data/lib/pione/tuple/data-null-tuple.rb +14 -0
  153. data/lib/pione/tuple/message-tuple.rb +7 -0
  154. data/lib/pione/tuple/process-log-tuple.rb +13 -0
  155. data/lib/pione/tuple/touch-tuple.rb +14 -0
  156. data/lib/pione/uri-scheme/myftp-scheme.rb +45 -0
  157. data/lib/pione/util.rb +18 -0
  158. data/lib/pione/util/cpu.rb +20 -0
  159. data/lib/pione/util/error-report.rb +9 -1
  160. data/lib/pione/util/evaluatable.rb +47 -0
  161. data/lib/pione/util/ftp-server.rb +468 -0
  162. data/lib/pione/util/id.rb +39 -0
  163. data/lib/pione/util/indentation.rb +19 -0
  164. data/lib/pione/util/ip-address.rb +35 -0
  165. data/lib/pione/util/misc.rb +0 -47
  166. data/lib/pione/util/uuid.rb +28 -0
  167. data/lib/pione/util/variable-holdable.rb +38 -0
  168. data/lib/pione/version.rb +1 -1
  169. data/pione.gemspec +16 -14
  170. data/test/agent/spec_logger.rb +35 -44
  171. data/test/agent/spec_messenger.rb +25 -0
  172. data/test/agent/spec_rule-provider.rb +1 -1
  173. data/test/agent/spec_task-worker.rb +7 -13
  174. data/test/{system → component}/spec_document.rb +20 -20
  175. data/test/component/spec_package.rb +77 -0
  176. data/test/component/spec_package/TestPackage/Test.pione +14 -0
  177. data/test/component/spec_package/TestPackage/bin/count +3 -0
  178. data/test/component/spec_package/TestPackage/package.yml +7 -0
  179. data/test/component/spec_package/TestPackage/scenario/case1/input/1.txt +1 -0
  180. data/test/component/spec_package/TestPackage/scenario/case1/scenario.yml +1 -0
  181. data/test/component/spec_rule.rb +140 -0
  182. data/test/endurance-test/graph.plt +12 -0
  183. data/test/endurance-test/run.sh +65 -0
  184. data/test/location/location-behavior.rb +125 -0
  185. data/test/location/spec_ftp-location.rb +28 -90
  186. data/test/location/spec_local-location.rb +26 -76
  187. data/test/log/raw-process-log/pione-process.log +710 -0
  188. data/test/log/spec_domain-log.rb +57 -0
  189. data/test/log/spec_message-log.rb +44 -0
  190. data/test/log/spec_process-log.rb +88 -0
  191. data/test/log/spec_process-record.rb +148 -0
  192. data/test/log/spec_system-log.rb +142 -0
  193. data/test/log/spec_xes-log.rb +2 -2
  194. data/test/model/spec_assignment.rb +26 -25
  195. data/test/model/spec_block.rb +51 -97
  196. data/test/model/spec_boolean.rb +0 -5
  197. data/test/model/spec_call-rule.rb +6 -6
  198. data/test/model/spec_data-expr.rb +0 -7
  199. data/test/model/spec_data-expr.yml +8 -0
  200. data/test/model/spec_float.rb +1 -1
  201. data/test/model/spec_float.yml +13 -0
  202. data/test/model/spec_integer.rb +1 -1
  203. data/test/model/spec_integer.yml +12 -1
  204. data/test/model/spec_keyed-sequence.yml +5 -0
  205. data/test/model/spec_message.rb +2 -4
  206. data/test/model/spec_package-expr.rb +19 -0
  207. data/test/model/spec_parameters.rb +56 -88
  208. data/test/model/spec_pione-method.rb +15 -14
  209. data/test/model/spec_rule-expr.rb +4 -52
  210. data/test/model/spec_rule-expr.yml +11 -0
  211. data/test/model/spec_sequence.yml +6 -0
  212. data/test/model/spec_string.rb +21 -13
  213. data/test/model/spec_string.yml +10 -2
  214. data/test/model/spec_ticket-expr.rb +25 -3
  215. data/test/model/spec_variable.rb +8 -8
  216. data/test/rule-handler/spec_action-handler.pione +37 -0
  217. data/test/rule-handler/spec_action-handler.rb +41 -97
  218. data/test/rule-handler/spec_flow-handler.rb +24 -30
  219. data/test/rule-handler/spec_update-criteria.pione +16 -0
  220. data/test/rule-handler/spec_update-criteria.rb +7 -4
  221. data/test/rule-handler/spec_update-criteria.yml +191 -0
  222. data/test/system/spec_domain-info.rb +25 -0
  223. data/test/test-util.rb +38 -228
  224. data/test/transformer/spec_block-transformer.rb +1 -1
  225. data/test/transformer/spec_expr-transformer.rb +30 -39
  226. data/test/transformer/spec_flow-element-transformer.rb +17 -17
  227. data/test/transformer/spec_literal-transformer.rb +3 -3
  228. data/test/transformer/spec_rule-definition-transformer.rb +55 -76
  229. data/test/{spec_data-finder.rb → tuple-space/spec_data-finder.rb} +1 -1
  230. data/test/{spec_data-finder.yml → tuple-space/spec_data-finder.yml} +0 -0
  231. data/test/tuple/spec_data-tuple.rb +5 -76
  232. data/test/tuple/spec_finished-tuple.rb +5 -46
  233. data/test/tuple/spec_message-tuple.rb +10 -0
  234. data/test/tuple/spec_task-tuple.rb +4 -110
  235. data/test/tuple/spec_touch-tuple.rb +14 -0
  236. data/test/tuple/tuple-behavior.rb +14 -0
  237. data/test/uri-scheme/spec_local-scheme.rb +1 -1
  238. data/test/uri-scheme/spec_myftp-scheme.rb +73 -0
  239. data/test/uri-scheme/spec_myftp-scheme.yml +85 -0
  240. data/test/util/spec_cpu.rb +8 -0
  241. data/test/util/spec_error-report.rb +42 -0
  242. data/test/util/spec_evaluatable.rb +18 -0
  243. data/test/util/spec_ftp-server.rb +249 -0
  244. data/test/util/spec_id.pione +14 -0
  245. data/test/util/spec_id.rb +77 -0
  246. data/test/util/spec_indentation.rb +77 -0
  247. data/test/util/spec_ip-address.rb +15 -0
  248. data/test/util/spec_uuid.rb +11 -0
  249. data/test/util/spec_variable-holdable.rb +69 -0
  250. metadata +282 -83
  251. data/bin/pione-eval +0 -111
  252. data/demo/demo.rb +0 -311
  253. data/demo/public/base.css +0 -94
  254. data/demo/public/demo.js +0 -107
  255. data/demo/public/index.html +0 -91
  256. data/demo/public/jquery-1.8.3.min.js +0 -2
  257. data/lib/pione/model/binary-operator.rb +0 -90
  258. data/lib/pione/model/list.rb +0 -108
  259. data/lib/pione/model/package.rb +0 -56
  260. data/lib/pione/model/rule-io.rb +0 -178
  261. data/lib/pione/model/rule.rb +0 -295
  262. data/lib/pione/system/identifier.rb +0 -61
  263. data/lib/pione/tuple/log-tuple.rb +0 -14
  264. data/lib/pione/util/terminal.rb +0 -78
  265. data/test/log/data/sample.log +0 -1003
  266. data/test/model/spec_binary-operator.rb +0 -39
  267. data/test/model/spec_package.rb +0 -15
  268. data/test/model/spec_rule.rb +0 -158
  269. data/test/spec_identifier.rb +0 -29
  270. data/test/spec_log.rb +0 -52
@@ -51,9 +51,17 @@ module Pione
51
51
  @scheme = name
52
52
  SCHEMES[name] = self
53
53
  end
54
+
55
+ def set_real_appendable(b)
56
+ @appendable = b
57
+ end
58
+
59
+ def real_appendable?
60
+ @appendable
61
+ end
54
62
  end
55
63
 
56
- forward :class, :scheme
64
+ forward! :class, :scheme, :real_appendable?
57
65
  forward :@uri, :host
58
66
 
59
67
  # @return [URI]
@@ -81,7 +89,7 @@ module Pione
81
89
  # @return [BasicLocation]
82
90
  # new location
83
91
  def +(name)
84
- self.class.new(@uri.as_directory + name)
92
+ self.class.new(@uri.as_directory + name.to_s)
85
93
  end
86
94
 
87
95
  # Create new location that has URI as a directory.
@@ -125,11 +133,25 @@ module Pione
125
133
  System::FileCache.cached?(self)
126
134
  end
127
135
 
128
- # Creates a location.
136
+ # Write a data into the location.
137
+ #
138
+ # @param data [String]
139
+ # data content
140
+ # @return [void]
141
+ def write(data)
142
+ if exist?
143
+ update(data)
144
+ else
145
+ create(data)
146
+ end
147
+ end
148
+
149
+ # Creates a file at the location. If a file exists at the location aleady,
150
+ # it raises an exception.
129
151
  #
130
152
  # @param data [String]
131
153
  # data content
132
- # @return[void]
154
+ # @return [void]
133
155
  def create(data)
134
156
  raise NotImplementedError
135
157
  end
@@ -183,14 +205,32 @@ module Pione
183
205
  raise NotImplementedError
184
206
  end
185
207
 
186
- # Return entries of the resource path.
208
+ # Return entries of the location.
187
209
  #
188
210
  # @return [Array<Location>]
189
- # entries of the location path
211
+ # entries of the location
190
212
  def entries
191
213
  raise NotImplementedError
192
214
  end
193
215
 
216
+ # Return file entries of the location.
217
+ #
218
+ # @return [Array<Location>]
219
+ # file entries of the location
220
+ def file_entries
221
+ entries.select{|entry| entry.file?}
222
+ end
223
+
224
+ # Return directory entries of the location.
225
+ #
226
+ # @return [Array<Location>]
227
+ # directory entries of the location
228
+ def directory_entries
229
+ entries.select do |entry|
230
+ entry.directory? and not(entry.path.basename == "." or entry.path.basename == "..")
231
+ end
232
+ end
233
+
194
234
  # Return true if there is data in the location.
195
235
  #
196
236
  # @return [Boolean]
@@ -233,7 +273,9 @@ module Pione
233
273
  raise NotImplementedError
234
274
  end
235
275
 
236
- # Link to the destination.
276
+ # Link to the destination. If the location scheme is same to destination,
277
+ # create link by a symbolic link or lightweight copy method. If not, copy
278
+ # it simply.
237
279
  #
238
280
  # @param dest [BasicLocation]
239
281
  # destination
@@ -3,6 +3,15 @@ module Pione
3
3
  # FTPLocation represents locations on FTP server.
4
4
  class FTPLocation < BasicLocation
5
5
  set_scheme "ftp"
6
+ set_real_appendable false
7
+
8
+ # for myftp scheme
9
+ SCHEMES["myftp"] = self
10
+
11
+ def initialize(uri)
12
+ uri = uri.to_ftp_scheme if uri.scheme == "myftp"
13
+ super(uri)
14
+ end
6
15
 
7
16
  def rebuild(path)
8
17
  scheme = @uri.scheme
@@ -19,15 +28,19 @@ module Pione
19
28
  else
20
29
  connect do |ftp|
21
30
  makedirs(ftp, @path.dirname)
22
- file = Temppath.create
23
- file.open("w") {|f| f.write(data)}
24
- ftp.put(file.to_s, @path.to_s)
31
+ path = Temppath.create
32
+ Location[path].create(data)
33
+ ftp.put(path, @path.to_s)
25
34
  end
26
35
  end
27
36
  end
28
37
 
29
38
  def append(data)
30
- exist? ? update(read + data) : create(data)
39
+ if exist?
40
+ update(read + data)
41
+ else
42
+ create(data)
43
+ end
31
44
  end
32
45
 
33
46
  def read
@@ -70,7 +83,7 @@ module Pione
70
83
  connect do |ftp|
71
84
  ftp.nlst(@path.to_s).map do |entry|
72
85
  rebuild(@path + entry)
73
- end.select {|entry| entry.file?}
86
+ end
74
87
  end
75
88
  end
76
89
 
@@ -107,7 +120,7 @@ module Pione
107
120
 
108
121
  def move(dest)
109
122
  if dest.scheme == scheme and dest.host == host
110
- ftp.rename(@path.to_s, dest.path.to_s)
123
+ connect{|ftp| ftp.rename(@path.to_s, dest.path.to_s)}
111
124
  else
112
125
  copy(dest)
113
126
  delete
@@ -3,6 +3,7 @@ module Pione
3
3
  # LocalLocation represents local disk locations.
4
4
  class LocalLocation < BasicLocation
5
5
  set_scheme "local"
6
+ set_real_appendable true
6
7
 
7
8
  def initialize(uri)
8
9
  super(uri.absolute)
@@ -19,13 +20,13 @@ module Pione
19
20
  raise ExistAlready.new(self)
20
21
  else
21
22
  @path.dirname.mkpath unless @path.dirname.exist?
22
- @path.open("w+"){|f| f.write(data)}
23
+ @path.open("w"){|f| f.write(data)}
23
24
  end
24
25
  end
25
26
 
26
27
  def append(data)
27
28
  if exist?
28
- update(read + data)
29
+ @path.open("a"){|f| f.write(data)}
29
30
  else
30
31
  create(data)
31
32
  end
@@ -37,14 +38,20 @@ module Pione
37
38
 
38
39
  def update(data)
39
40
  if @path.exist?
40
- @path.open("w+"){|file| file.write(data)}
41
+ @path.open("w"){|file| file.write(data)}
41
42
  else
42
43
  raise NotFound.new(@uri)
43
44
  end
44
45
  end
45
46
 
46
47
  def delete
47
- @path.delete if @path.exist?
48
+ if @path.exist?
49
+ if @path.file?
50
+ @path.delete
51
+ else
52
+ FileUtils.remove_entry_secure(@path)
53
+ end
54
+ end
48
55
  end
49
56
 
50
57
  def mtime
@@ -56,7 +63,9 @@ module Pione
56
63
  end
57
64
 
58
65
  def entries
59
- @path.entries.select{|entry| (@path + entry).file?}.map do |entry|
66
+ @path.entries.select do |entry|
67
+ not(entry.to_s == "." or entry.to_s == "..")
68
+ end.map do |entry|
60
69
  Location["local:%s" % (@path + entry).expand_path]
61
70
  end
62
71
  rescue Errno::ENOENT
@@ -79,7 +88,7 @@ module Pione
79
88
  raise NotFound.new(self) unless exist?
80
89
  if dest.kind_of?(LocalLocation)
81
90
  dest.path.dirname.mkpath unless dest.path.dirname.exist?
82
- FileUtils.mv(@path, dest.path)
91
+ FileUtils.mv(@path, dest.path, force: true)
83
92
  else
84
93
  copy(dest)
85
94
  delete
data/lib/pione/log.rb CHANGED
@@ -4,7 +4,10 @@ module Pione
4
4
  end
5
5
  end
6
6
 
7
+ require 'pione/log/message-log'
7
8
  require 'pione/log/process-record'
8
9
  require 'pione/log/process-log'
9
10
  require 'pione/log/xes-log'
10
- require 'pione/log/domain-info'
11
+ require 'pione/log/domain-log'
12
+ require 'pione/log/system-log'
13
+
@@ -1,7 +1,13 @@
1
1
  module Pione
2
2
  module Log
3
- # DomainInfo is a domain log that records domain inputs and parameters.
4
- class DomainInfo
3
+ # DomainLog is a domain log that records domain inputs and parameters.
4
+ class DomainLog
5
+ include Sys # for Uname
6
+
7
+ FILENAME = ".domain.log"
8
+
9
+ forward_as_key! :@record, :system_name, :system_nodename, :system_machine, :system_version, :system_release
10
+
5
11
  # @return [Location::BasicLocation]
6
12
  # domain's location
7
13
  attr_reader :domain_location
@@ -15,15 +21,21 @@ module Pione
15
21
  def initialize(handler)
16
22
  @domain_location = handler.domain_location
17
23
  @record = {
18
- "uname" => `uname -a`.chomp,
19
- "params" => handler.params.textize,
20
- "original_params" => handler.original_params.textize,
21
- "inputs" => inputs_string(handler.inputs),
22
- "domain" => handler.domain,
23
- "domain_location" => @domain_location.uri.to_s,
24
- "task_id" => handler.task_id.to_s,
25
- "dry_run" => handler.dry_run.to_s
24
+ :system_name => Uname.sysname,
25
+ :system_nodename => Uname.nodename,
26
+ :system_machine => Uname.machine,
27
+ :system_version => Uname.version,
28
+ :system_release => Uname.release,
29
+ :params => handler.params.textize,
30
+ :original_params => handler.original_params.textize,
31
+ :inputs => inputs_string(handler.inputs),
32
+ :domain => handler.domain,
33
+ :domain_location => @domain_location.uri.to_s,
34
+ :dry_run => handler.dry_run.to_s
26
35
  }
36
+ if handler.respond_to?(:working_directory)
37
+ @record[:working_directory] = handler.working_directory.uri.to_s
38
+ end
27
39
  end
28
40
 
29
41
  # Save domain information file.
@@ -33,7 +45,7 @@ module Pione
33
45
  text = "== %s\n\n" % Time.now
34
46
  text << @record.map{|key, val| "- %s: %s" % [key,val]}.join("\n")
35
47
  text << "\n\n"
36
- (@domain_location + ".domain_info").append(text)
48
+ (@domain_location + FILENAME).append(text)
37
49
  end
38
50
 
39
51
  private
@@ -1,11 +1,11 @@
1
1
  module Pione
2
- module Util
2
+ module Log
3
3
  # ConsoleMessage is a set of utility methods for sending messages to user.
4
- module ConsoleMessage
4
+ module MessageLog
5
5
  # @api private
6
6
  MESSAGE_QUEUE = Queue.new
7
7
 
8
- # message queue thread
8
+ # Message queue thread
9
9
  Thread.new {
10
10
  while msg = MESSAGE_QUEUE.pop
11
11
  puts msg
@@ -93,12 +93,11 @@ module Pione
93
93
  # @param type [String]
94
94
  # message heading type
95
95
  # @return [void]
96
- def debug_message(msg, level=0, type="debug")
96
+ def debug_message(msg, level=0, head="debug")
97
97
  if debug_mode? and not(quiet_mode?)
98
- message(type, :magenta, " "*level + msg)
98
+ message(:debug, head, :magenta, " "*level + msg)
99
99
  end
100
100
  end
101
- module_function :debug_message
102
101
 
103
102
  # Send the debug message to notify that something begins.
104
103
  #
@@ -127,9 +126,9 @@ module Pione
127
126
  # @param type [String]
128
127
  # message heading type
129
128
  # @return [void]
130
- def user_message(msg, level=0, type="info")
129
+ def user_message(msg, level=0, head="info", color=:green)
131
130
  if not(quiet_mode?)
132
- message(type, :green, " "*level + msg)
131
+ message(:info, head, color, msg, level)
133
132
  end
134
133
  end
135
134
 
@@ -138,8 +137,8 @@ module Pione
138
137
  # @param msg [String]
139
138
  # user message
140
139
  # @return [void]
141
- def user_message_begin(msg)
142
- user_message(msg, 0, ">>>")
140
+ def user_message_begin(msg, level=0)
141
+ user_message(msg, level, "-->")
143
142
  end
144
143
 
145
144
  # Send the debug message to notify that something ends.
@@ -147,8 +146,8 @@ module Pione
147
146
  # @param [String] msg
148
147
  # debug message
149
148
  # @return [void]
150
- def user_message_end(msg)
151
- user_message(msg, 0, "<<<")
149
+ def user_message_end(msg, level=0)
150
+ user_message(msg, level, "<--")
152
151
  end
153
152
 
154
153
  # Show the message.
@@ -161,7 +160,7 @@ module Pione
161
160
  #
162
161
  # @api private
163
162
  def show(msg)
164
- message("show", :red, msg)
163
+ message(:debug, "show", :red, msg)
165
164
  end
166
165
 
167
166
  # Print the message with the color.
@@ -174,8 +173,10 @@ module Pione
174
173
  # message content
175
174
  #
176
175
  # @api private
177
- def message(type, color, msg)
178
- MESSAGE_QUEUE.push "%s %s" % [Terminal.color(color, "%5s" % type), msg]
176
+ def message(type, head, color, msg, level=0)
177
+ write(Tuple[:message].new(type: type, head: head, color: color, contents: msg, level: level))
178
+ rescue NoMethodError
179
+ MESSAGE_QUEUE.push "%s%s %s" % [" "*level, ("%5s" % head).color(color), msg]
179
180
  end
180
181
  module_function :message
181
182
  end
@@ -1,6 +1,6 @@
1
1
  module Pione
2
2
  module Log
3
- # ProcessLog represents process log records of PIONE.
3
+ # ProcessLog represents process log file.
4
4
  class ProcessLog
5
5
  # formatter table
6
6
  @format = {}
@@ -29,13 +29,25 @@ module Pione
29
29
  #
30
30
  # @param location [Location]
31
31
  # path of process log file
32
- # @return [ProcessLogFile]
33
- # log object
32
+ # @return [Hash{String => ProcessLog}]
33
+ # pairs of log id and the log
34
34
  def read(location)
35
- if location.file?
36
- read_file(location)
37
- else
38
- read_directory(location)
35
+ cache = location
36
+ unless location.scheme == "local"
37
+ cache = Location[Temppath.create]
38
+ cache.create(location.read)
39
+ end
40
+ records = cache.path.each_line.map do |line|
41
+ JSON.parse(line).inject({}) do |data, pair|
42
+ data[pair[0].to_sym] = pair[1]
43
+ data
44
+ end.tap do |table|
45
+ break ProcessRecord.build(table)
46
+ end
47
+ end
48
+ group_by(:log_id, records).inject({}) do |table, pair|
49
+ key, _records = pair
50
+ table[key] = new(_records)
39
51
  end
40
52
  end
41
53
 
@@ -48,38 +60,14 @@ module Pione
48
60
 
49
61
  attr_reader :filter_block
50
62
 
51
- private
52
-
53
- # Read records from the log file at the location.
63
+ # Return the record table grouped by the key.
54
64
  #
55
- # @param location [Location::BasicLocation]
56
- # log location
57
- def read_file(location)
58
- cache = Location[Temppath.create]
59
- cache.create(location.read)
60
- cache.path.each_line.map do |line|
61
- JSON.parse(line).inject({}) do |data, pair|
62
- data[pair[0].to_sym] = pair[1]
63
- data
64
- end.tap do |table|
65
- break ProcessRecord.build(table)
66
- end
67
- end.tap do |records|
68
- break new([ProcessLogBundle.new(records)])
69
- end
70
- end
71
-
72
- # Read records from log files in directory at the location.
73
- #
74
- # @param location [Location::BasicLocation]
75
- # log directory location
76
- def read_directory(location)
77
- location.entries.inject(new([])) do |formatter, entry|
78
- if /pione_\d{14}\.log/.match(entry.path.basename.to_s)
79
- new(formatter.bundles + read_file(entry).bundles)
80
- else
81
- formatter
82
- end
65
+ # @return [Hash{String => Array<ProcessRecord>}]
66
+ # grouping records table
67
+ def group_by(key, records)
68
+ records.inject({}) do |table, record|
69
+ table[record.send(key)] ||= []
70
+ table.tap {|x| x[record.send(key)] << record}
83
71
  end
84
72
  end
85
73
  end
@@ -93,7 +81,13 @@ module Pione
93
81
  # @param records [Array<ProcessRecord>]
94
82
  # log records
95
83
  def initialize(records)
96
- @records = records.select {|record| self.class.filter_block.call(record)}
84
+ @records = records.select do |record|
85
+ if block = self.class.filter_block
86
+ block.call(record)
87
+ else
88
+ true
89
+ end
90
+ end
97
91
  end
98
92
 
99
93
  # Return the record table grouped by the key.
@@ -101,26 +95,10 @@ module Pione
101
95
  # @return [Hash{String => Array<ProcessRecord>}]
102
96
  # grouping records table
103
97
  def group_by(key)
104
- @records.inject({}) do |table, record|
105
- table[record.send(key)] ||= []
106
- table.tap {|x| x[record.send(key)] << record}
107
- end
108
- end
109
- end
110
-
111
- # ProcessLogFormatter is a basic class for fomatting process logs.
112
- class ProcessLogFormatter < ProcessLog
113
- # @return [Array<ProcessBunle>]
114
- # target logs that we format
115
- attr_reader :bundles
116
-
117
- # @param bundles [Array<ProcessLogBundle>]
118
- # log bundles
119
- def initialize(bundles)
120
- @bundles = bundles
98
+ self.class.group_by(key, @records)
121
99
  end
122
100
 
123
- # Format bundle logs.
101
+ # Format records.
124
102
  #
125
103
  # @return [String]
126
104
  # result string
@@ -129,35 +107,6 @@ module Pione
129
107
  end
130
108
  end
131
109
 
132
- # ProcessLogFormatError is raised when formatter cannot format some objects.
133
- class ProcessLogFormatError < StandardError
134
- # @param object [Object]
135
- # the object that we cannnot format
136
- def initialize(object)
137
- @object = object
138
- end
139
-
140
- # @api private
141
- def message
142
- "not formattable: %s" % @object.inspect
143
- end
144
- end
145
-
146
- # ProcessLogBundle is a bundle of raw logs.
147
- class ProcessLogBundle
148
- attr_reader :agent_activity_log
149
- attr_reader :rule_process_log
150
- attr_reader :task_process_log
151
-
152
- # @param records [Array<ProcessRecord>]
153
- # log records
154
- def initialize(records)
155
- @agent_activity_log = AgentActivityLog.new(records)
156
- @rule_process_log = RuleProcessLog.new(records)
157
- @task_process_log = TaskProcessLog.new(records)
158
- end
159
- end
160
-
161
110
  # AgentActivityLog is a set of records written about agent activities.
162
111
  class AgentActivityLog < ProcessLog
163
112
  set_filter {|record| record.type == :agent_activity}