-
Notifications
You must be signed in to change notification settings - Fork 0
/
jruby_ispn_test.rb
220 lines (182 loc) · 5.99 KB
/
jruby_ispn_test.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
require 'java'
CURRENT_PATH = File.expand_path File.dirname(__FILE__)
DML_CONF_PATH = File.join(CURRENT_PATH, 'src', 'common', 'dml')
ISPN_CONF_PATH = File.join(CURRENT_PATH, 'config')
$CLASSPATH << ISPN_CONF_PATH
# load the jars
LIB_PATH = File.join(CURRENT_PATH, 'lib')
$CLASSPATH << LIB_PATH
Dir[File.join(LIB_PATH, '*.jar')].each{|jar|
#puts "Loading JAR: #{jar}"
require jar
}
# load the domain model jar
DIST_PATH = File.join(CURRENT_PATH, 'dist')
$CLASSPATH << DIST_PATH
require File.join(DIST_PATH, 'geograph-domain.jar')
# Load Fenix Framework
FenixConfig = Java::PtIstFenixframework::Config
FenixFramework = Java::PtIstFenixframework::FenixFramework
# Load the domain models
FenixGeoObject = Java::ItAlgoGeographDomain::GeoObject
FenixRoot = Java::ItAlgoGeographDomain::Root
# Load the CloudTM glue framework
CloudTmInit = Java::OrgCloudtmFramework::Init
CloudTmTxSystem = Java::OrgCloudtmFramework::TxSystem
CloudTmConfig = Java::OrgCloudtmFramework::CloudtmConfig
#FenixTransactionManager = Java::OrgCloudtmFrameworkFenix::FFTxManager
IspnTransactionManager = Java::OrgCloudtmFrameworkIspn::IspnTxManager
IllegalWriteException = Java::PtIstFenixframeworkPstm::IllegalWriteException
CommitException = Java::Jvstm::CommitException
WriteOnReadException = Java::Jvstm::WriteOnReadException
UnableToDetermineIdException = Java::PtIstFenixframeworkPstm::AbstractDomainObject::UnableToDetermineIdException
class TmpIspnTransactionManager
def withTransaction(&block)
result = nil
try_read_only = true
while(true) do
Java::PtIstFenixframeworkPstm::Transaction.begin(try_read_only)
finished = false
begin
result = block.call
Java::PtIstFenixframeworkPstm::Transaction.commit
finished = true
return result
rescue CommitException => ce
FenixTransaction.abort
finished = true
rescue WriteOnReadException => wore
puts "jvstm.WriteOnReadException"
Java::PtIstFenixframeworkPstm::Transaction.abort
finished = true
try_read_only = false
rescue UnableToDetermineIdException => unableToDetermineIdException
puts "Restaring TX: unable to determine id. Cause: #{unableToDetermineIdException.getCause}"
puts unableToDetermineIdException.to_s
Java::PtIstFenixframeworkPstm::Transaction.abort
finished = true
ensure
unless finished
Java::PtIstFenixframeworkPstm::Transaction.abort
end
end
end
end
end
# In order to bypass the use of the constructor with closure, that causes problems
# in the jruby binding.
# Here we open the Fenix Config class and we define a method that permits to
# valorize the same protected variables managed by the standard constructor.
class FenixConfig
# Accepts an hash of params, keys are instance variables of FenixConfig class
# and values are used to valorize these variables.
def init params
params.each do |name, value|
set_param(name, value)
end
end
private
# Sets an instance variable value.
def set_param(name, value)
# Jruby doesn't offer accessors for the protected variables.
field = self.java_class.declared_field name
field.accessible = true
field.set_value Java.ruby_to_java(self), Java.ruby_to_java(value)
end
end
class CloudTmTransactionManager
#cattr_accessor :manager
class << self
def manager
@manager
end
def manager=(man)
@manager = man
end
end
end
# This is the Fenix Framework loader. It provides a simple way to
# run the framework initialization process.
class FenixLoader
# Load the Fenix Framework.
# Options:
# => dml: the dml file name
# => conf: the configuration file name
# => root: the root class
def self.load(options)
config = FenixConfig.new
config.init(
:domainModelPath => File.join(DML_CONF_PATH, options[:dml]),
:dbAlias => File.join(ISPN_CONF_PATH, options[:conf]),
:rootClass => FenixRoot.java_class,
:repositoryType => FenixConfig::RepositoryType::INFINISPAN
)
CloudTmInit.initializeTxSystem(config, CloudTmConfig::Framework::ISPN)
CloudTmTransactionManager.manager = CloudTmTxSystem.getManager
end
end
class FenixGeoObject
# fake to_json method
def to_json
{
:id => oid,
:latitude => latitude.to_s,
:longitude => longitude.to_s
}
end
class << self
def create attrs = {}
manager = CloudTmTransactionManager.manager
manager.withTransaction do
instance = FenixGeoObject.new
attrs.each do |attr, value|
instance.send("#{attr}=", value)
end
manager.save instance
instance.set_root manager.getRoot
instance.to_json
end
end
def all
manager = CloudTmTransactionManager.manager
manager.withTransaction do
_geo_objects = manager.getRoot.getGeoObjects
_geo_objects.map(&:to_json)
end
end
end
end
FenixLoader.load({
:dml => 'geograph.dml',
:conf => 'infinispanFile.xml'
})
go = FenixGeoObject.create({
:latitude => java.math.BigDecimal.new("45.4324"),
:longitude => java.math.BigDecimal.new("23.6543")
})
puts "Created #{go.inspect}"
FenixGeoObject.all.each do |geo_object|
puts "Created geo object: lat = #{geo_object[:latitude]} - lon = #{geo_object[:longitude]}"
end
#puts "Json version: #{FenixGeoObject.all.to_json}"
FenixGeoObject.create({
:latitude => java.math.BigDecimal.new("72.6426"),
:longitude => java.math.BigDecimal.new("32.5425")
})
_manager = CloudTmTransactionManager.manager
_manager.withTransaction do
_gobjects = _manager.getRoot.getGeoObjects
go1 = _gobjects.toArray[0]
go2 = _gobjects.toArray[1]
go1.addIncoming(go2)
go1.latitude = nil
end
_manager.withTransaction do
_manager.getRoot.getGeoObjects.each do |gobj|
if gobj.hasAnyIncoming
puts "Link from: #{gobj.incoming.toArray[0].to_json.inspect}"
puts "Link to: #{gobj.incoming.toArray[0].outcoming.toArray[0].to_json.inspect}"
gobj.removeIncoming(gobj.incoming.toArray[0])
end
end
end