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
@@ -1,6 +1,7 @@
|
|
1
1
|
module Pione
|
2
2
|
module Log
|
3
|
-
# UnknownProcessRecordType is raised when we find unknown process
|
3
|
+
# UnknownProcessRecordType is raised when we find unknown process record
|
4
|
+
# types.
|
4
5
|
class UnknownProcessRecordType < StandardError
|
5
6
|
# @param type [Symbol]
|
6
7
|
# type name
|
@@ -8,15 +9,18 @@ module Pione
|
|
8
9
|
@type = type
|
9
10
|
end
|
10
11
|
|
11
|
-
# @api private
|
12
12
|
def message
|
13
13
|
'Unknown process type "%s"' % @type
|
14
14
|
end
|
15
15
|
end
|
16
16
|
|
17
17
|
# ProcessRecord is a class that represents records of process log. Records
|
18
|
-
# are in tuple spaces and handled by PIONE's logger agent.
|
18
|
+
# are in tuple spaces and handled by PIONE's process logger agent. If you
|
19
|
+
# want to add record type, you need to create the subclass of this.
|
19
20
|
class ProcessRecord
|
21
|
+
include SimpleIdentity
|
22
|
+
ignore_identity :log_id
|
23
|
+
|
20
24
|
# known process record types and classes
|
21
25
|
TYPE_TABLE = {}
|
22
26
|
|
@@ -52,15 +56,19 @@ module Pione
|
|
52
56
|
#
|
53
57
|
# @param name [Symbol]
|
54
58
|
# field name of the record
|
59
|
+
# @param type [Class]
|
60
|
+
# field data type
|
55
61
|
# @return [void]
|
56
62
|
def field(name)
|
57
63
|
unless (@fields ||= []).include?(name)
|
58
64
|
@fields << name
|
59
65
|
|
66
|
+
# field reader
|
60
67
|
define_method(name) do
|
61
68
|
instance_variable_get("@%s" % name)
|
62
69
|
end
|
63
70
|
|
71
|
+
# field writer
|
64
72
|
define_method("%s=" % name) do |val|
|
65
73
|
val = Time.parse(val) if name == :timestamp and val.kind_of?(String)
|
66
74
|
instance_variable_set("@%s" % name, val)
|
@@ -68,9 +76,10 @@ module Pione
|
|
68
76
|
end
|
69
77
|
end
|
70
78
|
|
71
|
-
#
|
72
|
-
def inherited(
|
73
|
-
|
79
|
+
# Subclass inherites superclass's fields.
|
80
|
+
def inherited(subclass)
|
81
|
+
subclass.instance_variable_set(:@__ignore_identities__, @__ignore_identities__.clone)
|
82
|
+
subclass.instance_variable_set(:@fields, @fields.clone)
|
74
83
|
end
|
75
84
|
end
|
76
85
|
|
@@ -84,6 +93,11 @@ module Pione
|
|
84
93
|
# transition name
|
85
94
|
field :transition
|
86
95
|
|
96
|
+
# @!attribute [rw]
|
97
|
+
# @return [String]
|
98
|
+
# log_id
|
99
|
+
field :log_id
|
100
|
+
|
87
101
|
forward! :class, :type, :fields
|
88
102
|
|
89
103
|
# Create a new process log record.
|
@@ -106,15 +120,15 @@ module Pione
|
|
106
120
|
end
|
107
121
|
end
|
108
122
|
|
109
|
-
# Format as JSON string.
|
123
|
+
# Format as a JSON string.
|
110
124
|
#
|
111
125
|
# @return [String]
|
112
126
|
# JSON string
|
113
|
-
def format
|
114
|
-
JSON.dump(to_hash)
|
127
|
+
def format(log_id)
|
128
|
+
JSON.dump(to_hash.merge(log_id: log_id))
|
115
129
|
end
|
116
130
|
|
117
|
-
# Convert record into a hash table.
|
131
|
+
# Convert the record into a hash table.
|
118
132
|
#
|
119
133
|
# @return [Hash]
|
120
134
|
# hash table representation of the record
|
@@ -129,7 +143,6 @@ module Pione
|
|
129
143
|
end
|
130
144
|
end
|
131
145
|
|
132
|
-
# @api private
|
133
146
|
def to_json(*args)
|
134
147
|
to_hash.to_json(*args)
|
135
148
|
end
|
@@ -0,0 +1,107 @@
|
|
1
|
+
module Pione
|
2
|
+
module Log
|
3
|
+
module SystemLog
|
4
|
+
# Log the fatal message.
|
5
|
+
#
|
6
|
+
# @param msg [String]
|
7
|
+
# the fatal message
|
8
|
+
def fatal(msg)
|
9
|
+
Global.system_logger.fatal(msg)
|
10
|
+
end
|
11
|
+
module_function :fatal
|
12
|
+
|
13
|
+
# Log the error message.
|
14
|
+
#
|
15
|
+
# @param msg [String]
|
16
|
+
# the error message
|
17
|
+
def error(msg)
|
18
|
+
Global.system_logger.error(msg)
|
19
|
+
end
|
20
|
+
module_function :error
|
21
|
+
|
22
|
+
# Log the warn message.
|
23
|
+
#
|
24
|
+
# @param msg [String]
|
25
|
+
# the warn message
|
26
|
+
def warn(msg)
|
27
|
+
Global.system_logger.warn(msg)
|
28
|
+
end
|
29
|
+
module_function :warn
|
30
|
+
|
31
|
+
# Log the info message.
|
32
|
+
#
|
33
|
+
# @param msg [String]
|
34
|
+
# the info message
|
35
|
+
def info(msg)
|
36
|
+
Global.system_logger.info(msg)
|
37
|
+
end
|
38
|
+
module_function :info
|
39
|
+
|
40
|
+
# Log the debug message.
|
41
|
+
#
|
42
|
+
# @param msg [String]
|
43
|
+
# the debug message
|
44
|
+
def debug(msg)
|
45
|
+
Global.system_logger.debug(msg)
|
46
|
+
end
|
47
|
+
module_function :debug
|
48
|
+
end
|
49
|
+
|
50
|
+
class SystemLogger
|
51
|
+
# Log the fatal message.
|
52
|
+
#
|
53
|
+
# @param msg [String]
|
54
|
+
# the fatal message
|
55
|
+
def fatal(msg)
|
56
|
+
raise NotImplementedError
|
57
|
+
end
|
58
|
+
|
59
|
+
# Log the error message.
|
60
|
+
#
|
61
|
+
# @param msg [String]
|
62
|
+
# the error message
|
63
|
+
def error(msg)
|
64
|
+
raise NotImplementedError
|
65
|
+
end
|
66
|
+
|
67
|
+
# Log the warn message.
|
68
|
+
#
|
69
|
+
# @param msg [String]
|
70
|
+
# the warn message
|
71
|
+
def warn(msg)
|
72
|
+
raise NotImplementedError
|
73
|
+
end
|
74
|
+
|
75
|
+
# Log the info message.
|
76
|
+
#
|
77
|
+
# @param msg [String]
|
78
|
+
# the info message
|
79
|
+
def info(msg)
|
80
|
+
raise NotImplementedError
|
81
|
+
end
|
82
|
+
|
83
|
+
# Log the debug message.
|
84
|
+
#
|
85
|
+
# @param msg [String]
|
86
|
+
# the debug message
|
87
|
+
def debug(msg)
|
88
|
+
raise NotImplementedError
|
89
|
+
end
|
90
|
+
end
|
91
|
+
|
92
|
+
# StandardSystemLogger is a logger using Ruby standard Logger.
|
93
|
+
class StandardSystemLogger
|
94
|
+
forward! :@logger, :fatal, :error, :warn, :info, :debug
|
95
|
+
|
96
|
+
def initialize(out)
|
97
|
+
@logger = Logger.new(out)
|
98
|
+
end
|
99
|
+
end
|
100
|
+
|
101
|
+
class SyslogSystemLogger < StandardSystemLogger
|
102
|
+
def initialize
|
103
|
+
@logger = Logger::Syslog.new('pione')
|
104
|
+
end
|
105
|
+
end
|
106
|
+
end
|
107
|
+
end
|
data/lib/pione/log/xes-log.rb
CHANGED
@@ -1,9 +1,21 @@
|
|
1
1
|
module Pione
|
2
2
|
module Log
|
3
3
|
# XESLog is a class for XES formatted log.
|
4
|
-
class XESLog <
|
4
|
+
class XESLog < ProcessLog
|
5
5
|
set_format_name :xes
|
6
6
|
|
7
|
+
attr_reader :agent_activity_log
|
8
|
+
attr_reader :rule_process_log
|
9
|
+
attr_reader :task_process_log
|
10
|
+
|
11
|
+
# @param records [Array<ProcessRecord>]
|
12
|
+
# log records
|
13
|
+
def initialize(records)
|
14
|
+
@agent_activity_log = AgentActivityLog.new(records)
|
15
|
+
@rule_process_log = RuleProcessLog.new(records)
|
16
|
+
@task_process_log = TaskProcessLog.new(records)
|
17
|
+
end
|
18
|
+
|
7
19
|
# Format as a XML document.
|
8
20
|
#
|
9
21
|
# @return [String]
|
@@ -14,7 +26,7 @@ module Pione
|
|
14
26
|
XES::Document.new.tap do |doc|
|
15
27
|
doc.log = XES::Log.default.tap do |log|
|
16
28
|
log.concept_name = "PIONE process log"
|
17
|
-
log.traces += [format_agent_activity + format_rule_process
|
29
|
+
log.traces += [format_agent_activity + [format_rule_process, format_task_process]].flatten.select(&filter)
|
18
30
|
log.traces.flatten!
|
19
31
|
end
|
20
32
|
if doc.formattable?
|
@@ -33,43 +45,39 @@ module Pione
|
|
33
45
|
#
|
34
46
|
# @return [Array<XES::Trace>]
|
35
47
|
def format_agent_activity
|
36
|
-
@
|
37
|
-
|
38
|
-
XES
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
event.lifecycle_transition = record.transition
|
47
|
-
end
|
48
|
+
@agent_activity_log.group_by(:agent_uuid).map do |agent_uuid, records|
|
49
|
+
XES::Trace.new.tap do |trace|
|
50
|
+
trace.attributes << XES.string("pione:traceType", "agent_activity")
|
51
|
+
trace.identity_id = agent_uuid
|
52
|
+
trace.events = records.sort{|a, b| a.timestamp <=> b.timestamp}.map do |record|
|
53
|
+
XES::Event.new.tap do |event|
|
54
|
+
event.concept_name = record.state
|
55
|
+
event.org_resource = record.agent_type
|
56
|
+
event.time_timestamp = record.timestamp
|
57
|
+
event.lifecycle_transition = record.transition
|
48
58
|
end
|
49
59
|
end
|
50
|
-
end
|
51
|
-
end
|
60
|
+
end
|
61
|
+
end.flatten
|
52
62
|
end
|
53
63
|
|
54
64
|
# Format rule process records.
|
55
65
|
#
|
56
|
-
# @return [
|
66
|
+
# @return [XES::Trace]
|
57
67
|
def format_rule_process
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
event.lifecycle_transition = record.transition
|
68
|
+
XES::Trace.new.tap do |trace|
|
69
|
+
trace.concept_name = "rule_process %s" % Util::UUID.generate
|
70
|
+
trace.attributes << XES.string("pione:traceType", "rule_process")
|
71
|
+
trace.events = @rule_process_log.records.map do |record|
|
72
|
+
XES::Event.new.tap do |event|
|
73
|
+
# standard attributes
|
74
|
+
event.concept_name = record.name
|
75
|
+
event.org_resource = record.caller
|
76
|
+
event.time_timestamp = record.timestamp
|
77
|
+
event.lifecycle_transition = record.transition
|
69
78
|
|
70
|
-
|
71
|
-
|
72
|
-
end
|
79
|
+
# pione extension attributes
|
80
|
+
event.attributes << XES.string("pione:ruleType", record.rule_type)
|
73
81
|
end
|
74
82
|
end
|
75
83
|
end
|
@@ -77,25 +85,23 @@ module Pione
|
|
77
85
|
|
78
86
|
# Format task process records.
|
79
87
|
#
|
80
|
-
# @return [
|
88
|
+
# @return [XES::Trace]
|
81
89
|
def format_task_process
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
event.lifecycle_transition = record.transition
|
90
|
+
XES::Trace.new.tap do |trace|
|
91
|
+
trace.concept_name = "task process %s" % Util::UUID.generate
|
92
|
+
trace.attributes << XES.string("pione:traceType", "task_process")
|
93
|
+
trace.events = @task_process_log.records.map do |record|
|
94
|
+
XES::Event.new.tap do |event|
|
95
|
+
# standard attributes
|
96
|
+
event.concept_name = record.name
|
97
|
+
# event.org_resource = record.caller
|
98
|
+
event.time_timestamp = record.timestamp
|
99
|
+
event.lifecycle_transition = record.transition
|
93
100
|
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
end
|
101
|
+
# pione extension attributes
|
102
|
+
event.attributes << XES.string("pione:ruleType", record.rule_type)
|
103
|
+
event.attributes << XES.string("pione:inputs", record.inputs)
|
104
|
+
event.attributes << XES.string("pione:parameters", record.parameters)
|
99
105
|
end
|
100
106
|
end
|
101
107
|
end
|
data/lib/pione/model.rb
CHANGED
@@ -14,16 +14,14 @@ require 'pione/model/variable'
|
|
14
14
|
require 'pione/model/variable-table'
|
15
15
|
require 'pione/model/data-expr'
|
16
16
|
require 'pione/model/parameters'
|
17
|
-
require 'pione/model/package'
|
17
|
+
require 'pione/model/package-expr'
|
18
18
|
require 'pione/model/ticket-expr'
|
19
19
|
require 'pione/model/rule-expr'
|
20
|
-
require 'pione/model/binary-operator'
|
21
20
|
require 'pione/model/message'
|
22
21
|
require 'pione/model/call-rule'
|
23
22
|
require 'pione/model/assignment'
|
24
23
|
require 'pione/model/block'
|
25
24
|
require 'pione/model/constraints'
|
26
|
-
require 'pione/model/rule'
|
27
25
|
|
28
26
|
module Pione
|
29
27
|
# Model is a name space for all PIONE models.
|
@@ -25,21 +25,26 @@ module Pione
|
|
25
25
|
# MethodNotFound is an exception class for the case of method missing.
|
26
26
|
class MethodNotFound < StandardError
|
27
27
|
attr_reader :name
|
28
|
-
attr_reader :
|
28
|
+
attr_reader :receiver
|
29
|
+
attr_reader :arguments
|
29
30
|
|
30
31
|
# Creates an exception.
|
31
|
-
# @param [String
|
32
|
+
# @param name [String]
|
32
33
|
# method name
|
33
|
-
# @param [
|
34
|
+
# @param receiver [Callable]
|
34
35
|
# method reciever
|
35
|
-
|
36
|
+
# @param arguments [Array<Callable>]
|
37
|
+
# method arguments
|
38
|
+
def initialize(name, receiver, *arguments)
|
36
39
|
@name = name
|
37
|
-
@
|
40
|
+
@receiver = receiver
|
41
|
+
@arguments = arguments
|
38
42
|
end
|
39
43
|
|
40
|
-
# @api private
|
41
44
|
def message
|
42
|
-
|
45
|
+
rec_type = @receiver.pione_model_type
|
46
|
+
arg_types = @arguments.map{|arg| arg.pione_model_type}.join(" -> ")
|
47
|
+
"PIONE method \"%s\" is not found: %s. %s" % [@name, rec_type, arg_types]
|
43
48
|
end
|
44
49
|
end
|
45
50
|
|
@@ -162,17 +167,19 @@ module Pione
|
|
162
167
|
|
163
168
|
# Call pione model object method.
|
164
169
|
#
|
165
|
-
# @param [
|
166
|
-
#
|
167
|
-
# @param [
|
170
|
+
# @param vtable [VariableTable]
|
171
|
+
# variable table
|
172
|
+
# @param name [String]
|
173
|
+
# method's name
|
174
|
+
# @param args [Array]
|
168
175
|
# method's arguments
|
169
176
|
# @return [Object]
|
170
|
-
#
|
171
|
-
def call_pione_method(name, *args)
|
177
|
+
# the result
|
178
|
+
def call_pione_method(vtable, name, *args)
|
172
179
|
if pione_method = pione_model_type.find_method(name, self, *args)
|
173
|
-
pione_method.call(self, *args)
|
180
|
+
pione_method.call(vtable, self, *args)
|
174
181
|
else
|
175
|
-
raise MethodNotFound.new(name, self)
|
182
|
+
raise MethodNotFound.new(name, self, *args)
|
176
183
|
end
|
177
184
|
end
|
178
185
|
|
@@ -184,6 +191,8 @@ module Pione
|
|
184
191
|
end
|
185
192
|
|
186
193
|
class Element < BasicModel
|
194
|
+
include SimpleIdentity
|
195
|
+
|
187
196
|
class << self
|
188
197
|
attr_reader :sequence_class
|
189
198
|
|
@@ -200,13 +209,20 @@ module Pione
|
|
200
209
|
end
|
201
210
|
|
202
211
|
class Value < Element
|
212
|
+
include SimpleIdentity
|
213
|
+
|
203
214
|
attr_reader :value
|
204
215
|
|
205
|
-
# @param value [
|
216
|
+
# @param value [Object]
|
206
217
|
# value in ruby
|
207
218
|
def initialize(value)
|
208
219
|
@value = value
|
209
220
|
end
|
221
|
+
|
222
|
+
def inspect
|
223
|
+
'#<%s "%s">' % [self.class.name, @value]
|
224
|
+
end
|
225
|
+
alias :to_s :inspect
|
210
226
|
end
|
211
227
|
end
|
212
228
|
end
|