summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormguetlein <martin.guetlein@gmail.com>2011-05-24 16:17:46 +0200
committermguetlein <martin.guetlein@gmail.com>2011-05-24 16:17:46 +0200
commite28863129af071e25ec581b46c4160aaba75c33d (patch)
treeaaa07ad41dd60f2a77f2abb52421bdbd53edf36d
parent908ccc82b2ef1680bff2a17b23cac5919de2e38e (diff)
add validation to tests again, slightly modify validation tests (qmrf model, more debugging options)
-rw-r--r--all.rb2
-rw-r--r--validation.rb41
2 files changed, 27 insertions, 16 deletions
diff --git a/all.rb b/all.rb
index 8c5babd..850a309 100644
--- a/all.rb
+++ b/all.rb
@@ -10,4 +10,4 @@ require './task.rb'
require './algorithm.rb'
require './fminer.rb'
require './lazar.rb'
-#require './validation.rb'
+require './validation.rb'
diff --git a/validation.rb b/validation.rb
index 74c6d23..0ff3c15 100644
--- a/validation.rb
+++ b/validation.rb
@@ -34,6 +34,8 @@ class ValidationTest < Test::Unit::TestCase
@@subjectid = nil
end
+ @@delete = true
+ @@feature_types = ["bbrc", "last"]
@@data = []
files = { #File.new("data/hamster_carcinogenicity.csv") => :crossvalidation,
File.new("data/hamster_carcinogenicity.mini.csv") => :crossvalidation,
@@ -61,11 +63,13 @@ class ValidationTest < Test::Unit::TestCase
def global_teardown
puts "delete and logout"
- @@data.each{|data| OpenTox::Dataset.find(data[:data],@@subjectid).delete(@@subjectid) if data[:delete]}
- @@vs.each{|v| v.delete(@@subjectid)} if defined?@@vs
- @@cvs.each{|cv| cv.delete(@@subjectid)} if defined?@@cvs
- @@reports.each{|report| report.delete(@@subjectid)} if defined?@@reports
- @@qmrfReports.each{|qmrfReport| qmrfReport.delete(@@subjectid)} if defined?@@qmrfReports
+ if @@delete
+ @@data.each{|data| OpenTox::Dataset.find(data[:data],@@subjectid).delete(@@subjectid) if data[:delete]}
+ @@vs.each{|v| v.delete(@@subjectid)} if defined?@@vs
+ @@cvs.each{|cv| cv.delete(@@subjectid)} if defined?@@cvs
+ @@reports.each{|report| report.delete(@@subjectid)} if defined?@@reports
+ @@qmrfReports.each{|qmrfReport| qmrfReport.delete(@@subjectid)} if defined?@@qmrfReports
+ end
OpenTox::Authorization.logout(@@subjectid) if AA_SERVER
end
@@ -113,6 +117,7 @@ class ValidationTest < Test::Unit::TestCase
assert model.uri?
v_list = OpenTox::Validation.list( {:model => model} )
assert v_list.size==1 and v_list.include?(v.uri)
+ puts v.uri unless @@delete
@@vs << v
end
end
@@ -147,6 +152,7 @@ class ValidationTest < Test::Unit::TestCase
assert_equal report.uri,report2.uri
report3_uri = v.find_or_create_report(@@subjectid)
assert_equal report.uri,report3_uri
+ puts report2.uri unless @@delete
@@reports << report2
end
end
@@ -170,7 +176,7 @@ class ValidationTest < Test::Unit::TestCase
@@cv_identifiers = []
@@data.each do |data|
if data[:type]==:crossvalidation
- ["bbrc", "last"].each do |fminer|
+ @@feature_types.each do |fminer|
puts "test_crossvalidation "+data[:info].to_s+" "+fminer
p = {
:dataset_uri => data[:data],
@@ -213,6 +219,7 @@ class ValidationTest < Test::Unit::TestCase
alg = OpenTox::Crossvalidation.find(cv_uri).metadata[OT.algorithm]
assert alg==algorithm,"wrong algorithm for filtered crossvalidation, should be: '"+algorithm.to_s+"', is: '"+alg.to_s+"'"
end
+ puts cv.uri unless @@delete
@@cvs << cv
@@cv_datasets << data
@@ -253,6 +260,7 @@ class ValidationTest < Test::Unit::TestCase
assert_equal report.uri,report2.uri
report3_uri = cv.find_or_create_report(@@subjectid)
assert_equal report.uri,report3_uri
+ puts report2.uri unless @@delete
@@reports << report2
end
end
@@ -288,6 +296,7 @@ class ValidationTest < Test::Unit::TestCase
assert_equal report.uri,report2.uri
report3 = OpenTox::AlgorithmComparisonReport.find_for_crossvalidation(@@cvs[j].uri,@@subjectid)
assert_equal report.uri,report3.uri
+ puts report2.uri unless @@delete
@@reports << report2
end
end
@@ -301,21 +310,23 @@ class ValidationTest < Test::Unit::TestCase
@@cvs.each do |cv|
puts "test_qmrf_report"
assert defined?cv,"no crossvalidation defined"
- validations = cv.metadata[OT.validation]
- assert_kind_of Array,validations
- assert validations.size==cv.metadata[OT.numFolds].to_i,validations.size.to_s+"!="+cv.metadata[OT.numFolds].to_s
- val = OpenTox::Validation.find(validations[0], @@subjectid)
- model_uri = val.metadata[OT.model]
-
+ model_uri = OpenTox::Algorithm::Lazar.new.run({:dataset_uri => cv.metadata[OT.dataset], :subjectid => @@subjectid}).to_s
+ assert model_uri.uri?
+# validations = cv.metadata[OT.validation]
+# assert_kind_of Array,validations
+# assert validations.size==cv.metadata[OT.numFolds].to_i,validations.size.to_s+"!="+cv.metadata[OT.numFolds].to_s
+# val = OpenTox::Validation.find(validations[0], @@subjectid)
+# model_uri = val.metadata[OT.model]
model = OpenTox::Model::Generic.find(model_uri, @@subjectid)
assert model!=nil
-
#assert_rest_call_error OpenTox::NotFoundError do
# OpenTox::QMRFReport.find_for_model(model_uri, @@subjectid)
#end
-
- @@qmrfReports << OpenTox::QMRFReport.create(model_uri, @@subjectid)
+ qmrfReport = OpenTox::QMRFReport.create(model_uri, @@subjectid)
+ puts qmrfReport.uri unless @@delete
+ @@qmrfReports << qmrfReport
end
+
end
################### utils and overrides ##########################