pione 0.1.4 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +4 -3
- data/.simplecov +7 -0
- data/.travis.yml +8 -0
- data/Gemfile +3 -0
- data/History.txt +13 -0
- data/README.md +2 -0
- data/Rakefile +16 -6
- data/bin/pione-val +5 -0
- data/example/AbstractRule/package.yml +1 -0
- data/example/HelloWorld/package.yml +2 -0
- data/example/HelloWorld/scenario/scenario.yml +2 -0
- data/example/LoopByTouch/LoopByTouch.pione +28 -0
- data/example/LoopByTouch/package.yml +1 -0
- data/example/MakePair/package.yml +2 -0
- data/example/MakePair/{data → scenario/input}/1.i +0 -0
- data/example/MakePair/{data → scenario/input}/2.i +0 -0
- data/example/MakePair/{data → scenario/input}/3.i +0 -0
- data/example/MakePair/{data → scenario/input}/4.i +0 -0
- data/example/MakePair/{data → scenario/input}/5.i +0 -0
- data/example/MakePair/scenario/scenario.yml +1 -0
- data/example/ScoreAggregation/ScoreAggregation.pione +122 -0
- data/example/ScoreAggregation/bin/apply-template.rb +10 -0
- data/example/ScoreAggregation/bin/histgram-graph.sh +18 -0
- data/example/ScoreAggregation/bin/mean-summary.rb +10 -0
- data/example/ScoreAggregation/bin/personal-bar-graph.sh +18 -0
- data/example/ScoreAggregation/bin/personal-pre-statistics.rb +37 -0
- data/example/ScoreAggregation/bin/total-mean.rb +10 -0
- data/example/ScoreAggregation/bin/total-statistics.rb +43 -0
- data/example/ScoreAggregation/generate-data.rb +63 -0
- data/example/ScoreAggregation/package.yml +1 -0
- data/example/ScoreAggregation/scenario/case1/input/A.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/B.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/C.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/D.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/E.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/F.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/G.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/H.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/I.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/J.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/K.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/L.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/M.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/N.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/O.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/P.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/Q.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/R.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/S.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/T.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/U.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/V.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/W.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/X.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/Y.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/Z.score +15 -0
- data/example/ScoreAggregation/scenario/case1/input/stat-template.erb +24 -0
- data/example/ScoreAggregation/scenario/case1/scenario.yml +3 -0
- data/example/{SequentialProcess/SequentialProcess.pione → SerialProcessing/SerialProcessing.pione} +0 -0
- data/example/SerialProcessing/package.yml +1 -0
- data/example/WorkflowPatterns/01_Sequence/Sequence.pione +21 -0
- data/example/WorkflowPatterns/02_PrallelSplit/ParallelSplit.pione +29 -0
- data/example/WorkflowPatterns/03_Synchronization/Synchronization.pione +30 -0
- data/example/WorkflowPatterns/04_ExclusiveChoice/ExclusiveChoice.pione +44 -0
- data/example/WorkflowPatterns/05_SimpleMerge/SimpleMerge.pione +44 -0
- data/example/WorkflowPatterns/06_MultiChoice/MultiChoice.pione +48 -0
- data/example/WorkflowPatterns/07_StructuredSynchronizingMerge/StructuredSynchronizingMerge.pione +71 -0
- data/example/WorkflowPatterns/08_MultiMerge/MultiMerge.pione +44 -0
- data/example/WorkflowPatterns/11_ImplicitTermination/ImplicitTermination.pione +29 -0
- data/example/WorkflowPatterns/12_MultipleInstancesWithoutSynchronization/MultipleInstancesWithoutSynchronization.pione +29 -0
- data/example/WorkflowPatterns/13_MultipleInstancesWithDesignTimeKnowledge/MultipleInstancesWithDesignTimeKnowledge.pione +28 -0
- data/example/WorkflowPatterns/14_MultipleInstancesWithRunTimeKnowledge/MultipleInstancesWithRunTimeKnowledge.pione +33 -0
- data/example/WorkflowPatterns/33_GeneralizedANDJoin/GeneralizedANDJoin.pione +21 -0
- data/example/WorkflowPatterns/37_LocalSynchronizingMerge/LocalSynchronizingMerge.pione +101 -0
- data/example/WorkflowPatterns/41_ThreadMerge/ThreadMerge.pione +43 -0
- data/example/WorkflowPatterns/42_ThreadSplit/ThreadSplit.pione +16 -0
- data/lib/pione.rb +23 -47
- data/lib/pione/agent/broker.rb +1 -1
- data/lib/pione/agent/input-generator.rb +1 -1
- data/lib/pione/agent/logger.rb +62 -49
- data/lib/pione/agent/messenger.rb +38 -0
- data/lib/pione/agent/rule-provider.rb +3 -3
- data/lib/pione/agent/task-worker.rb +14 -2
- data/lib/pione/agent/tuple-space-client.rb +1 -1
- data/lib/pione/agent/tuple-space-server-client-life-checker.rb +5 -3
- data/lib/pione/command.rb +2 -0
- data/lib/pione/command/basic-command.rb +1 -1
- data/lib/pione/command/pione-client.rb +57 -16
- data/lib/pione/command/pione-log.rb +5 -5
- data/lib/pione/command/pione-syntax-checker.rb +22 -7
- data/lib/pione/command/pione-task-worker.rb +36 -19
- data/lib/pione/command/pione-tuple-space-viewer.rb +3 -3
- data/lib/pione/command/pione-val.rb +40 -0
- data/lib/pione/component.rb +8 -0
- data/lib/pione/{system → component}/document.rb +13 -11
- data/lib/pione/component/package.rb +269 -0
- data/lib/pione/component/rule.rb +206 -0
- data/lib/pione/location/basic-location.rb +49 -7
- data/lib/pione/location/ftp-location.rb +19 -6
- data/lib/pione/location/local-location.rb +15 -6
- data/lib/pione/log.rb +4 -1
- data/lib/pione/log/{domain-info.rb → domain-log.rb} +23 -11
- data/lib/pione/{util/console-message.rb → log/message-log.rb} +16 -15
- data/lib/pione/log/process-log.rb +35 -86
- data/lib/pione/log/process-record.rb +24 -11
- data/lib/pione/log/system-log.rb +107 -0
- data/lib/pione/log/xes-log.rb +54 -48
- data/lib/pione/model.rb +1 -3
- data/lib/pione/model/assignment.rb +1 -0
- data/lib/pione/model/basic-model.rb +31 -15
- data/lib/pione/model/block.rb +1 -1
- data/lib/pione/model/boolean.rb +10 -23
- data/lib/pione/model/constraints.rb +12 -0
- data/lib/pione/model/data-expr.rb +31 -36
- data/lib/pione/model/feature-expr.rb +6 -23
- data/lib/pione/model/float.rb +29 -18
- data/lib/pione/model/integer.rb +44 -56
- data/lib/pione/model/keyed-sequence.rb +11 -4
- data/lib/pione/model/message.rb +4 -4
- data/lib/pione/model/ordinal-sequence.rb +12 -14
- data/lib/pione/model/package-expr.rb +53 -0
- data/lib/pione/model/parameters.rb +12 -11
- data/lib/pione/model/pione-method.rb +2 -2
- data/lib/pione/model/rule-expr.rb +30 -52
- data/lib/pione/model/sequence.rb +26 -26
- data/lib/pione/model/string.rb +13 -54
- data/lib/pione/model/ticket-expr.rb +12 -53
- data/lib/pione/model/type.rb +7 -1
- data/lib/pione/model/variable-table.rb +5 -4
- data/lib/pione/model/variable.rb +0 -5
- data/lib/pione/option/common-option.rb +2 -1
- data/lib/pione/option/task-worker-owner-option.rb +1 -1
- data/lib/pione/patch/drb-patch.rb +1 -1
- data/lib/pione/patch/em-ftpd-patch.rb +7 -0
- data/lib/pione/patch/rinda-patch.rb +53 -0
- data/lib/pione/patch/uri-patch.rb +5 -0
- data/lib/pione/relay/relay-socket.rb +2 -2
- data/lib/pione/rule-handler/action-handler.rb +71 -64
- data/lib/pione/rule-handler/basic-handler.rb +50 -32
- data/lib/pione/rule-handler/flow-handler.rb +51 -34
- data/lib/pione/rule-handler/update-criteria.rb +43 -20
- data/lib/pione/system.rb +13 -0
- data/lib/pione/system/domain-info.rb +34 -0
- data/lib/pione/system/global.rb +8 -1
- data/lib/pione/system/object.rb +1 -1
- data/lib/pione/transformer/expr-transformer.rb +3 -3
- data/lib/pione/transformer/literal-transformer.rb +3 -3
- data/lib/pione/transformer/rule-definition-transformer.rb +11 -9
- data/lib/pione/tuple-space/tuple-space-server-interface.rb +19 -1
- data/lib/pione/tuple-space/tuple-space-server.rb +9 -2
- data/lib/pione/tuple.rb +30 -0
- data/lib/pione/tuple/data-null-tuple.rb +14 -0
- data/lib/pione/tuple/message-tuple.rb +7 -0
- data/lib/pione/tuple/process-log-tuple.rb +13 -0
- data/lib/pione/tuple/touch-tuple.rb +14 -0
- data/lib/pione/uri-scheme/myftp-scheme.rb +45 -0
- data/lib/pione/util.rb +18 -0
- data/lib/pione/util/cpu.rb +20 -0
- data/lib/pione/util/error-report.rb +9 -1
- data/lib/pione/util/evaluatable.rb +47 -0
- data/lib/pione/util/ftp-server.rb +468 -0
- data/lib/pione/util/id.rb +39 -0
- data/lib/pione/util/indentation.rb +19 -0
- data/lib/pione/util/ip-address.rb +35 -0
- data/lib/pione/util/misc.rb +0 -47
- data/lib/pione/util/uuid.rb +28 -0
- data/lib/pione/util/variable-holdable.rb +38 -0
- data/lib/pione/version.rb +1 -1
- data/pione.gemspec +16 -14
- data/test/agent/spec_logger.rb +35 -44
- data/test/agent/spec_messenger.rb +25 -0
- data/test/agent/spec_rule-provider.rb +1 -1
- data/test/agent/spec_task-worker.rb +7 -13
- data/test/{system → component}/spec_document.rb +20 -20
- data/test/component/spec_package.rb +77 -0
- data/test/component/spec_package/TestPackage/Test.pione +14 -0
- data/test/component/spec_package/TestPackage/bin/count +3 -0
- data/test/component/spec_package/TestPackage/package.yml +7 -0
- data/test/component/spec_package/TestPackage/scenario/case1/input/1.txt +1 -0
- data/test/component/spec_package/TestPackage/scenario/case1/scenario.yml +1 -0
- data/test/component/spec_rule.rb +140 -0
- data/test/endurance-test/graph.plt +12 -0
- data/test/endurance-test/run.sh +65 -0
- data/test/location/location-behavior.rb +125 -0
- data/test/location/spec_ftp-location.rb +28 -90
- data/test/location/spec_local-location.rb +26 -76
- data/test/log/raw-process-log/pione-process.log +710 -0
- data/test/log/spec_domain-log.rb +57 -0
- data/test/log/spec_message-log.rb +44 -0
- data/test/log/spec_process-log.rb +88 -0
- data/test/log/spec_process-record.rb +148 -0
- data/test/log/spec_system-log.rb +142 -0
- data/test/log/spec_xes-log.rb +2 -2
- data/test/model/spec_assignment.rb +26 -25
- data/test/model/spec_block.rb +51 -97
- data/test/model/spec_boolean.rb +0 -5
- data/test/model/spec_call-rule.rb +6 -6
- data/test/model/spec_data-expr.rb +0 -7
- data/test/model/spec_data-expr.yml +8 -0
- data/test/model/spec_float.rb +1 -1
- data/test/model/spec_float.yml +13 -0
- data/test/model/spec_integer.rb +1 -1
- data/test/model/spec_integer.yml +12 -1
- data/test/model/spec_keyed-sequence.yml +5 -0
- data/test/model/spec_message.rb +2 -4
- data/test/model/spec_package-expr.rb +19 -0
- data/test/model/spec_parameters.rb +56 -88
- data/test/model/spec_pione-method.rb +15 -14
- data/test/model/spec_rule-expr.rb +4 -52
- data/test/model/spec_rule-expr.yml +11 -0
- data/test/model/spec_sequence.yml +6 -0
- data/test/model/spec_string.rb +21 -13
- data/test/model/spec_string.yml +10 -2
- data/test/model/spec_ticket-expr.rb +25 -3
- data/test/model/spec_variable.rb +8 -8
- data/test/rule-handler/spec_action-handler.pione +37 -0
- data/test/rule-handler/spec_action-handler.rb +41 -97
- data/test/rule-handler/spec_flow-handler.rb +24 -30
- data/test/rule-handler/spec_update-criteria.pione +16 -0
- data/test/rule-handler/spec_update-criteria.rb +7 -4
- data/test/rule-handler/spec_update-criteria.yml +191 -0
- data/test/system/spec_domain-info.rb +25 -0
- data/test/test-util.rb +38 -228
- data/test/transformer/spec_block-transformer.rb +1 -1
- data/test/transformer/spec_expr-transformer.rb +30 -39
- data/test/transformer/spec_flow-element-transformer.rb +17 -17
- data/test/transformer/spec_literal-transformer.rb +3 -3
- data/test/transformer/spec_rule-definition-transformer.rb +55 -76
- data/test/{spec_data-finder.rb → tuple-space/spec_data-finder.rb} +1 -1
- data/test/{spec_data-finder.yml → tuple-space/spec_data-finder.yml} +0 -0
- data/test/tuple/spec_data-tuple.rb +5 -76
- data/test/tuple/spec_finished-tuple.rb +5 -46
- data/test/tuple/spec_message-tuple.rb +10 -0
- data/test/tuple/spec_task-tuple.rb +4 -110
- data/test/tuple/spec_touch-tuple.rb +14 -0
- data/test/tuple/tuple-behavior.rb +14 -0
- data/test/uri-scheme/spec_local-scheme.rb +1 -1
- data/test/uri-scheme/spec_myftp-scheme.rb +73 -0
- data/test/uri-scheme/spec_myftp-scheme.yml +85 -0
- data/test/util/spec_cpu.rb +8 -0
- data/test/util/spec_error-report.rb +42 -0
- data/test/util/spec_evaluatable.rb +18 -0
- data/test/util/spec_ftp-server.rb +249 -0
- data/test/util/spec_id.pione +14 -0
- data/test/util/spec_id.rb +77 -0
- data/test/util/spec_indentation.rb +77 -0
- data/test/util/spec_ip-address.rb +15 -0
- data/test/util/spec_uuid.rb +11 -0
- data/test/util/spec_variable-holdable.rb +69 -0
- metadata +282 -83
- data/bin/pione-eval +0 -111
- data/demo/demo.rb +0 -311
- data/demo/public/base.css +0 -94
- data/demo/public/demo.js +0 -107
- data/demo/public/index.html +0 -91
- data/demo/public/jquery-1.8.3.min.js +0 -2
- data/lib/pione/model/binary-operator.rb +0 -90
- data/lib/pione/model/list.rb +0 -108
- data/lib/pione/model/package.rb +0 -56
- data/lib/pione/model/rule-io.rb +0 -178
- data/lib/pione/model/rule.rb +0 -295
- data/lib/pione/system/identifier.rb +0 -61
- data/lib/pione/tuple/log-tuple.rb +0 -14
- data/lib/pione/util/terminal.rb +0 -78
- data/test/log/data/sample.log +0 -1003
- data/test/model/spec_binary-operator.rb +0 -39
- data/test/model/spec_package.rb +0 -15
- data/test/model/spec_rule.rb +0 -158
- data/test/spec_identifier.rb +0 -29
- 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
|
-
#
|
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
|
208
|
+
# Return entries of the location.
|
187
209
|
#
|
188
210
|
# @return [Array<Location>]
|
189
|
-
# entries of the location
|
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
|
-
|
23
|
-
|
24
|
-
ftp.put(
|
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?
|
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
|
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
|
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
|
-
|
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
|
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
|
-
|
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
|
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-
|
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
|
-
#
|
4
|
-
class
|
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
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
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 +
|
48
|
+
(@domain_location + FILENAME).append(text)
|
37
49
|
end
|
38
50
|
|
39
51
|
private
|
@@ -1,11 +1,11 @@
|
|
1
1
|
module Pione
|
2
|
-
module
|
2
|
+
module Log
|
3
3
|
# ConsoleMessage is a set of utility methods for sending messages to user.
|
4
|
-
module
|
4
|
+
module MessageLog
|
5
5
|
# @api private
|
6
6
|
MESSAGE_QUEUE = Queue.new
|
7
7
|
|
8
|
-
#
|
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,
|
96
|
+
def debug_message(msg, level=0, head="debug")
|
97
97
|
if debug_mode? and not(quiet_mode?)
|
98
|
-
message(
|
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,
|
129
|
+
def user_message(msg, level=0, head="info", color=:green)
|
131
130
|
if not(quiet_mode?)
|
132
|
-
message(
|
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,
|
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,
|
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
|
-
|
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
|
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 [
|
33
|
-
# log
|
32
|
+
# @return [Hash{String => ProcessLog}]
|
33
|
+
# pairs of log id and the log
|
34
34
|
def read(location)
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
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
|
-
|
52
|
-
|
53
|
-
# Read records from the log file at the location.
|
63
|
+
# Return the record table grouped by the key.
|
54
64
|
#
|
55
|
-
# @
|
56
|
-
#
|
57
|
-
def
|
58
|
-
|
59
|
-
|
60
|
-
|
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
|
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
|
-
|
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
|
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}
|